LSST Applications g00d0e8bbd7+edbf708997,g03191d30f7+6b31559d11,g118115db7c+ac820e85d2,g199a45376c+5137f08352,g1fd858c14a+90100aa1a7,g262e1987ae+64df5f6984,g29ae962dfc+1eb4aece83,g2cef7863aa+73c82f25e4,g3541666cd7+1e37cdad5c,g35bb328faa+edbf708997,g3fd5ace14f+fb4e2866cc,g47891489e3+19fcc35de2,g53246c7159+edbf708997,g5b326b94bb+d622351b67,g64539dfbff+dfe1dff262,g67b6fd64d1+19fcc35de2,g74acd417e5+cfdc02aca8,g786e29fd12+af89c03590,g7aefaa3e3d+dc1a598170,g87389fa792+a4172ec7da,g88cb488625+60ba2c3075,g89139ef638+19fcc35de2,g8d4809ba88+dfe1dff262,g8d7436a09f+db94b797be,g8ea07a8fe4+79658f16ab,g90f42f885a+6577634e1f,g9722cb1a7f+d8f85438e7,g98df359435+7fdd888faa,ga2180abaac+edbf708997,ga9e74d7ce9+128cc68277,gbf99507273+edbf708997,gca7fc764a6+19fcc35de2,gd7ef33dd92+19fcc35de2,gdab6d2f7ff+cfdc02aca8,gdbb4c4dda9+dfe1dff262,ge410e46f29+19fcc35de2,ge41e95a9f2+dfe1dff262,geaed405ab2+062dfc8cdc,w.2025.46
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)