LSSTApplications  19.0.0-14-gb0260a2+72efe9b372,20.0.0+7927753e06,20.0.0+8829bf0056,20.0.0+995114c5d2,20.0.0+b6f4b2abd1,20.0.0+bddc4f4cbe,20.0.0-1-g253301a+8829bf0056,20.0.0-1-g2b7511a+0d71a2d77f,20.0.0-1-g5b95a8c+7461dd0434,20.0.0-12-g321c96ea+23efe4bbff,20.0.0-16-gfab17e72e+fdf35455f6,20.0.0-2-g0070d88+ba3ffc8f0b,20.0.0-2-g4dae9ad+ee58a624b3,20.0.0-2-g61b8584+5d3db074ba,20.0.0-2-gb780d76+d529cf1a41,20.0.0-2-ged6426c+226a441f5f,20.0.0-2-gf072044+8829bf0056,20.0.0-2-gf1f7952+ee58a624b3,20.0.0-20-geae50cf+e37fec0aee,20.0.0-25-g3dcad98+544a109665,20.0.0-25-g5eafb0f+ee58a624b3,20.0.0-27-g64178ef+f1f297b00a,20.0.0-3-g4cc78c6+e0676b0dc8,20.0.0-3-g8f21e14+4fd2c12c9a,20.0.0-3-gbd60e8c+187b78b4b8,20.0.0-3-gbecbe05+48431fa087,20.0.0-38-ge4adf513+a12e1f8e37,20.0.0-4-g97dc21a+544a109665,20.0.0-4-gb4befbc+087873070b,20.0.0-4-gf910f65+5d3db074ba,20.0.0-5-gdfe0fee+199202a608,20.0.0-5-gfbfe500+d529cf1a41,20.0.0-6-g64f541c+d529cf1a41,20.0.0-6-g9a5b7a1+a1cd37312e,20.0.0-68-ga3f3dda+5fca18c6a4,20.0.0-9-g4aef684+e18322736b,w.2020.45
LSSTDataManagementBasePackage
camera_tests.py
Go to the documentation of this file.
1 # This file is part of obs_base.
2 #
3 # Developed for the LSST Data Management System.
4 # This product includes software developed by the LSST Project
5 # (https://www.lsst.org).
6 # See the COPYRIGHT file at the top-level directory of this distribution
7 # for details of code ownership.
8 #
9 # This program is free software: you can redistribute it and/or modify
10 # it under the terms of the GNU General Public License as published by
11 # the Free Software Foundation, either version 3 of the License, or
12 # (at your option) any later version.
13 #
14 # This program is distributed in the hope that it will be useful,
15 # but WITHOUT ANY WARRANTY; without even the implied warranty of
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 # GNU General Public License for more details.
18 #
19 # You should have received a copy of the GNU General Public License
20 # along with this program. If not, see <https://www.gnu.org/licenses/>.
21 
22 import abc
23 import collections
24 import math
25 
26 import lsst.geom
27 from lsst.afw.cameraGeom import FOCAL_PLANE, FIELD_ANGLE
28 
29 __all__ = ["CameraTests"]
30 
31 
32 class CameraTests(metaclass=abc.ABCMeta):
33  """Tests that the butler returns a useable Camera.
34 
35  In the subclasses's setUp():
36  * Call setUp_camera() to fill in required parameters.
37  """
38 
39  def setUp_camera(self,
40  camera_name=None,
41  n_detectors=None,
42  first_detector_name=None,
43  plate_scale=None,
44  ):
45  """Set up the necessary variables for camera tests.
46 
47  Parameters
48  ----------
49 
50  camera_name : `str`
51  name of this camera
52  n_detectors : `int`
53  number of detectors in this camera
54  first_detector_name : `str`
55  name of the first detector in this camera
56  plate_scale : `lsst.geom.Angle`
57  plate scale at center of focal plane, as angle-on-sky/mm
58  """
59  fields = ['camera_name',
60  'n_detectors',
61  'first_detector_name',
62  'plate_scale',
63  ]
64  CameraData = collections.namedtuple("CameraData", fields)
65  self.camera_data = CameraData(camera_name=camera_name,
66  n_detectors=n_detectors,
67  first_detector_name=first_detector_name,
68  plate_scale=plate_scale,
69  )
70 
71  def test_iterable(self):
72  """Simplest camera test: can we get a Camera instance, and does
73  iterating return Detectors?"""
74  camera = self.butler.get('camera', immediate=True)
75  self.assertIsInstance(camera, lsst.afw.cameraGeom.Camera)
76  for detector in camera:
77  msg = "Failed for detector={}".format(detector)
78  self.assertIsInstance(detector, lsst.afw.cameraGeom.Detector, msg=msg)
79 
80  def test_camera_butler(self):
81  """Check that the butler returns the right type of camera."""
82  camera = self.butler.get('camera', immediate=True)
83  self.assertEqual(camera.getName(), self.camera_data.camera_name)
84  self.assertEqual(len(camera), self.camera_data.n_detectors)
85  self.assertEqual(next(iter(camera)).getName(), self.camera_data.first_detector_name)
86 
87  def test_plate_scale(self):
88  """Check the plate scale at center of focal plane
89 
90  Check plate_scale using the FOCAL_PLANE to FIELD_ANGLE transform
91  from the camera.
92  """
93  plate_scale = self.camera_data.plate_scale
94  self.assertIsNotNone(plate_scale)
95  camera = self.butler.get('camera', immediate=True)
96  focalPlaneToFieldAngle = camera.getTransformMap().getTransform(FOCAL_PLANE, FIELD_ANGLE)
97  focalPlaneRadiusMm = 0.001 # an offset small enough to be in the linear regime
98  for offsetAngleRad in (0.0, 0.65, 1.3): # direction of offset; a few arbitrary angles
99  cosAng = math.cos(offsetAngleRad)
100  sinAng = math.sin(offsetAngleRad)
101  fieldAngleRadians = focalPlaneToFieldAngle.applyForward(
102  lsst.geom.Point2D(cosAng * focalPlaneRadiusMm, sinAng * focalPlaneRadiusMm))
103  fieldAngleRadius = math.hypot(*fieldAngleRadians) * lsst.geom.radians
104  measuredScale1 = fieldAngleRadius / focalPlaneRadiusMm
105  self.assertAnglesAlmostEqual(measuredScale1, plate_scale)
106 
107  focalPlanePos = focalPlaneToFieldAngle.applyInverse(
108  lsst.geom.Point2D(fieldAngleRadius.asRadians() * cosAng,
109  fieldAngleRadius.asRadians() * sinAng))
110  focalPlaneRadiusMm2 = math.hypot(*focalPlanePos)
111  measureScale2 = fieldAngleRadius / focalPlaneRadiusMm2
112  self.assertAnglesAlmostEqual(measureScale2, plate_scale)
lsst::afw::cameraGeom::Camera
An immutable representation of a camera.
Definition: Camera.h:43
astshim.fitsChanContinued.next
def next(self)
Definition: fitsChanContinued.py:105
lsst.obs.base.camera_tests.CameraTests.camera_data
camera_data
Definition: camera_tests.py:60
lsst.obs.base.camera_tests.CameraTests
Definition: camera_tests.py:32
lsst.obs.base.camera_tests.CameraTests.test_iterable
def test_iterable(self)
Definition: camera_tests.py:71
lsst.pex.config.history.format
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:174
lsst.obs.base.camera_tests.CameraTests.test_plate_scale
def test_plate_scale(self)
Definition: camera_tests.py:87
lsst.obs.base.camera_tests.CameraTests.setUp_camera
def setUp_camera(self, camera_name=None, n_detectors=None, first_detector_name=None, plate_scale=None)
Definition: camera_tests.py:39
lsst::geom
Definition: AffineTransform.h:36
lsst::afw::cameraGeom
Definition: Amplifier.h:33
lsst.obs.base.camera_tests.CameraTests.test_camera_butler
def test_camera_butler(self)
Definition: camera_tests.py:80
lsst::geom::Point< double, 2 >
astshim.fitsChanContinued.iter
def iter(self)
Definition: fitsChanContinued.py:88
lsst::afw::cameraGeom::Detector
A representation of a detector in a mosaic camera.
Definition: Detector.h:185