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
|
Represents a multidimensional Gaussian function truncated at zero. More...
#include <TruncatedGaussian.h>
Public Types | |
enum | SampleStrategy { DIRECT_WITH_REJECTION , ALIGN_AND_WEIGHT } |
Enum that describes different ways of sampling from a multidimensional TruncatedGaussian. More... | |
typedef TruncatedGaussianSampler | Sampler |
typedef TruncatedGaussianLogEvaluator | LogEvaluator |
typedef TruncatedGaussianEvaluator | Evaluator |
Public Member Functions | |
Sampler | sample (SampleStrategy strategy) const |
Create a Sampler object that uses the given strategy. | |
Sampler | sample (Scalar minRejectionEfficiency=0.1) const |
Create a Sampler object that determines the strategy to use automatically. | |
LogEvaluator | evaluateLog () const |
Create a LogEvaluator object that can be used to efficiently evaluate the -log of the function. | |
Evaluator | evaluate () const |
Create an Evaluator object that can be used to efficiently evaluate the function. | |
int | getDim () const |
Return the dimensionality of the function. | |
Vector | maximize () const |
Return the location of the maximum of the truncated Gaussian. | |
Scalar | getUntruncatedFraction () const |
Return the fraction of the Gaussian integral that was truncated by the bounds. | |
Scalar | getLogPeakAmplitude () const |
Return the -log of the peak amplitude of the untruncated function. | |
Scalar | getLogIntegral () const |
Return the -log of the integral of the truncated function. | |
~TruncatedGaussian () | |
Static Public Member Functions | |
static TruncatedGaussian | fromSeriesParameters (Scalar q0, Vector const &gradient, Matrix const &hessian) |
Create from the first and second logarithmic derivatives of the Gaussian. | |
static TruncatedGaussian | fromStandardParameters (Vector const &mean, Matrix const &covariance) |
Create from the "standard" mean and covariance parameters of the normal distribution. | |
Friends | |
class | TruncatedGaussianSampler |
class | TruncatedGaussianLogEvaluator |
Represents a multidimensional Gaussian function truncated at zero.
This is typically used to represent the posterior probability of amplitude parameters, given a flat prior; we require that the amplitudes each be positive but otherwise do not modify the Gaussian likelihood.
Currently only 1 and 2 dimensions are supported, and all dimensions must be truncated. Computing integrals is the only operation for which > 2-d is not implemented, but the integrals must be computed upon construction, so we can't support any other operations for > 2-d either.
Many operations on TruncatedGaussians are defined in -log space, as underflow/overflow problems will often occur in the non-log forms.
See Truncated Gaussian Math for implementation notes
Definition at line 59 of file TruncatedGaussian.h.
Definition at line 89 of file TruncatedGaussian.h.
Definition at line 88 of file TruncatedGaussian.h.
Definition at line 87 of file TruncatedGaussian.h.
Enum that describes different ways of sampling from a multidimensional TruncatedGaussian.
Definition at line 63 of file TruncatedGaussian.h.
lsst::meas::modelfit::TruncatedGaussian::~TruncatedGaussian | ( | ) |
|
inline |
Create an Evaluator object that can be used to efficiently evaluate the function.
Definition at line 355 of file TruncatedGaussian.h.
|
inline |
Create a LogEvaluator object that can be used to efficiently evaluate the -log of the function.
Definition at line 353 of file TruncatedGaussian.h.
|
static |
Create from the first and second logarithmic derivatives of the Gaussian.
This causes the TruncatedGaussian to model the function:
\[ f(\alpha) = 1_{\alpha \ge 0}(\alpha) \; e^{-q(0) -g^T \alpha -\frac{1}{2}\alpha^T H \alpha} = 1_{\alpha \ge 0}(\alpha) \; e^{-q(\alpha)} \]
Where \(1_{\alpha \ge 0}(\alpha)\) is the indicator function
\[ 1_{\alpha \ge 0}(\alpha) \equiv \begin{cases} 1 & \text{if $\alpha \ge 0$}\\ 0 & \text{if $\alpha \lt 0$} \end{cases} \]
Note that this implies
\[ \left.\frac{\partial q}{\partial \alpha} \right|_{\alpha=0} = g \]
\[ \left.\frac{\partial^2 q}{\partial \alpha^2} \right|_{\alpha=0} = H \]
with (for \(\alpha \ge 0\))
\[ q(\alpha) \equiv -\ln f(\alpha) \]
Note that unlike that constructed by fromStandardParameters(), in this case \(f(\alpha)\) is NOT normalized to integrate to one.
[in] | q0 | Zeroth-order term in the expansion |
[in] | gradient | Vector of first derivatives \(g\) |
[in] | hessian | Matrix of second derivatives \(H\) (symmetric) |
|
static |
Create from the "standard" mean and covariance parameters of the normal distribution.
This causes the TruncatedGaussian to model the function:
\[ f(\alpha) = \frac{1_{\alpha \ge 0}(\alpha)}{k\left|2\pi\Sigma\right|^{1/2}} e^{-\frac{1}{2}(\alpha-\mu)^T \Sigma^{-1} (\alpha-\mu)} = \frac{1_{\alpha \ge 0}(\alpha)}{k}\;\Phi(\alpha-\mu,\Sigma) \]
Where \(1_{\alpha \ge 0}(\alpha)\) is the indicator function
\[ 1_{\alpha \ge 0}(\alpha) \equiv \begin{cases} 1 & \text{if $\alpha \ge 0$}\\ 0 & \text{if $\alpha \lt 0$} \end{cases} \]
and \(k\) is the normalization constant that \(f(\alpha)\) integrates to unity:
\[ k \equiv \int_0^{\infty}\!\!\Phi(\alpha-\mu,\Sigma) d\alpha \]
Note that unlike that constructed by fromSeriesParameters(), in this case \(f(\alpha\) is normalized to integrate to one.
[in] | mean | Mean vector \(\mu\) |
[in] | covariance | Covariance matrix \(\Sigma\) (symmetric) |
int lsst::meas::modelfit::TruncatedGaussian::getDim | ( | ) | const |
Return the dimensionality of the function.
Scalar lsst::meas::modelfit::TruncatedGaussian::getLogIntegral | ( | ) | const |
Return the -log of the integral of the truncated function.
More precisely, this is simply
\[ -\ln\int_{-\infty}^{\infty} f(\alpha) d\alpha \]
In series form, this is equivalent to
\[ -\ln\int_0^{\infty} e^{-q(\alpha)} d\alpha \]
In standard parameter form it is 0 by construction.
Scalar lsst::meas::modelfit::TruncatedGaussian::getLogPeakAmplitude | ( | ) | const |
Return the -log of the peak amplitude of the untruncated function.
In series form, this is equal to \(q(\mu)\) where \(\mu=-H^{-1}g\). In standard parameter form, this is \(\frac{1}{2}\ln\left|2\pi\Sigma\right| - \ln k\).
Scalar lsst::meas::modelfit::TruncatedGaussian::getUntruncatedFraction | ( | ) | const |
Return the fraction of the Gaussian integral that was truncated by the bounds.
In series form (see fromSeriesParameters), this is
\[ \frac{\int_0^{\infty} e^{-q(\alpha)} d\alpha}{\int_{-infty}^{\infty} e^{-q(\alpha)} d\alpha} \]
while in standard parameter form it is simply the normalization \(k\) described in fromStandardParameters().
Vector lsst::meas::modelfit::TruncatedGaussian::maximize | ( | ) | const |
Return the location of the maximum of the truncated Gaussian.
This is simply the untruncated location parameter mu if all of its elements are positive; otherwise, one or more elements will be zero (and the rest may not be same as the elements of mu).
|
inline |
Create a Sampler object that uses the given strategy.
Definition at line 342 of file TruncatedGaussian.h.
|
inline |
Create a Sampler object that determines the strategy to use automatically.
If the efficiency (number of accepted samples divided by number of total samples) is would (on average) be greater than the given value, DIRECT_WITH_REJECTION is used. If not, ALIGN_AND_WEIGHT is used. Note that the sampling effeciency for DIRECT_WITH_REJECTION is exactly the same as the "untruncated fraction".
Definition at line 346 of file TruncatedGaussian.h.
|
friend |
Definition at line 233 of file TruncatedGaussian.h.
|
friend |
Definition at line 232 of file TruncatedGaussian.h.