Loading [MathJax]/extensions/tex2jax.js
LSST Applications g04a91732dc+cc8870d3f5,g07dc498a13+5aa0b8792f,g0fba68d861+80045be308,g1409bbee79+5aa0b8792f,g1a7e361dbc+5aa0b8792f,g1fd858c14a+f64bc332a9,g208c678f98+1ae86710ed,g35bb328faa+fcb1d3bbc8,g4d2262a081+47ad8a29a8,g4d39ba7253+9633a327c1,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g60b5630c4e+9633a327c1,g668ecb457e+25d63fd678,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g7b71ed6315+fcb1d3bbc8,g8852436030+8b64ca622a,g89139ef638+5aa0b8792f,g89e1512fd8+04325574d3,g8d6b6b353c+9633a327c1,g9125e01d80+fcb1d3bbc8,g989de1cb63+5aa0b8792f,g9f33ca652e+b196626af7,ga9baa6287d+9633a327c1,gaaedd4e678+5aa0b8792f,gabe3b4be73+1e0a283bba,gb1101e3267+71e32094df,gb58c049af0+f03b321e39,gb90eeb9370+2807b1ad02,gcf25f946ba+8b64ca622a,gd315a588df+a39986a76f,gd6cbbdb0b4+c8606af20c,gd9a9a58781+fcb1d3bbc8,gde0f65d7ad+4e42d81ab7,ge278dab8ac+932305ba37,ge82c20c137+76d20ab76d,gfe73954cf8+a1301e4c20,w.2025.11
LSST Data Management Base Package
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
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: