LSST Applications g0f08755f38+9c285cab97,g1635faa6d4+13f3999e92,g1653933729+a8ce1bb630,g1a0ca8cf93+bf6eb00ceb,g28da252d5a+0829b12dee,g29321ee8c0+5700dc9eac,g2bbee38e9b+9634bc57db,g2bc492864f+9634bc57db,g2cdde0e794+c2c89b37c4,g3156d2b45e+41e33cbcdc,g347aa1857d+9634bc57db,g35bb328faa+a8ce1bb630,g3a166c0a6a+9634bc57db,g3e281a1b8c+9f2c4e2fc3,g414038480c+077ccc18e7,g41af890bb2+fde0dd39b6,g5fbc88fb19+17cd334064,g781aacb6e4+a8ce1bb630,g80478fca09+55a9465950,g82479be7b0+d730eedb7d,g858d7b2824+9c285cab97,g9125e01d80+a8ce1bb630,g9726552aa6+10f999ec6a,ga5288a1d22+2a84bb7594,gacf8899fa4+c69c5206e8,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+9634bc57db,gcf0d15dbbd+4b7d09cae4,gda3e153d99+9c285cab97,gda6a2b7d83+4b7d09cae4,gdaeeff99f8+1711a396fd,ge2409df99d+5e831397f4,ge79ae78c31+9634bc57db,gf0baf85859+147a0692ba,gf3967379c6+41c94011de,gf3fb38a9a8+8f07a9901b,gfb92a5be7c+9c285cab97,w.2024.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Static Public Member Functions | Static Public Attributes | List of all members
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)
STL namespace.

◆ 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)),
24 _rho(std::make_shared<RhoParameterD>(rho)) {};

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}

◆ 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

constexpr 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

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

Definition at line 46 of file object.h.

◆ PY_NAMESPACE_SEPARATOR

constexpr 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: