LSST Applications  21.0.0+75b29a8a7f,21.0.0+e70536a077,21.0.0-1-ga51b5d4+62c747d40b,21.0.0-10-gbfb87ad6+3307648ee3,21.0.0-15-gedb9d5423+47cba9fc36,21.0.0-2-g103fe59+fdf0863a2a,21.0.0-2-g1367e85+d38a93257c,21.0.0-2-g45278ab+e70536a077,21.0.0-2-g5242d73+d38a93257c,21.0.0-2-g7f82c8f+e682ffb718,21.0.0-2-g8dde007+d179fbfa6a,21.0.0-2-g8f08a60+9402881886,21.0.0-2-ga326454+e682ffb718,21.0.0-2-ga63a54e+08647d4b1b,21.0.0-2-gde069b7+26c92b3210,21.0.0-2-gecfae73+0445ed2f95,21.0.0-2-gfc62afb+d38a93257c,21.0.0-27-gbbd0d29+ae871e0f33,21.0.0-28-g5fc5e037+feb0e9397b,21.0.0-3-g21c7a62+f4b9c0ff5c,21.0.0-3-g357aad2+57b0bddf0b,21.0.0-3-g4be5c26+d38a93257c,21.0.0-3-g65f322c+3f454acf5d,21.0.0-3-g7d9da8d+75b29a8a7f,21.0.0-3-gaa929c8+9e4ef6332c,21.0.0-3-ge02ed75+4b120a55c4,21.0.0-4-g3300ddd+e70536a077,21.0.0-4-g591bb35+4b120a55c4,21.0.0-4-gc004bbf+4911b9cd27,21.0.0-4-gccdca77+f94adcd104,21.0.0-4-ge8fba5a+2b3a696ff9,21.0.0-5-gb155db7+2c5429117a,21.0.0-5-gdf36809+637e4641ee,21.0.0-6-g00874e7+c9fd7f7160,21.0.0-6-g4e60332+4b120a55c4,21.0.0-7-gc8ca178+40eb9cf840,21.0.0-8-gfbe0b4b+9e4ef6332c,21.0.0-9-g2fd488a+d83b7cd606,w.2021.05
LSST Data Management Base Package
Public Member Functions | Public Attributes | List of all members
lsst.obs.base.camera_tests.CameraTests Class Reference
Inheritance diagram for lsst.obs.base.camera_tests.CameraTests:
lsst.obs.base.tests.ObsTests

Public Member Functions

def setUp_camera (self, camera_name=None, n_detectors=None, first_detector_name=None, plate_scale=None)
 
def test_iterable (self)
 
def test_camera_butler (self)
 
def test_plate_scale (self)
 

Public Attributes

 camera_data
 

Detailed Description

Tests that the butler returns a useable Camera.

In the subclasses's setUp():
    * Call setUp_camera() to fill in required parameters.

Definition at line 32 of file camera_tests.py.

Member Function Documentation

◆ setUp_camera()

def lsst.obs.base.camera_tests.CameraTests.setUp_camera (   self,
  camera_name = None,
  n_detectors = None,
  first_detector_name = None,
  plate_scale = None 
)
Set up the necessary variables for camera tests.

Parameters
----------

camera_name : `str`
    name of this camera
n_detectors : `int`
    number of detectors in this camera
first_detector_name : `str`
    name of the first detector in this camera
plate_scale : `lsst.geom.Angle`
    plate scale at center of focal plane, as angle-on-sky/mm

Definition at line 39 of file camera_tests.py.

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 

◆ test_camera_butler()

def lsst.obs.base.camera_tests.CameraTests.test_camera_butler (   self)
Check that the butler returns the right type of camera.

Definition at line 80 of file camera_tests.py.

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 
std::string const & getName() const noexcept
Return a filter's name.
Definition: Filter.h:78

◆ test_iterable()

def lsst.obs.base.camera_tests.CameraTests.test_iterable (   self)
Simplest camera test: can we get a Camera instance, and does
iterating return Detectors?

Definition at line 71 of file camera_tests.py.

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 
An immutable representation of a camera.
Definition: Camera.h:43
A representation of a detector in a mosaic camera.
Definition: Detector.h:185
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:174

◆ test_plate_scale()

def lsst.obs.base.camera_tests.CameraTests.test_plate_scale (   self)
Check the plate scale at center of focal plane

Check plate_scale using the FOCAL_PLANE to FIELD_ANGLE transform
from the camera.

Definition at line 87 of file camera_tests.py.

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)

Member Data Documentation

◆ camera_data

lsst.obs.base.camera_tests.CameraTests.camera_data

Definition at line 65 of file camera_tests.py.


The documentation for this class was generated from the following file: