LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
makeTestRawVisitInfo.py
Go to the documentation of this file.
1 # This file is part of obs_test.
2 #
3 # Developed for the LSST Data Management System.
4 # This product includes software developed by the LSST Project
5 # (http://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 <http://www.gnu.org/licenses/>.
21 #
22 __all__ = ["MakeTestRawVisitInfo"]
23 
24 from lsst.afw.image import VisitInfo, RotType
25 from lsst.geom import degrees, SpherePoint
26 from lsst.afw.coord import Observatory, Weather
27 from lsst.obs.base import MakeRawVisitInfo
28 
29 
30 class MakeTestRawVisitInfo(MakeRawVisitInfo):
31  """Make a VisitInfo from the FITS header of a test image.
32 
33  Notes
34  -----
35  Since the test data is extracted from LSST Sim data,
36  this is a copy of MakeLsstSimRawVisitInfo
37  (using a copy avoids undesireable dependencies).
38  """
39  observatory = Observatory(-70.749417*degrees, -30.244633*degrees, 2663) # long, lat, elev
40 
41  def setArgDict(self, md, argDict):
42  """Set an argument dict for VisitInfo and pop associated metadata.
43 
44  Parameters
45  ----------
46  md : `lsst.daf.base.PropertySet`
47  Image metadata.
48  argDict : `dict`
49  A dict of arguments for the `lsst.afw.image.VisitInfo`
50  constructor. Updated by this call.
51 
52  Returns
53  -------
54  visitInfo : `lsst.afw.image.VisitInfo`
55  Visit information.
56  """
57  MakeRawVisitInfo.setArgDict(self, md, argDict)
58  argDict["darkTime"] = self.popFloat(md, "DARKTIME")
59  argDict["boresightAzAlt"] = SpherePoint(
60  self.popAngle(md, "AZIMUTH"),
61  self.altitudeFromZenithDistance(self.popAngle(md, "ZENITH")),
62  )
63  argDict["boresightRaDec"] = SpherePoint(
64  self.popAngle(md, "RA_DEG"),
65  self.popAngle(md, "DEC_DEG"),
66  )
67  argDict["boresightAirmass"] = self.popFloat(md, "AIRMASS")
68  argDict["boresightRotAngle"] = -self.popAngle(md, "ROTANG")
69  argDict["rotType"] = RotType.SKY
70  argDict["observatory"] = self.observatoryobservatory
71  argDict["weather"] = Weather(
72  self.popFloat(md, "TEMPERA"),
73  self.pascalFromMmHg(self.popFloat(md, "PRESS")),
74  float("nan"),
75  )
76  return VisitInfo(**argDict)
77 
78  def getDateAvg(self, md, exposureTime):
79  """Return date at the middle of the exposure.
80 
81  Parameters
82  ----------
83  md : `lsst.daf.base.PropertySet`
84  Image metadata.
85  exposureTime : `float`
86  Exposure time, in sec
87 
88  Returns
89  -------
90  dateAvg : `lsst.daf.base.DateTime`
91  Date at middle of the exposure, or `lsst.daf.base.DateTime()`
92  if the metadata item ``TAI`` is not found.
93  """
94  startDate = self.popMjdDate(md, "TAI", timesys="TAI")
95  return self.offsetDate(startDate, 0.5*exposureTime)
Hold the location of an observatory.
Definition: Observatory.h:43
Basic weather information sufficient for a simple model for air mass or refraction.
Definition: Weather.h:38
Information about a single exposure of an imaging camera.
Definition: VisitInfo.h:68
Point in an unspecified spherical coordinate system.
Definition: SpherePoint.h:57
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects.