LSST Applications g1653933729+34a971ddd9,g1a997c3884+34a971ddd9,g2160c40384+da0d0eec6b,g28da252d5a+1236b942f7,g2bbee38e9b+e5a1bc5b38,g2bc492864f+e5a1bc5b38,g2ca4be77d2+192fe503f0,g2cdde0e794+704103fe75,g3156d2b45e+6e87dc994a,g347aa1857d+e5a1bc5b38,g35bb328faa+34a971ddd9,g3a166c0a6a+e5a1bc5b38,g3e281a1b8c+8ec26ec694,g4005a62e65+ba0306790b,g414038480c+9f5be647b3,g41af890bb2+c3a10c924f,g5065538af8+e7237db731,g5a0bb5165c+eae055db26,g717e5f8c0f+b65b5c3ae4,g80478fca09+4ce5a07937,g82479be7b0+08790af60f,g858d7b2824+b65b5c3ae4,g9125e01d80+34a971ddd9,ga5288a1d22+5df949a35e,gae0086650b+34a971ddd9,gb58c049af0+ace264a4f2,gbd397ab92a+2141afb137,gc28159a63d+e5a1bc5b38,gc805d3fbd4+b65b5c3ae4,gcf0d15dbbd+97632ccc20,gd6b7c0dfd1+de826e8718,gda6a2b7d83+97632ccc20,gdaeeff99f8+7774323b41,ge2409df99d+e6cadbf968,ge33fd446bb+b65b5c3ae4,ge79ae78c31+e5a1bc5b38,gf0baf85859+890af219f9,gf5289d68f6+a27069ed62,w.2024.37
LSST Data Management Base Package
Loading...
Searching...
No Matches
prior.h
Go to the documentation of this file.
1#ifndef LSST_GAUSS2D_FIT_PRIOR_H
2#define LSST_GAUSS2D_FIT_PRIOR_H
3
4#include <map>
5
7
8#include "math.h"
9#include "param_defs.h"
10
11namespace lsst::gauss2d::fit {
12
16class PriorEvaluation : public Object {
17public:
19
20 double loglike;
23
24 double compute_dloglike_dx(const ParamBase& param, bool transformed = true) const;
25
26 std::string repr(bool name_keywords = false,
27 std::string_view namespace_separator = Object::CC_NAMESPACE_SEPARATOR) const override;
28 std::string str() const override;
29
31 bool check_size = true);
33};
34
38class Prior : public Object {
39public:
49 virtual PriorEvaluation evaluate(bool calc_jacobians = false, bool normalize_loglike = true) const = 0;
50
51 virtual size_t size() const = 0;
52
53 virtual ~Prior() = default;
54};
55} // namespace lsst::gauss2d::fit
56
57#endif
A generic object from the gauss2d library.
Definition object.h:40
static constexpr std::string_view CC_NAMESPACE_SEPARATOR
The C++ namespace separator.
Definition object.h:45
Results from the evaluation of a prior probability function.
Definition prior.h:16
double compute_dloglike_dx(const ParamBase &param, bool transformed=true) const
Definition prior.cc:67
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.
Definition prior.cc:83
std::string str() const override
Return a brief, human-readable string representation of this.
Definition prior.cc:90
std::map< ParamBaseCRef, std::vector< double > > Jacobians
Definition prior.h:18
std::vector< double > residuals
Definition prior.h:21
PriorEvaluation(double loglike, std::vector< double > residuals={}, Jacobians jacobians={}, bool check_size=true)
Definition prior.cc:46
Interface for a prior probability function.
Definition prior.h:38
virtual PriorEvaluation evaluate(bool calc_jacobians=false, bool normalize_loglike=true) const =0
Evaluate the log likelihood and residual-dependent terms.
virtual size_t size() const =0
virtual ~Prior()=default
virtual std::vector< double > get_loglike_const_terms() const =0
Return the constant terms of the log likelihood (dependent on stddevs only)
Interface for parameters with values and metadata.
Definition parameter.h:58