LSST Applications  21.0.0-131-g8cabc107+528f53ee53,22.0.0+00495a2688,22.0.0+0ef2527977,22.0.0+11a2aa21cd,22.0.0+269b7e55e3,22.0.0+2c6b6677a3,22.0.0+64c1bc5aa5,22.0.0+7b3a3f865e,22.0.0+e1b6d2281c,22.0.0+ff3c34362c,22.0.1-1-g1b65d06+c95cbdf3df,22.0.1-1-g7058be7+1cf78af69b,22.0.1-1-g7dab645+2a65e40b06,22.0.1-1-g8760c09+64c1bc5aa5,22.0.1-1-g949febb+64c1bc5aa5,22.0.1-1-ga324b9c+269b7e55e3,22.0.1-1-gf9d8b05+ff3c34362c,22.0.1-10-g781e53d+9b51d1cd24,22.0.1-10-gba590ab+b9624b875d,22.0.1-13-g76f9b8d+2c6b6677a3,22.0.1-14-g22236948+57af756299,22.0.1-18-g3db9cf4b+9b7092c56c,22.0.1-18-gb17765a+2264247a6b,22.0.1-2-g8ef0a89+2c6b6677a3,22.0.1-2-gcb770ba+c99495d3c6,22.0.1-24-g2e899d296+4206820b0d,22.0.1-3-g7aa11f2+2c6b6677a3,22.0.1-3-g8c1d971+f253ffa91f,22.0.1-3-g997b569+ff3b2f8649,22.0.1-4-g1930a60+6871d0c7f6,22.0.1-4-g5b7b756+6b209d634c,22.0.1-6-ga02864e+6871d0c7f6,22.0.1-7-g3402376+a1a2182ac4,22.0.1-7-g65f59fa+54b92689ce,master-gcc5351303a+e1b6d2281c,w.2021.32
LSST Data Management Base Package
Classes | Functions
lsst.cp.pipe.ptc.photodiode Namespace Reference

Classes

class  PhotodiodeData
 

Functions

def getBOTphotodiodeData (dataRef, dataPath='/project/shared/BOT/_parent/raw/photodiode_data/', logger=None)
 

Function Documentation

◆ getBOTphotodiodeData()

def lsst.cp.pipe.ptc.photodiode.getBOTphotodiodeData (   dataRef,
  dataPath = '/project/shared/BOT/_parent/raw/photodiode_data/',
  logger = None 
)
Get the photodiode data associated with a BOT dataRef.

This is a temporary Gen2-only interface to the photodiode readings from
the SLAC Run3 datasets onwards.

Parameters
----------
dataRef : `lsst.daf.persistence.ButlerDataRef`
    dataRef of the of the detector/visit to load the data for.

dataPath : `str`, optional
    Path at which to find the corresponding photodiode data files.

logger : `lsst.log.Log`, optional
    Logger for logging warnings.


Returns
-------
photodiodeData : `lsst.cp.pipe.photodiode.PhotodiodeData` or `None`
    The full time-series of the photodiode readings, with methods to
    integrate the photocharge, or None if the expected file isn't found.

Definition at line 30 of file photodiode.py.

31  logger=None):
32  """Get the photodiode data associated with a BOT dataRef.
33 
34  This is a temporary Gen2-only interface to the photodiode readings from
35  the SLAC Run3 datasets onwards.
36 
37  Parameters
38  ----------
39  dataRef : `lsst.daf.persistence.ButlerDataRef`
40  dataRef of the of the detector/visit to load the data for.
41 
42  dataPath : `str`, optional
43  Path at which to find the corresponding photodiode data files.
44 
45  logger : `lsst.log.Log`, optional
46  Logger for logging warnings.
47 
48 
49  Returns
50  -------
51  photodiodeData : `lsst.cp.pipe.photodiode.PhotodiodeData` or `None`
52  The full time-series of the photodiode readings, with methods to
53  integrate the photocharge, or None if the expected file isn't found.
54 
55  """
56  if logger is None:
57  logger = lsstLog.Log.getDefaultLogger()
58 
59  def getKeyFromDataId(dataRef, key):
60  if key in dataRef.dataId:
61  return dataRef.dataId[key]
62  else:
63  result = dataRef.getButler().queryMetadata('raw', key, dataRef.dataId)
64  assert len(result) == 1, f"Failed to find unique value for {key} with {dataRef.dataId}"
65  return result[0]
66 
67  dayObs = getKeyFromDataId(dataRef, 'dayObs')
68  seqNum = getKeyFromDataId(dataRef, 'seqNum')
69 
70  filePattern = 'Photodiode_Readings_%s_%06d.txt'
71 
72  dayObsAsNumber = dayObs.replace('-', '')
73  diodeFilename = os.path.join(dataPath, filePattern % (dayObsAsNumber, seqNum))
74 
75  if not os.path.exists(diodeFilename):
76  logger.warn(f"Failed to find the photodiode data at {diodeFilename}")
77  return None
78 
79  try:
80  photodiodeData = PhotodiodeData(diodeFilename)
81  return photodiodeData
82  except Exception:
83  logger.warn(f"Photodiode data found at {diodeFilename} but failed to load.")
84  return None
85 
86