LSST Applications g0d97872fb5+4fd969bb9d,g1653933729+34a971ddd9,g28da252d5a+072f89fe25,g2bbee38e9b+a99b0ab4cd,g2bc492864f+a99b0ab4cd,g2ca4be77d2+c0e3b27cd8,g2cdde0e794+704103fe75,g3156d2b45e+6e87dc994a,g347aa1857d+a99b0ab4cd,g35bb328faa+34a971ddd9,g3a166c0a6a+a99b0ab4cd,g3e281a1b8c+8ec26ec694,g4005a62e65+ba0306790b,g414038480c+9ed5ed841a,g569e0e2b34+cb4faa46ad,g5a97de2502+520531a62c,g717e5f8c0f+29153700a5,g7ede599f99+367733290c,g80478fca09+17051a22cc,g82479be7b0+f2f1ea0a87,g858d7b2824+29153700a5,g8b782ad322+29153700a5,g8cd86fa7b1+05420e7f7d,g9125e01d80+34a971ddd9,ga5288a1d22+e7f674aaf3,gae0086650b+34a971ddd9,gae74b0b5c6+45ef5cdc51,gb58c049af0+ace264a4f2,gc28159a63d+a99b0ab4cd,gcf0d15dbbd+8051a81198,gda6a2b7d83+8051a81198,gdaeeff99f8+7774323b41,gdf4d240d4a+34a971ddd9,ge2409df99d+cb167bac99,ge33fd446bb+29153700a5,ge79ae78c31+a99b0ab4cd,gf0baf85859+890af219f9,gf5289d68f6+9faa5c5784,w.2024.36
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Static Public Attributes | List of all members
lsst::gauss2d::fit::LogitLimitedTransform Class Referenceabstract

#include <transforms.h>

Inheritance diagram for lsst::gauss2d::fit::LogitLimitedTransform:
lsst::modelfit::parameters::Transform< T > lsst::modelfit::parameters::Object

Public Member Functions

 LogitLimitedTransform (std::shared_ptr< parameters::Limits< double > > limits, double factor=1)
 
std::string description () const override
 Return a description of this transform.
 
std::string repr (bool name_keywords=false, const std::string_view &namespace_separator=parameters::Object::CC_NAMESPACE_SEPARATOR) const override
 Return a full, callable string representation of this.
 
std::string str () const override
 Return a brief, human-readable string representation of this.
 
double get_factor () const
 
parameters::Limits< double > & get_limits () const
 
double derivative (double x) const override
 
double forward (double x) const override
 
double reverse (double x) const override
 
void set_factor (double factor)
 
void set_limits (std::shared_ptr< parameters::Limits< double > > limits)
 
virtual T derivative (T x) const =0
 Return the derivative of this tranform at the value x.
 
virtual T forward (T x) const =0
 Return the transformed value of x.
 
virtual T reverse (T x) const =0
 Return the original value of x given a transformed value.
 

Static Public Attributes

static constexpr std::string_view CC_NAMESPACE_SEPARATOR = "::"
 The C++ namespace separator.
 

Detailed Description

Definition at line 111 of file transforms.h.

Constructor & Destructor Documentation

◆ LogitLimitedTransform()

lsst::gauss2d::fit::LogitLimitedTransform::LogitLimitedTransform ( std::shared_ptr< parameters::Limits< double > > limits,
double factor = 1 )
inlineexplicit

Definition at line 113 of file transforms.h.

113 {
114 set_limits(std::move(limits));
115 set_factor(factor);
116 _set_range();
117 }
void set_limits(std::shared_ptr< parameters::Limits< double > > limits)
Definition transforms.h:145
T move(T... args)

Member Function Documentation

◆ derivative() [1/2]

double lsst::gauss2d::fit::LogitLimitedTransform::derivative ( double x) const
override

Definition at line 10 of file transforms.cc.

10 {
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}
int y
Definition SpanSet.cc:48

◆ derivative() [2/2]

template<class T >
virtual T lsst::modelfit::parameters::Transform< T >::derivative ( T x) const
pure virtualinherited

Return the derivative of this tranform at the value x.

Implemented in lsst::modelfit::parameters::UnitTransform< T >.

◆ description()

std::string lsst::gauss2d::fit::LogitLimitedTransform::description ( ) const
inlineoverridevirtual

Return a description of this transform.

Implements lsst::modelfit::parameters::Transform< T >.

Definition at line 119 of file transforms.h.

119{ return "Logit limited (to finite range) transform"; }

◆ forward() [1/2]

double lsst::gauss2d::fit::LogitLimitedTransform::forward ( double x) const
override

Definition at line 19 of file transforms.cc.

19 {
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}
int min
int max
T infinity(T... args)
T nan(T... args)

◆ forward() [2/2]

template<class T >
virtual T lsst::modelfit::parameters::Transform< T >::forward ( T x) const
pure virtualinherited

Return the transformed value of x.

Implemented in lsst::modelfit::parameters::UnitTransform< T >.

◆ get_factor()

double lsst::gauss2d::fit::LogitLimitedTransform::get_factor ( ) const
inline

Definition at line 132 of file transforms.h.

132{ return _factor; }

◆ get_limits()

parameters::Limits< double > & lsst::gauss2d::fit::LogitLimitedTransform::get_limits ( ) const
inline

Definition at line 133 of file transforms.h.

133{ return *_limits; }

◆ repr()

std::string lsst::gauss2d::fit::LogitLimitedTransform::repr ( bool name_keywords = false,
const std::string_view & namespace_separator = parameters::Object::CC_NAMESPACE_SEPARATOR ) const
inlineoverridevirtual

Return a full, callable string representation of this.

Parameters
name_keywordsWhether to prefix arguments with "{name}=", where name is the arg name in the header (as with keyword arguments in Python).
namespace_separatorThe string to use to delimit namespaces, i.e. :: in C++ and . in Python.
Returns
A callable string representation of this, which should return an an identical object to this.
Note
The representation with name_keywords=false must be callable in C++. The representation with name_keywords=true should be callable in Python, if there are any bindings.

Implements lsst::modelfit::parameters::Object.

Definition at line 120 of file transforms.h.

122 {
123 return parameters::type_name_str<LogitLimitedTransform>(false, namespace_separator) + "("
124 + (name_keywords ? "limits=" : "") + _limits->repr(name_keywords, namespace_separator) + ", "
125 + (name_keywords ? "factor=" : "") + std::to_string(_factor) + ")";
126 }
T to_string(T... args)

◆ reverse() [1/2]

double lsst::gauss2d::fit::LogitLimitedTransform::reverse ( double x) const
override

Definition at line 31 of file transforms.cc.

31 {
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}

◆ reverse() [2/2]

template<class T >
virtual T lsst::modelfit::parameters::Transform< T >::reverse ( T x) const
pure virtualinherited

Return the original value of x given a transformed value.

Implemented in lsst::modelfit::parameters::UnitTransform< T >.

◆ set_factor()

void lsst::gauss2d::fit::LogitLimitedTransform::set_factor ( double factor)
inline

Definition at line 139 of file transforms.h.

139 {
140 if (!(factor > 0))
141 throw std::invalid_argument("LogitLimitedTransform factor=" + std::to_string(factor) + " !>0");
142 _factor = factor;
143 }

◆ set_limits()

void lsst::gauss2d::fit::LogitLimitedTransform::set_limits ( std::shared_ptr< parameters::Limits< double > > limits)
inline

Definition at line 145 of file transforms.h.

145 {
146 _limits = (limits == nullptr) ? std::make_shared<parameters::Limits<double>>() : std::move(limits);
147 _set_range();
148 }
Range-based limits for parameter values.
Definition limits.h:45
T make_shared(T... args)

◆ str()

std::string lsst::gauss2d::fit::LogitLimitedTransform::str ( ) const
inlineoverridevirtual

Return a brief, human-readable string representation of this.

Implements lsst::modelfit::parameters::Object.

Definition at line 127 of file transforms.h.

127 {
128 return parameters::type_name_str<LogitLimitedTransform>(true) + "(limits=" + _limits->str()
129 + ", factor=" + std::to_string(_factor) + ")";
130 }

Member Data Documentation

◆ CC_NAMESPACE_SEPARATOR

constexpr std::string_view lsst::modelfit::parameters::Object::CC_NAMESPACE_SEPARATOR = "::"
staticconstexprinherited

The C++ namespace separator.

Definition at line 42 of file object.h.


The documentation for this class was generated from the following files: