Loading [MathJax]/extensions/tex2jax.js
LSST Applications g0fba68d861+05816baf74,g1ec0fe41b4+f536777771,g1fd858c14a+a9301854fb,g35bb328faa+fcb1d3bbc8,g4af146b050+a5c07d5b1d,g4d2262a081+6e5fcc2a4e,g53246c7159+fcb1d3bbc8,g56a49b3a55+9c12191793,g5a012ec0e7+3632fc3ff3,g60b5630c4e+ded28b650d,g67b6fd64d1+ed4b5058f4,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g8352419a5c+fcb1d3bbc8,g87b7deb4dc+7b42cf88bf,g8852436030+e5453db6e6,g89139ef638+ed4b5058f4,g8e3bb8577d+d38d73bdbd,g9125e01d80+fcb1d3bbc8,g94187f82dc+ded28b650d,g989de1cb63+ed4b5058f4,g9d31334357+ded28b650d,g9f33ca652e+50a8019d8c,gabe3b4be73+1e0a283bba,gabf8522325+fa80ff7197,gb1101e3267+d9fb1f8026,gb58c049af0+f03b321e39,gb665e3612d+2a0c9e9e84,gb89ab40317+ed4b5058f4,gcf25f946ba+e5453db6e6,gd6cbbdb0b4+bb83cc51f8,gdd1046aedd+ded28b650d,gde0f65d7ad+941d412827,ge278dab8ac+d65b3c2b70,ge410e46f29+ed4b5058f4,gf23fb2af72+b7cae620c0,gf5e32f922b+fcb1d3bbc8,gf67bdafdda+ed4b5058f4,w.2025.16
LSST Data Management Base Package
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
lsst::gauss2d::Gaussian Class Reference

A 2D Gaussian with a Centroid, Ellipse, and integral. More...

#include <gaussian.h>

Inheritance diagram for lsst::gauss2d::Gaussian:
lsst::gauss2d::Object

Public Member Functions

 Gaussian (std::shared_ptr< Centroid > centroid=nullptr, std::shared_ptr< Ellipse > ellipse=nullptr, std::shared_ptr< GaussianIntegral > integral=nullptr)
 Construct a new Gaussian object.
 
 ~Gaussian ()
 
double get_const_normal () const
 Get the multiplicative factor for Gaussian function evaluations: integral/(2*area)
 
double get_integral_value () const
 Get the integral value.
 
Centroidget_centroid ()
 Get the centroid object.
 
Ellipseget_ellipse ()
 Get the ellipse object.
 
GaussianIntegralget_integral ()
 Get the integral object.
 
std::shared_ptr< Centroidget_centroid_ptr ()
 
std::shared_ptr< Ellipseget_ellipse_ptr ()
 
std::shared_ptr< GaussianIntegralget_integral_ptr ()
 
const Centroidget_centroid_const () const
 
const Ellipseget_ellipse_const () const
 
const GaussianIntegralget_integral_const () const
 
void set_const_normal (double const_normal)
 
void set_integral_value (double integral)
 
void set_centroid_ptr (std::shared_ptr< Centroid > centroid)
 
void set_ellipse_ptr (std::shared_ptr< Ellipse > ellipse)
 
void set_integral_ptr (std::shared_ptr< GaussianIntegral > integral)
 
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 Gaussian &other) const
 
bool operator!= (const Gaussian &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 Gaussian with a Centroid, Ellipse, and integral.

Gaussian offers some convenience functions but is otherwise a container for its three component subclasses.

Definition at line 99 of file gaussian.h.

Constructor & Destructor Documentation

◆ Gaussian()

lsst::gauss2d::Gaussian::Gaussian ( std::shared_ptr< Centroid > centroid = nullptr,
std::shared_ptr< Ellipse > ellipse = nullptr,
std::shared_ptr< GaussianIntegral > integral = nullptr )
explicit

Construct a new Gaussian object.

Parameters
centroidThe centroid. Defaults to a new, default Centroid.
ellipseThe ellipse. Defaults to a new, default Ellipse.
integralThe integral. Defaults to a new, default GaussianIntegralValue.

Definition at line 47 of file gaussian.cc.

49 : _centroid(centroid != nullptr ? std::move(centroid) : std::make_shared<Centroid>()),
50 _ellipse(ellipse != nullptr ? std::move(ellipse) : std::make_shared<Ellipse>()),
51 _integral(integral != nullptr ? std::move(integral) : std::make_shared<GaussianIntegralValue>()) {}
T make_shared(T... args)
T move(T... args)

◆ ~Gaussian()

lsst::gauss2d::Gaussian::~Gaussian ( )

Definition at line 52 of file gaussian.cc.

52{};

Member Function Documentation

◆ get_centroid()

Centroid & lsst::gauss2d::Gaussian::get_centroid ( )

Get the centroid object.

Definition at line 57 of file gaussian.cc.

57{ return *_centroid; }

◆ get_centroid_const()

const Centroid & lsst::gauss2d::Gaussian::get_centroid_const ( ) const

Definition at line 65 of file gaussian.cc.

65{ return *_centroid; }

◆ get_centroid_ptr()

std::shared_ptr< Centroid > lsst::gauss2d::Gaussian::get_centroid_ptr ( )

Definition at line 61 of file gaussian.cc.

61{ return _centroid; }

◆ get_const_normal()

double lsst::gauss2d::Gaussian::get_const_normal ( ) const

Get the multiplicative factor for Gaussian function evaluations: integral/(2*area)

Definition at line 54 of file gaussian.cc.

54{ return _integral->get_value() / (2 * _ellipse->get_area()); }

◆ get_ellipse()

Ellipse & lsst::gauss2d::Gaussian::get_ellipse ( )

Get the ellipse object.

Definition at line 58 of file gaussian.cc.

58{ return *_ellipse; }

◆ get_ellipse_const()

const Ellipse & lsst::gauss2d::Gaussian::get_ellipse_const ( ) const

Definition at line 66 of file gaussian.cc.

66{ return *_ellipse; }

◆ get_ellipse_ptr()

std::shared_ptr< Ellipse > lsst::gauss2d::Gaussian::get_ellipse_ptr ( )

Definition at line 62 of file gaussian.cc.

62{ return _ellipse; }

◆ get_integral()

GaussianIntegral & lsst::gauss2d::Gaussian::get_integral ( )

Get the integral object.

Definition at line 59 of file gaussian.cc.

59{ return *_integral; }

◆ get_integral_const()

const GaussianIntegral & lsst::gauss2d::Gaussian::get_integral_const ( ) const

Definition at line 67 of file gaussian.cc.

67{ return *_integral; }

◆ get_integral_ptr()

std::shared_ptr< GaussianIntegral > lsst::gauss2d::Gaussian::get_integral_ptr ( )

Definition at line 63 of file gaussian.cc.

63{ return _integral; }

◆ get_integral_value()

double lsst::gauss2d::Gaussian::get_integral_value ( ) const

Get the integral value.

Definition at line 55 of file gaussian.cc.

55{ return _integral->get_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

◆ operator!=()

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

Definition at line 101 of file gaussian.cc.

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

◆ operator==()

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

Definition at line 96 of file gaussian.cc.

96 {
97 return (*_centroid == other.get_centroid_const()) && (*_ellipse == other.get_ellipse_const())
98 && (*_integral == other.get_integral_const());
99}

◆ repr()

std::string lsst::gauss2d::Gaussian::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 84 of file gaussian.cc.

84 {
85 return type_name_str<Gaussian>(false, namespace_separator) + "(" + (name_keywords ? "centroid=" : "")
86 + _centroid->repr(name_keywords, namespace_separator) + ", " + (name_keywords ? "ellipse=" : "")
87 + _ellipse->repr(name_keywords, namespace_separator) + ", " + (name_keywords ? "integral=" : "")
88 + _integral->repr(name_keywords, namespace_separator) + ")";
89}
std::string type_name_str(bool strip_namespace=false, std::string_view namespace_str=detail::NAMESPACE_SEPARATOR)
Get a string representation of an arbitrary C++ type, potentially modifying its namespace prefix.
Definition type_name.h:104

◆ set_centroid_ptr()

void lsst::gauss2d::Gaussian::set_centroid_ptr ( std::shared_ptr< Centroid > centroid)

Definition at line 74 of file gaussian.cc.

74 {
75 _centroid = this->_check_not_nullptr<Centroid>(centroid, "centroid");
76}

◆ set_const_normal()

void lsst::gauss2d::Gaussian::set_const_normal ( double const_normal)

Definition at line 69 of file gaussian.cc.

69 {
70 _integral->set_value(get_const_normal() * 2 * _ellipse->get_area());
71}
double get_const_normal() const
Get the multiplicative factor for Gaussian function evaluations: integral/(2*area)
Definition gaussian.cc:54

◆ set_ellipse_ptr()

void lsst::gauss2d::Gaussian::set_ellipse_ptr ( std::shared_ptr< Ellipse > ellipse)

Definition at line 77 of file gaussian.cc.

77 {
78 _ellipse = this->_check_not_nullptr<Ellipse>(ellipse, "ellipse");
79}

◆ set_integral_ptr()

void lsst::gauss2d::Gaussian::set_integral_ptr ( std::shared_ptr< GaussianIntegral > integral)

Definition at line 80 of file gaussian.cc.

80 {
81 _integral = this->_check_not_nullptr<GaussianIntegral>(integral, "integral");
82}

◆ set_integral_value()

void lsst::gauss2d::Gaussian::set_integral_value ( double integral)

Definition at line 72 of file gaussian.cc.

72{ _integral->set_value(integral); }

◆ str()

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

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

Implements lsst::gauss2d::Object.

Definition at line 91 of file gaussian.cc.

91 {
92 return type_name_str<Gaussian>(true) + "(centroid=" + _centroid->str() + ", ellipse=" + _ellipse->str()
93 + ", integral=" + _integral->str() + ")";
94}

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: