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::Centroid Class Reference

A 2D coordinate representing the center of a plane figure. More...

#include <centroid.h>

Inheritance diagram for lsst::gauss2d::Centroid:
lsst::gauss2d::Object

Public Member Functions

 Centroid (std::shared_ptr< CentroidData > data)
 
 Centroid (double x=0, double y=0)
 
void convolve (const Centroid &cen)
 Convolve this with another centroid.
 
const CentroidDataget_data () const
 Get this centroid's data.
 
double get_x () const
 Get the x value.
 
std::array< double, 2 > get_xy () const
 Get the x and y values.
 
double get_y () const
 Get the y value.
 
std::shared_ptr< Centroidmake_convolution (const Centroid &cen) const
 Return the convolution of this with another centroid.
 
std::unique_ptr< Centroidmake_convolution_uniq (const Centroid &cen) const
 Same as make_convolution(), but returning a unique_ptr.
 
void set_x (double x)
 
void set_xy (const std::array< double, 2 > &xy)
 
void set_y (double y)
 
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.
 
bool operator== (const Centroid &other) const
 
bool operator!= (const Centroid &other) const
 

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 2D coordinate representing the center of a plane figure.

This is a centroid in a 2D coordinate system, generally used for ellipses in this package. Storage is implemented in CentroidData.

Parameters
dataThe centroid data

Definition at line 114 of file centroid.h.

Constructor & Destructor Documentation

◆ Centroid() [1/2]

lsst::gauss2d::Centroid::Centroid ( std::shared_ptr< CentroidData > data)
explicit

Definition at line 109 of file centroid.cc.

110 : _data(data == nullptr ? std::make_shared<CentroidValues>() : std::move(data)) {}
char * data
Definition BaseRecord.cc:61
T move(T... args)
STL namespace.

◆ Centroid() [2/2]

lsst::gauss2d::Centroid::Centroid ( double x = 0,
double y = 0 )
explicit

Definition at line 112 of file centroid.cc.

112 : _data(std::make_shared<CentroidValues>()) {
113 set_x(x);
114 set_y(y);
115}
int y
Definition SpanSet.cc:48
void set_y(double y)
Definition centroid.cc:94
void set_x(double x)
Definition centroid.cc:92

Member Function Documentation

◆ convolve()

void lsst::gauss2d::Centroid::convolve ( const Centroid & cen)

Convolve this with another centroid.

Convolution simply adds the value of the other centroid to this.

Parameters
cenThe centroid to convolve with

Definition at line 69 of file centroid.cc.

69 {
70 this->set_x(this->get_x() + cen.get_x());
71 this->set_y(this->get_y() + cen.get_y());
72}
double get_y() const
Get the y value.
Definition centroid.cc:80
double get_x() const
Get the x value.
Definition centroid.cc:76

◆ get_data()

const CentroidData & lsst::gauss2d::Centroid::get_data ( ) const

Get this centroid's data.

Definition at line 74 of file centroid.cc.

74{ return *_data; }

◆ get_x()

double lsst::gauss2d::Centroid::get_x ( ) const

Get the x value.

Definition at line 76 of file centroid.cc.

76{ return _data->get_x(); }

◆ get_xy()

std::array< double, 2 > lsst::gauss2d::Centroid::get_xy ( ) const

Get the x and y values.

Definition at line 78 of file centroid.cc.

78{ return _data->get_xy(); }

◆ get_y()

double lsst::gauss2d::Centroid::get_y ( ) const

Get the y value.

Definition at line 80 of file centroid.cc.

80{ return _data->get_y(); }

◆ make_convolution()

std::shared_ptr< Centroid > lsst::gauss2d::Centroid::make_convolution ( const Centroid & cen) const

Return the convolution of this with another centroid.

Convolution simply adds the values of both centroids together

Parameters
cenThe centroid to convolve with
Returns
A new centroid with values set to the convolution.

Definition at line 82 of file centroid.cc.

82 {
83 return this->make_convolution_uniq(cen);
84}
std::unique_ptr< Centroid > make_convolution_uniq(const Centroid &cen) const
Same as make_convolution(), but returning a unique_ptr.
Definition centroid.cc:85

◆ make_convolution_uniq()

std::unique_ptr< Centroid > lsst::gauss2d::Centroid::make_convolution_uniq ( const Centroid & cen) const

Same as make_convolution(), but returning a unique_ptr.

Definition at line 85 of file centroid.cc.

85 {
86 // TODO: Replace with cloning derived data
87 std::unique_ptr<Centroid> cen_ret = std::make_unique<Centroid>(this->get_x(), this->get_y());
88 cen_ret->convolve(cen);
89 return cen_ret;
90}

◆ 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

◆ operator!=()

bool lsst::gauss2d::Centroid::operator!= ( const Centroid & other) const

Definition at line 107 of file centroid.cc.

107{ return !(*this == other); }

◆ operator==()

bool lsst::gauss2d::Centroid::operator== ( const Centroid & other) const

Definition at line 103 of file centroid.cc.

103 {
104 return (this->get_x() == other.get_x()) && (this->get_y() == other.get_y());
105};

◆ repr()

std::string lsst::gauss2d::Centroid::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 96 of file centroid.cc.

96 {
97 return type_name_str<Centroid>(false, namespace_separator) + "(" + (name_keywords ? "data=" : "")
98 + _data->repr(name_keywords, namespace_separator) + ")";
99}

◆ set_x()

void lsst::gauss2d::Centroid::set_x ( double x)

Definition at line 92 of file centroid.cc.

92{ _data->set_x(x); }

◆ set_xy()

void lsst::gauss2d::Centroid::set_xy ( const std::array< double, 2 > & xy)

Definition at line 93 of file centroid.cc.

93{ _data->set_xy(xy); }

◆ set_y()

void lsst::gauss2d::Centroid::set_y ( double y)

Definition at line 94 of file centroid.cc.

94{ _data->set_y(y); }

◆ str()

std::string lsst::gauss2d::Centroid::str ( ) const
overridevirtual

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

Implements lsst::gauss2d::Object.

Definition at line 101 of file centroid.cc.

101{ return type_name_str<Centroid>(true) + "(data=" + _data->str() + ")"; }

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: