LSST Applications g063fba187b+cac8b7c890,g0f08755f38+6aee506743,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+b4475c5878,g1dcb35cd9c+8f9bc1652e,g20f6ffc8e0+6aee506743,g217e2c1bcf+73dee94bd0,g28da252d5a+1f19c529b9,g2bbee38e9b+3f2625acfc,g2bc492864f+3f2625acfc,g3156d2b45e+6e55a43351,g32e5bea42b+1bb94961c2,g347aa1857d+3f2625acfc,g35bb328faa+a8ce1bb630,g3a166c0a6a+3f2625acfc,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+8a9e676b2a,g7af13505b9+809c143d88,g80478fca09+6ef8b1810f,g82479be7b0+f568feb641,g858d7b2824+6aee506743,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,ga5288a1d22+2903d499ea,gb58c049af0+d64f4d3760,gc28159a63d+3f2625acfc,gcab2d0539d+b12535109e,gcf0d15dbbd+46a3f46ba9,gda6a2b7d83+46a3f46ba9,gdaeeff99f8+1711a396fd,ge79ae78c31+3f2625acfc,gef2f8181fd+0a71e47438,gf0baf85859+c1f95f4921,gfa517265be+6aee506743,gfa999e8aa5+17cd334064,w.2024.51
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: