LSST Applications g04e9c324dd+8c5ae1fdc5,g134cb467dc+b203dec576,g18429d2f64+358861cd2c,g199a45376c+0ba108daf9,g1fd858c14a+dd066899e3,g262e1987ae+ebfced1d55,g29ae962dfc+72fd90588e,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+b668f15bc5,g4595892280+3897dae354,g47891489e3+abcf9c3559,g4d44eb3520+fb4ddce128,g53246c7159+8c5ae1fdc5,g67b6fd64d1+abcf9c3559,g67fd3c3899+1f72b5a9f7,g74acd417e5+cb6b47f07b,g786e29fd12+668abc6043,g87389fa792+8856018cbb,g89139ef638+abcf9c3559,g8d7436a09f+bcf525d20c,g8ea07a8fe4+9f5ccc88ac,g90f42f885a+6054cc57f1,g97be763408+06f794da49,g9dd6db0277+1f72b5a9f7,ga681d05dcb+7e36ad54cd,gabf8522325+735880ea63,gac2eed3f23+abcf9c3559,gb89ab40317+abcf9c3559,gbf99507273+8c5ae1fdc5,gd8ff7fe66e+1f72b5a9f7,gdab6d2f7ff+cb6b47f07b,gdc713202bf+1f72b5a9f7,gdfd2d52018+8225f2b331,ge365c994fd+375fc21c71,ge410e46f29+abcf9c3559,geaed405ab2+562b3308c0,gf9a733ac38+8c5ae1fdc5,w.2025.35
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst::gauss2d::fit::SersicParametricEllipse Class Reference

A ParametericEllipse with effective radius Parameters. More...

#include <sersicparametricellipse.h>

Inheritance diagram for lsst::gauss2d::fit::SersicParametricEllipse:
lsst::gauss2d::fit::ParametricEllipse lsst::gauss2d::fit::Parametric lsst::gauss2d::fit::QuasiEllipse lsst::gauss2d::Object

Public Member Functions

 SersicParametricEllipse (std::shared_ptr< ReffXParameterD > size_x, std::shared_ptr< ReffYParameterD > size_y, std::shared_ptr< RhoParameterD > rho=nullptr)
 Construct a SersicParametricEllipse with existing Parameter instances.
 
 SersicParametricEllipse (double size_x=0, double size_y=0, double rho=0)
 
ParamRefsget_parameters (ParamRefs &params, ParamFilter *filter=nullptr) const override
 Add Parameter refs matching the filter to a vector, in order.
 
ParamCRefsget_parameters_const (ParamCRefs &params, ParamFilter *filter=nullptr) const override
 Same as get_parameters(), but for const refs.
 
double get_rho () const override
 Get the rho value.
 
double get_size_x () const override
 Get the size_x value.
 
double get_size_y () const override
 Get the size_y value.
 
std::array< double, 3 > get_xyr () const override
 Get the array of size_x, size_y, rho.
 
RhoParameterDget_rho_param () const override
 
SizeXParameterDget_size_x_param () const override
 
SizeYParameterDget_size_y_param () const override
 
std::shared_ptr< ReffXParameterDget_reff_x_param_ptr ()
 
std::shared_ptr< ReffYParameterDget_reff_y_param_ptr ()
 
std::shared_ptr< RhoParameterDget_rho_param_ptr () override
 
std::shared_ptr< SizeXParameterDget_size_x_param_ptr () override
 
std::shared_ptr< SizeYParameterDget_size_y_param_ptr () override
 
void set_rho (double rho) override
 
void set_size_x (double size_x) override
 
void set_size_y (double size_y) override
 
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::string str () const override
 Return a brief, human-readable string representation of this.
 
virtual void set_xyr (const std::array< double, 3 > &xyr)
 
ParamRefs get_parameters_new (ParamFilter *filter=nullptr) const
 Same as get_parameters(), but returning a new vector.
 
ParamCRefs get_parameters_const_new (ParamFilter *filter=nullptr) const
 Same as get_parameters_const(), but returning a new vector.
 

Static Public Member Functions

static std::string_view null_str (const std::string_view &namespace_separator)
 

Static Public Attributes

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

Detailed Description

A ParametericEllipse with effective radius Parameters.

Definition at line 15 of file sersicparametricellipse.h.

Constructor & Destructor Documentation

◆ SersicParametricEllipse() [1/2]

lsst::gauss2d::fit::SersicParametricEllipse::SersicParametricEllipse ( std::shared_ptr< ReffXParameterD > size_x,
std::shared_ptr< ReffYParameterD > size_y,
std::shared_ptr< RhoParameterD > rho = nullptr )
explicit

Construct a SersicParametricEllipse with existing Parameter instances.

Parameters
size_xThe x-axis effective radius parameter.
size_yThe y-axis effective radius parameter.
rhoThe correlation (rho) parameter.

Definition at line 14 of file sersicparametricellipse.cc.

17 : _size_x(size_x == nullptr ? std::make_shared<ReffXParameterD>(0) : std::move(size_x)),
18 _size_y(size_y == nullptr ? std::make_shared<ReffYParameterD>(0) : std::move(size_y)),
19 _rho(rho == nullptr ? std::make_shared<RhoParameterD>(0) : std::move(rho)) {};
T make_shared(T... args)
T move(T... args)

◆ SersicParametricEllipse() [2/2]

lsst::gauss2d::fit::SersicParametricEllipse::SersicParametricEllipse ( double size_x = 0,
double size_y = 0,
double rho = 0 )
explicit

Definition at line 21 of file sersicparametricellipse.cc.

22 : _size_x(std::make_shared<ReffXParameterD>(size_x)),
23 _size_y(std::make_shared<ReffYParameterD>(size_y)),

Member Function Documentation

◆ get_parameters()

ParamRefs & lsst::gauss2d::fit::SersicParametricEllipse::get_parameters ( ParamRefs & params,
ParamFilter * filter = nullptr ) const
overridevirtual

Add Parameter refs matching the filter to a vector, in order.

Parameters
paramsThe vector to add to.
filterThe filter to apply to this Object's parameters.
Returns
A ref to params (for method chaining)

Implements lsst::gauss2d::fit::Parametric.

Definition at line 26 of file sersicparametricellipse.cc.

26 {
27 return _get_parameters<ParamRefs>(params, filter, *_size_x, *_size_y, *_rho);
28}
t & _get_parameters(t &params, ParamFilter *filter, CentroidXParameterD &x, CentroidYParameterD &y)

◆ get_parameters_const()

ParamCRefs & lsst::gauss2d::fit::SersicParametricEllipse::get_parameters_const ( ParamCRefs & params,
ParamFilter * filter = nullptr ) const
overridevirtual

Same as get_parameters(), but for const refs.

Implements lsst::gauss2d::fit::Parametric.

Definition at line 29 of file sersicparametricellipse.cc.

29 {
30 return _get_parameters<ParamCRefs>(params, filter, *_size_x, *_size_y, *_rho);
31}

◆ get_parameters_const_new()

ParamCRefs lsst::gauss2d::fit::Parametric::get_parameters_const_new ( ParamFilter * filter = nullptr) const
inlineinherited

Same as get_parameters_const(), but returning a new vector.

Definition at line 33 of file parametric.h.

33 {
34 ParamCRefs params{};
35 get_parameters_const(params, filter);
36 return params;
37 }
virtual ParamCRefs & get_parameters_const(ParamCRefs &params, ParamFilter *filter=nullptr) const =0
Same as get_parameters(), but for const refs.
std::vector< ParamBaseCRef > ParamCRefs
Definition param_defs.h:11

◆ get_parameters_new()

ParamRefs lsst::gauss2d::fit::Parametric::get_parameters_new ( ParamFilter * filter = nullptr) const
inlineinherited

Same as get_parameters(), but returning a new vector.

Definition at line 27 of file parametric.h.

27 {
28 ParamRefs params{};
29 get_parameters(params, filter);
30 return params;
31 }
virtual ParamRefs & get_parameters(ParamRefs &params, ParamFilter *filter=nullptr) const =0
Add Parameter refs matching the filter to a vector, in order.
std::vector< ParamBaseRef > ParamRefs
Definition param_defs.h:13

◆ get_reff_x_param_ptr()

std::shared_ptr< ReffXParameterD > lsst::gauss2d::fit::SersicParametricEllipse::get_reff_x_param_ptr ( )

Definition at line 44 of file sersicparametricellipse.cc.

44{ return _size_x; };

◆ get_reff_y_param_ptr()

std::shared_ptr< ReffYParameterD > lsst::gauss2d::fit::SersicParametricEllipse::get_reff_y_param_ptr ( )

Definition at line 45 of file sersicparametricellipse.cc.

45{ return _size_y; };

◆ get_rho()

double lsst::gauss2d::fit::SersicParametricEllipse::get_rho ( ) const
overridevirtual

Get the rho value.

Implements lsst::gauss2d::fit::QuasiEllipse.

Definition at line 33 of file sersicparametricellipse.cc.

33{ return _rho->get_value(); }

◆ get_rho_param()

RhoParameterD & lsst::gauss2d::fit::SersicParametricEllipse::get_rho_param ( ) const
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 40 of file sersicparametricellipse.cc.

40{ return *_rho; }

◆ get_rho_param_ptr()

std::shared_ptr< RhoParameterD > lsst::gauss2d::fit::SersicParametricEllipse::get_rho_param_ptr ( )
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 46 of file sersicparametricellipse.cc.

46{ return _rho; }

◆ get_size_x()

double lsst::gauss2d::fit::SersicParametricEllipse::get_size_x ( ) const
overridevirtual

Get the size_x value.

Implements lsst::gauss2d::fit::QuasiEllipse.

Definition at line 34 of file sersicparametricellipse.cc.

34{ return _size_x->get_value(); }

◆ get_size_x_param()

SizeXParameterD & lsst::gauss2d::fit::SersicParametricEllipse::get_size_x_param ( ) const
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 41 of file sersicparametricellipse.cc.

41{ return *_size_x; };

◆ get_size_x_param_ptr()

std::shared_ptr< SizeXParameterD > lsst::gauss2d::fit::SersicParametricEllipse::get_size_x_param_ptr ( )
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 47 of file sersicparametricellipse.cc.

47{ return _size_x; };

◆ get_size_y()

double lsst::gauss2d::fit::SersicParametricEllipse::get_size_y ( ) const
overridevirtual

Get the size_y value.

Implements lsst::gauss2d::fit::QuasiEllipse.

Definition at line 35 of file sersicparametricellipse.cc.

35{ return _size_y->get_value(); }

◆ get_size_y_param()

SizeYParameterD & lsst::gauss2d::fit::SersicParametricEllipse::get_size_y_param ( ) const
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 42 of file sersicparametricellipse.cc.

42{ return *_size_y; };

◆ get_size_y_param_ptr()

std::shared_ptr< SizeYParameterD > lsst::gauss2d::fit::SersicParametricEllipse::get_size_y_param_ptr ( )
overridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 48 of file sersicparametricellipse.cc.

48{ return _size_y; };

◆ get_xyr()

std::array< double, 3 > lsst::gauss2d::fit::SersicParametricEllipse::get_xyr ( ) const
overridevirtual

Get the array of size_x, size_y, rho.

Reimplemented from lsst::gauss2d::fit::QuasiEllipse.

Definition at line 36 of file sersicparametricellipse.cc.

36 {
37 return {this->get_size_x(), this->get_size_y(), this->get_rho()};
38}
double get_rho() const override
Get the rho value.
double get_size_y() const override
Get the size_y value.
double get_size_x() const override
Get the size_x value.

◆ null_str()

static std::string_view lsst::gauss2d::Object::null_str ( const std::string_view & namespace_separator)
inlinestaticinherited

Definition at line 49 of file object.h.

49 {
50 return namespace_separator == CC_NAMESPACE_SEPARATOR ? "nullptr" : NULL_STR_GENERAL;
51 }
static constexpr std::string_view CC_NAMESPACE_SEPARATOR
The C++ namespace separator.
Definition object.h:45
static constexpr std::string_view NULL_STR_GENERAL
Definition object.h:46

◆ repr()

std::string lsst::gauss2d::fit::SersicParametricEllipse::repr ( bool name_keywords = false,
std::string_view namespace_separator = Object::CC_NAMESPACE_SEPARATOR ) const
overridevirtual

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::gauss2d::Object.

Definition at line 54 of file sersicparametricellipse.cc.

54 {
55 return std::string("SersicParametricEllipse(") + (name_keywords ? "size_x=" : "")
56 + _size_x->repr(name_keywords, namespace_separator) + ", " + (name_keywords ? "size_y=" : "")
57 + _size_y->repr(name_keywords, namespace_separator) + ", " + (name_keywords ? "rho=" : "")
58 + _rho->repr(name_keywords, namespace_separator) + ")";
59}

◆ set_rho()

void lsst::gauss2d::fit::SersicParametricEllipse::set_rho ( double rho)
inlineoverridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 50 of file sersicparametricellipse.cc.

50{ _rho->set_value(rho); }

◆ set_size_x()

void lsst::gauss2d::fit::SersicParametricEllipse::set_size_x ( double size_x)
inlineoverridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 51 of file sersicparametricellipse.cc.

51{ _size_x->set_value(size_x); }

◆ set_size_y()

void lsst::gauss2d::fit::SersicParametricEllipse::set_size_y ( double size_y)
inlineoverridevirtual

Implements lsst::gauss2d::fit::ParametricEllipse.

Definition at line 52 of file sersicparametricellipse.cc.

52{ _size_y->set_value(size_y); }

◆ set_xyr()

virtual void lsst::gauss2d::fit::ParametricEllipse::set_xyr ( const std::array< double, 3 > & xyr)
inlinevirtualinherited

Reimplemented in lsst::gauss2d::fit::GaussianParametricEllipse.

Definition at line 51 of file parametricellipse.h.

51 {
52 set_size_x(xyr[0]);
53 set_size_y(xyr[1]);
54 set_rho(xyr[2]);
55 };
virtual void set_size_y(double size_y)=0
virtual void set_rho(double rho)=0
virtual void set_size_x(double size_x)=0

◆ str()

std::string lsst::gauss2d::fit::SersicParametricEllipse::str ( ) const
overridevirtual

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

Implements lsst::gauss2d::Object.

Definition at line 61 of file sersicparametricellipse.cc.

61 {
62 return "SersicParametricEllipse(size_x=" + _size_x->str() + ", size_y=" + _size_y->str()
63 + ", rho=" + _rho->str() + ")";
64}

Member Data Documentation

◆ CC_NAMESPACE_SEPARATOR

std::string_view lsst::gauss2d::Object::CC_NAMESPACE_SEPARATOR = "::"
staticconstexprinherited

The C++ namespace separator.

Definition at line 45 of file object.h.

◆ NULL_STR_GENERAL

std::string_view lsst::gauss2d::Object::NULL_STR_GENERAL = "None"
staticconstexprinherited

Definition at line 46 of file object.h.

◆ PY_NAMESPACE_SEPARATOR

std::string_view lsst::gauss2d::Object::PY_NAMESPACE_SEPARATOR = "."
staticconstexprinherited

Definition at line 47 of file object.h.


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