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