LSST Applications g00274db5b6+edbf708997,g00d0e8bbd7+edbf708997,g199a45376c+5137f08352,g1fd858c14a+1d4b6db739,g262e1987ae+f4d9505c4f,g29ae962dfc+7156fb1a53,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3e17d7035e+5b3adc59f5,g3fd5ace14f+852fa6fbcb,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+9f17e571f4,g67b6fd64d1+6dc8069a4c,g74acd417e5+ae494d68d9,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+536efcc10a,g7cc15d900a+d121454f8d,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d7436a09f+28c28d8d6d,g8ea07a8fe4+db21c37724,g92c671f44c+9f17e571f4,g98df359435+b2e6376b13,g99af87f6a8+b0f4ad7b8d,gac66b60396+966efe6077,gb88ae4c679+7dec8f19df,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gc24b5d6ed1+9f17e571f4,gca7fc764a6+6dc8069a4c,gcc769fe2a4+97d0256649,gd7ef33dd92+6dc8069a4c,gdab6d2f7ff+ae494d68d9,gdbb4c4dda9+9f17e571f4,ge410e46f29+6dc8069a4c,geaed405ab2+e194be0d2b,w.2025.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
transforms.cc
Go to the documentation of this file.
1#include <limits>
2
4
6
7namespace lsst::gauss2d::fit {
8static const double INF = std::numeric_limits<double>::infinity();
9
10double LogitLimitedTransform::derivative(double x) const {
11 double y = (x - _limits->get_min()) / _range;
12 if (y == 1)
13 return INF;
14 else if (y == 0)
15 return -INF;
16 return (1 / y + 1 / (1 - y)) * _factor / _range;
17}
18
19double LogitLimitedTransform::forward(double x) const {
20 double min = _limits->get_min();
21 double max = _limits->get_max();
22 if (x == min)
24 else if (x == max)
26 double y = (x - min) / _range;
27 if (!(y < 1) || !(y > 0)) return nan("");
28 return log(y / (1 - y)) * _factor;
29}
30
31double LogitLimitedTransform::reverse(double x) const {
32 double y = -x * _factor;
33 // math.log(np.finfo(np.float64) = 709.782712893384
34 // things will go badly well before then
35 if (y > 709.7827) return _limits->get_min();
36 y = 1 + exp(y);
37 return _range / y + _limits->get_min();
38}
39} // namespace lsst::gauss2d::fit
double forward(double x) const override
Return the transformed value of x.
Definition transforms.cc:19
double derivative(double x) const override
Return the derivative of this tranform at the value x.
Definition transforms.cc:10
double reverse(double x) const override
Return the original value of x given a transformed value.
Definition transforms.cc:31
T infinity(T... args)