LSST Applications 28.0.0,g1653933729+a8ce1bb630,g1a997c3884+a8ce1bb630,g28da252d5a+5bd70b7e6d,g2bbee38e9b+638fca75ac,g2bc492864f+638fca75ac,g3156d2b45e+07302053f8,g347aa1857d+638fca75ac,g35bb328faa+a8ce1bb630,g3a166c0a6a+638fca75ac,g3e281a1b8c+7bbb0b2507,g4005a62e65+17cd334064,g414038480c+5b5cd4fff3,g41af890bb2+4ffae9de63,g4e1a3235cc+0f1912dca3,g6249c6f860+3c3976f90c,g80478fca09+46aba80bd6,g82479be7b0+77990446f6,g858d7b2824+78ba4d1ce1,g89c8672015+f667a5183b,g9125e01d80+a8ce1bb630,ga5288a1d22+2a6264e9ca,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc22bb204ba+78ba4d1ce1,gc28159a63d+638fca75ac,gcf0d15dbbd+32ddb6096f,gd6b7c0dfd1+3e339405e9,gda3e153d99+78ba4d1ce1,gda6a2b7d83+32ddb6096f,gdaeeff99f8+1711a396fd,gdd5a9049c5+b18c39e5e3,ge2409df99d+a5e4577cdc,ge33fd446bb+78ba4d1ce1,ge79ae78c31+638fca75ac,gf0baf85859+64e8883e75,gf5289d68f6+e1b046a8d7,gfa443fc69c+91d9ed1ecf,gfda6b12a05+8419469a56
LSST Data Management Base Package
Loading...
Searching...
No Matches
linearintegralmodel.cc
Go to the documentation of this file.
2
6#include "lsst/gauss2d/fit/parameters.h"
8
9namespace lsst::gauss2d::fit {
10
11// not giving a nullptr default because users should explicitly use the null Channel
13 if (data_in != nullptr) {
14 size_t idx = 0;
15 for (const auto& datum : *data_in) {
16 if (datum.second == nullptr) {
17 throw std::runtime_error("LinearIntegralModel data[" + std::to_string(idx)
18 + "] can't be null");
19 }
20 if (_map.find(datum.first) != _map.end()) {
21 throw std::runtime_error("LinearIntegralModel data[" + std::to_string(idx)
22 + "] channel=" + datum.first.get().str() + " duplicated");
23 }
24 _data.emplace_back(datum.first, datum.second);
25 _map.insert(_data.back());
26 idx++;
27 }
28 } else {
30 _map.insert(_data.back());
31 }
32}
34
37 for (auto& datum : _data) rval.emplace_back(datum.first);
38 return rval;
39}
40
41double LinearIntegralModel::get_integral(const Channel& channel) const {
42 return _map.at(channel)->get_value();
43}
44
47 return {};
48}
49
51 return _map.at(channel);
52}
53
55 return _map.at(channel);
56}
57
58typename LinearIntegralModel::Data::iterator LinearIntegralModel::begin() noexcept { return _data.begin(); }
59typename LinearIntegralModel::Data::const_iterator LinearIntegralModel::cbegin() const noexcept {
60 return _data.begin();
61}
62
63typename LinearIntegralModel::Data::iterator LinearIntegralModel::end() noexcept { return _data.end(); }
64typename LinearIntegralModel::Data::const_iterator LinearIntegralModel::cend() const noexcept {
65 return _data.cend();
66}
67
69 for (const auto& p : _data) insert_param_channel(p.first, *p.second, params, filter);
70 return params;
71}
73 for (const auto& p : _data) insert_param_channel(p.first, *p.second, params, filter);
74 return params;
75}
76
77size_t LinearIntegralModel::size() const { return _data.size(); }
78
79std::string LinearIntegralModel::repr(bool name_keywords, std::string_view namespace_separator) const {
80 std::string s = type_name_str<LinearIntegralModel>(false, namespace_separator) + "("
81 + (name_keywords ? "data=" : "") + "{";
82 for (const auto& datum : _data) {
83 s += datum.first.get().repr(name_keywords, namespace_separator) + ": "
84 + datum.second->repr(name_keywords, namespace_separator) + ",";
85 }
86 return s + "})";
87}
88
91 for (const auto& datum : _data) {
92 s += datum.first.get().str() + ": " + datum.second->str() + ",";
93 }
94 return s + "})";
95}
96
97} // namespace lsst::gauss2d::fit
T back(T... args)
T begin(T... args)
An observational channel, usually representing some range of wavelengths of light.
Definition channel.h:29
static const Channel & NONE()
Definition channel.cc:111
LinearIntegralModel(const Data *data_in)
Construct a LinearIntegralModel from input Data.
Data::const_iterator cbegin() const noexcept
ParamCRefs & get_parameters_const(ParamCRefs &params, ParamFilter *filter=nullptr) const override
Same as get_parameters(), but for const refs.
std::string repr(bool name_keywords=false, std::string_view namespace_separator=Object::CC_NAMESPACE_SEPARATOR) const override
Return a full, callable string representation of this.
std::vector< std::reference_wrapper< const Channel > > get_channels() const override
Get the set of channels this instance is applicable for.
std::shared_ptr< IntegralParameterD > at(const Channel &channel)
Get the IntegralParameterD for the given Channel.
std::vector< std::pair< ParamBaseCRef, ExtraParamFactorValues > > get_integral_derivative_factors(const Channel &channel) const override
Return the partial derivative of the model w.r.t.
double get_integral(const Channel &channel) const override
Get the value of the integral in a single Channel.
ParamRefs & get_parameters(ParamRefs &params, ParamFilter *filter=nullptr) const override
Add Parameter refs matching the filter to a vector, in order.
std::string str() const override
Return a brief, human-readable string representation of this.
Data::const_iterator cend() const noexcept
size_t size() const
Return the size of Data (number of Channel/IntegralParameterD instances)
T emplace_back(T... args)
T end(T... args)
T make_shared(T... args)
void insert_param_channel(const lsst::gauss2d::fit::Channel &channel, g2f::ParamBase &param, t &params, ParamFilter *filter)
Same as insert_param, but only inserting if filter has a null or matching Channel.
std::string type_name_str(bool strip_namespace=false, std::string_view namespace_str=detail::NAMESPACE_SEPARATOR)
Get a string representation of an arbitrary C++ type, potentially modifying its namespace prefix.
Definition type_name.h:104
T size(T... args)
Options for filtering Parameter instances.
T to_string(T... args)