Loading [MathJax]/extensions/tex2jax.js
LSST Applications g04a91732dc+a3f7a6a005,g07dc498a13+5ab4d22ec3,g0fba68d861+870ee37b31,g1409bbee79+5ab4d22ec3,g1a7e361dbc+5ab4d22ec3,g1fd858c14a+11200c7927,g20f46db602+25d63fd678,g35bb328faa+fcb1d3bbc8,g4d2262a081+cc8af5cafb,g4d39ba7253+6b9d64fe03,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g60b5630c4e+6b9d64fe03,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g7b71ed6315+fcb1d3bbc8,g8048e755c2+a1301e4c20,g8852436030+a750987b4a,g89139ef638+5ab4d22ec3,g89e1512fd8+a86d53a4aa,g8d6b6b353c+6b9d64fe03,g9125e01d80+fcb1d3bbc8,g989de1cb63+5ab4d22ec3,g9f33ca652e+38ca901d1a,ga9baa6287d+6b9d64fe03,gaaedd4e678+5ab4d22ec3,gabe3b4be73+1e0a283bba,gb1101e3267+aa269f591c,gb58c049af0+f03b321e39,gb90eeb9370+af74afe682,gc741bbaa4f+7f5db660ea,gcf25f946ba+a750987b4a,gd315a588df+b78635c672,gd6cbbdb0b4+c8606af20c,gd9a9a58781+fcb1d3bbc8,gde0f65d7ad+5839af1903,ge278dab8ac+932305ba37,ge82c20c137+76d20ab76d,w.2025.11
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: