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
PhotoCalib.h
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2017 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
23 #ifndef LSST_AFW_IMAGE_PHOTOCALIB_H
24 #define LSST_AFW_IMAGE_PHOTOCALIB_H
25 
32 #include "boost/format.hpp"
33 
36 #include "lsst/geom/Point.h"
37 #include "lsst/geom/Box.h"
38 #include "lsst/afw/table/Source.h"
44 #include "lsst/utils/Magnitude.h"
45 
46 namespace lsst {
47 namespace afw {
48 namespace image {
49 
51 struct Measurement {
52  Measurement(double value, double error) : value(value), error(error) {}
53  double const value;
54  double const error;
55 };
56 
57 std::ostream &operator<<(std::ostream &os, Measurement const &measurement);
58 
69 inline void assertNonNegative(double value, std::string const &name) {
70  if (value < 0) {
72  (boost::format("%s must be positive: %.3g") % name % value).str());
73  }
74 }
75 
115 public:
116  // Allow move, but no copy
117  PhotoCalib(PhotoCalib const &) = default;
118  PhotoCalib(PhotoCalib &&) = default;
119  PhotoCalib &operator=(PhotoCalib const &) = delete;
121 
122  ~PhotoCalib() override = default;
123 
128 
137  explicit PhotoCalib(double calibrationMean, double calibrationErr = 0,
139  : _calibrationMean(calibrationMean), _calibrationErr(calibrationErr), _isConstant(true) {
140  assertNonNegative(_calibrationMean, "Calibration mean");
141  assertNonNegative(_calibrationErr, "Calibration error");
142  ndarray::Array<double, 2, 2> coeffs = ndarray::allocate(ndarray::makeVector(1, 1));
143  coeffs[0][0] = calibrationMean;
144  _calibration = std::make_shared<afw::math::ChebyshevBoundedField>(
146  }
147 
155  : _calibration(calibration),
156  _calibrationMean(computeCalibrationMean(calibration)),
157  _calibrationErr(calibrationErr),
158  _isConstant(false) {
159  assertNonNegative(_calibrationMean, "Calibration (computed via BoundedField.mean()) mean");
160  assertNonNegative(_calibrationErr, "Calibration error");
161  }
162 
173  : _calibration(calibration),
174  _calibrationMean(calibrationMean),
175  _calibrationErr(calibrationErr),
176  _isConstant(isConstant) {
177  assertNonNegative(_calibrationMean, "Calibration mean");
178  assertNonNegative(_calibrationErr, "Calibration error");
179  }
180 
191  double instFluxToNanojansky(double instFlux, lsst::geom::Point<double, 2> const &point) const;
192 
194  double instFluxToNanojansky(double instFlux) const;
195 
207  Measurement instFluxToNanojansky(double instFlux, double instFluxErr,
208  lsst::geom::Point<double, 2> const &point) const;
209 
211  Measurement instFluxToNanojansky(double instFlux, double instFluxErr) const;
212 
226  std::string const &instFluxField) const;
227 
240  ndarray::Array<double, 2, 2> instFluxToNanojansky(afw::table::SourceCatalog const &sourceCatalog,
241  std::string const &instFluxField) const;
242 
256  void instFluxToNanojansky(afw::table::SourceCatalog &sourceCatalog, std::string const &instFluxField,
257  std::string const &outField) const;
258 
269  double instFluxToMagnitude(double instFlux, lsst::geom::Point<double, 2> const &point) const;
270 
272  double instFluxToMagnitude(double instFlux) const;
273 
285  Measurement instFluxToMagnitude(double instFlux, double instFluxErr,
286  lsst::geom::Point<double, 2> const &point) const;
287 
289  Measurement instFluxToMagnitude(double instFlux, double instFluxErr) const;
290 
304  std::string const &instFluxField) const;
305 
318  ndarray::Array<double, 2, 2> instFluxToMagnitude(afw::table::SourceCatalog const &sourceCatalog,
319  std::string const &instFluxField) const;
320 
337  void instFluxToMagnitude(afw::table::SourceCatalog &sourceCatalog, std::string const &instFluxField,
338  std::string const &outField) const;
339 
351  bool includeScaleUncertainty = true) const;
352 
370  std::vector<std::string> const &instFluxFields) const;
371 
374 
387  double magnitudeToInstFlux(double magnitude, lsst::geom::Point<double, 2> const &point) const;
388 
390  double magnitudeToInstFlux(double magnitude) const;
391 
404  double getCalibrationMean() const { return _calibrationMean; }
405 
418  double getCalibrationErr() const { return _calibrationErr; }
419 
432  double getInstFluxAtZeroMagnitude() const { return utils::referenceFlux / _calibrationMean; }
433 
450  double getLocalCalibration(lsst::geom::Point<double, 2> const &point) const { return evaluate(point); }
451 
466 
489 
491  bool operator==(PhotoCalib const &rhs) const;
492 
494  bool operator!=(PhotoCalib const &rhs) const { return !(*this == rhs); }
495 
496  bool isPersistable() const noexcept override { return true; }
497 
500 
502  std::string toString() const override;
503 
509  bool equals(typehandling::Storable const &other) const noexcept override;
510  // PhotoCalib equality comparable but intentionally not hashable
511 
512 protected:
513  std::string getPersistenceName() const override;
514 
515  void write(OutputArchiveHandle &handle) const override;
516 
517 private:
519 
520  // The "mean" calibration, defined as the geometric mean of _calibration evaluated over _calibration's
521  // bbox. Computed on instantiation as a convinience. Also, the actual calibration for a spatially-constant
522  // calibration.
523  double _calibrationMean;
524 
525  // The standard deviation of this PhotoCalib.
526  double _calibrationErr;
527 
528  // Is this spatially-constant? Used to short-circuit getting centroids.
529  bool _isConstant;
530 
536  double evaluate(lsst::geom::Point<double, 2> const &point) const;
540  ndarray::Array<double, 1> evaluateArray(ndarray::Array<double, 1> const &xx,
541  ndarray::Array<double, 1> const &yy) const;
545  ndarray::Array<double, 1> evaluateCatalog(afw::table::SourceCatalog const &sourceCatalog) const;
546 
548  double computeCalibrationMean(std::shared_ptr<afw::math::BoundedField> calibration) const;
549 
551  void instFluxToNanojanskyArray(afw::table::SourceCatalog const &sourceCatalog,
552  std::string const &instFluxField,
553  ndarray::Array<double, 2, 2> result) const;
554  void instFluxToMagnitudeArray(afw::table::SourceCatalog const &sourceCatalog,
555  std::string const &instFluxField,
556  ndarray::Array<double, 2, 2> result) const;
557 };
558 
571 
585 std::shared_ptr<PhotoCalib> makePhotoCalibFromCalibZeroPoint(double instFluxMag0, double instFluxMag0Err);
586 
587 } // namespace image
588 } // namespace afw
589 } // namespace lsst
590 
591 #endif // LSST_AFW_IMAGE_PHOTOCALIB_H
py::object result
Definition: _schema.cc:429
table::Key< std::string > name
Definition: Amplifier.cc:116
AmpInfoBoxKey bbox
Definition: Amplifier.cc:117
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
table::Key< double > calibrationMean
Definition: PhotoCalib.cc:369
table::Key< double > calibrationErr
Definition: PhotoCalib.cc:370
table::Key< table::Flag > isConstant
Definition: PhotoCalib.cc:371
std::ostream * os
Definition: Schema.cc:557
A class to manipulate images, masks, and variance as a single object.
Definition: MaskedImage.h:73
The photometric calibration of an exposure.
Definition: PhotoCalib.h:114
PhotoCalib(double calibrationMean, double calibrationErr, std::shared_ptr< afw::math::BoundedField > calibration, bool isConstant)
Create a calibration with a pre-computed mean.
Definition: PhotoCalib.h:171
afw::table::SourceCatalog calibrateCatalog(afw::table::SourceCatalog const &catalog, std::vector< std::string > const &instFluxFields) const
Return a flux calibrated catalog, with new _flux, _fluxErr, _mag, and _magErr fields.
Definition: PhotoCalib.cc:282
bool operator==(PhotoCalib const &rhs) const
Two PhotoCalibs are equal if their component bounded fields and calibrationErr are equal.
Definition: PhotoCalib.cc:229
double getCalibrationMean() const
Get the mean photometric calibration.
Definition: PhotoCalib.h:404
PhotoCalib & operator=(PhotoCalib &&)=delete
PhotoCalib(PhotoCalib &&)=default
double instFluxToNanojansky(double instFlux, lsst::geom::Point< double, 2 > const &point) const
Convert instFlux in ADU to nJy at a point in the BoundedField.
Definition: PhotoCalib.cc:104
PhotoCalib & operator=(PhotoCalib const &)=delete
std::string getPersistenceName() const override
Return the unique name used to persist this object and look up its factory.
Definition: PhotoCalib.cc:509
PhotoCalib()
Create a empty, zeroed calibration.
Definition: PhotoCalib.h:127
PhotoCalib(PhotoCalib const &)=default
double instFluxToMagnitude(double instFlux, lsst::geom::Point< double, 2 > const &point) const
Convert instFlux in ADU to AB magnitude.
Definition: PhotoCalib.cc:158
PhotoCalib(double calibrationMean, double calibrationErr=0, lsst::geom::Box2I const &bbox=lsst::geom::Box2I())
Create a non-spatially-varying calibration.
Definition: PhotoCalib.h:137
std::string toString() const override
Create a string representation of this object.
Definition: PhotoCalib.cc:242
bool operator!=(PhotoCalib const &rhs) const
Two PhotoCalibs are equal if their component bounded fields and calibrationErr are equal.
Definition: PhotoCalib.h:494
bool equals(typehandling::Storable const &other) const noexcept override
Compare this object to another Storable.
Definition: PhotoCalib.cc:252
PhotoCalib(std::shared_ptr< afw::math::BoundedField > calibration, double calibrationErr=0)
Create a spatially-varying calibration.
Definition: PhotoCalib.h:154
std::shared_ptr< typehandling::Storable > cloneStorable() const override
Create a new PhotoCalib that is a copy of this one.
Definition: PhotoCalib.cc:238
double getLocalCalibration(lsst::geom::Point< double, 2 > const &point) const
Get the local calibration at a point.
Definition: PhotoCalib.h:450
std::shared_ptr< afw::math::BoundedField > computeScalingTo(std::shared_ptr< PhotoCalib > other) const
Calculates the scaling between this PhotoCalib and another PhotoCalib.
Definition: PhotoCalib.cc:225
void write(OutputArchiveHandle &handle) const override
Write the object to one or more catalogs.
Definition: PhotoCalib.cc:511
bool isPersistable() const noexcept override
Return true if this particular object can be persisted using afw::table::io.
Definition: PhotoCalib.h:496
double getCalibrationErr() const
Get the mean photometric calibration error.
Definition: PhotoCalib.h:418
MaskedImage< float > calibrateImage(MaskedImage< float > const &maskedImage, bool includeScaleUncertainty=true) const
Return a flux calibrated image, with pixel values in nJy.
Definition: PhotoCalib.cc:260
~PhotoCalib() override=default
std::shared_ptr< afw::math::BoundedField > computeScaledCalibration() const
Calculates the spatially-variable calibration, normalized by the mean in the valid domain.
Definition: PhotoCalib.cc:221
double magnitudeToInstFlux(double magnitude, lsst::geom::Point< double, 2 > const &point) const
Convert AB magnitude to instFlux (ADU).
Definition: PhotoCalib.cc:217
double getInstFluxAtZeroMagnitude() const
Get the magnitude zero point (the instrumental flux corresponding to 0 magnitude).
Definition: PhotoCalib.h:432
A BoundedField based on 2-d Chebyshev polynomials of the first kind.
Record class that contains measurements made on a single exposure.
Definition: Source.h:78
A CRTP facade class for subclasses of Persistable.
Definition: Persistable.h:176
io::OutputArchiveHandle OutputArchiveHandle
Definition: Persistable.h:108
Interface supporting iteration over heterogenous containers.
Definition: Storable.h:58
Class for storing generic metadata.
Definition: PropertySet.h:66
An integer coordinate rectangle.
Definition: Box.h:55
Reports invalid arguments.
Definition: Runtime.h:66
bool strip
Definition: fits.cc:911
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects.
std::shared_ptr< PhotoCalib > makePhotoCalibFromCalibZeroPoint(double instFluxMag0, double instFluxMag0Err)
Construct a PhotoCalib from the deprecated Calib-style instFluxMag0/instFluxMag0Err values.
Definition: PhotoCalib.cc:613
class[[deprecated("Removed with no replacement (but see lsst::afw::image::TransmissionCurve). Will be " "removed after v22.")]] FilterProperty final
Describe the properties of a Filter (e.g.
Definition: Filter.h:53
std::shared_ptr< PhotoCalib > makePhotoCalibFromMetadata(daf::base::PropertySet &metadata, bool strip=false)
Construct a PhotoCalib from FITS FLUXMAG0/FLUXMAG0ERR keywords.
Definition: PhotoCalib.cc:595
std::ostream & operator<<(std::ostream &os, Measurement const &measurement)
Definition: PhotoCalib.cc:47
void assertNonNegative(double value, std::string const &name)
Raise lsst::pex::exceptions::InvalidParameterError if value is not >=0.
Definition: PhotoCalib.h:69
const double referenceFlux
The Oke & Gunn (1983) AB magnitude reference flux, in nJy (often approximated as 3631....
Definition: Magnitude.h:46
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:174
A base class for image defects.
A value and its error.
Definition: PhotoCalib.h:51
Measurement(double value, double error)
Definition: PhotoCalib.h:52
Utilities for converting between flux and magnitude in C++.