LSST Applications g0fba68d861+5616995c1c,g1ebb85f214+2420ccdea7,g1fd858c14a+44c57a1f81,g21d47ad084+8e51fce9ac,g262e1987ae+1a7d68eb3b,g2cef7863aa+3bd8df3d95,g35bb328faa+fcb1d3bbc8,g36ff55ed5b+2420ccdea7,g47891489e3+5c6313fe9a,g53246c7159+fcb1d3bbc8,g646c943bdb+dbb9921566,g67b6fd64d1+5c6313fe9a,g6bd32b75b5+2420ccdea7,g74acd417e5+37fc0c974d,g786e29fd12+cf7ec2a62a,g86c591e316+6e13bcb9e9,g87389fa792+1e0a283bba,g89139ef638+5c6313fe9a,g90f42f885a+fce05a46d3,g9125e01d80+fcb1d3bbc8,g93e38de9ac+5345a64125,g95a1e89356+47d08a1cc6,g97be763408+bba861c665,ga9e4eb89a6+85210110a1,gb0b61e0e8e+1f27f70249,gb58c049af0+f03b321e39,gb89ab40317+5c6313fe9a,gc4e39d7843+4e09c98c3d,gd16ba4ae74+5402bcf54a,gd8ff7fe66e+2420ccdea7,gd9a9a58781+fcb1d3bbc8,gdab6d2f7ff+37fc0c974d,gde280f09ee+604b327636,ge278dab8ac+50e2446c94,ge410e46f29+5c6313fe9a,gef3c2e6661+6b480e0fb7,gf67bdafdda+5c6313fe9a,gffca2db377+fcb1d3bbc8,v29.2.0.rc1
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 at(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.
std::vector< ChannelIntegralParameterD > Data
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 make_shared(T... args)
std::vector< ParamBaseRef > ParamRefs
Definition param_defs.h:13
std::vector< ParamBaseCRef > ParamCRefs
Definition param_defs.h:11
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)