use of gdsc.smlm.function.PoissonLikelihoodWrapper in project GDSC-SMLM by aherbert.
the class MaximumLikelihoodFitter method createLikelihoodWrapper.
private LikelihoodWrapper createLikelihoodWrapper(NonLinearFunction f, int n, double[] y, double[] a) {
LikelihoodWrapper maximumLikelihoodFunction = null;
final double myAlpha = (this.alpha > 0) ? this.alpha : 1;
// We can use different likelihood wrapper functions:
switch(likelihoodFunction) {
case POISSON_GAMMA_GAUSSIAN:
// Poisson-Gamma-Gaussian - EM-CCD data
maximumLikelihoodFunction = new PoissonGammaGaussianLikelihoodWrapper(f, a, y, n, myAlpha, sigma);
break;
case POISSON_GAUSSIAN:
// Sigma must be positive, otherwise fall back to a Poisson likelihood function
if (sigma > 0) {
maximumLikelihoodFunction = new PoissonGaussianLikelihoodWrapper(f, a, y, n, myAlpha, sigma);
break;
}
case POISSON:
default:
}
// Check if the method requires the gradient but it cannot be computed
if (maximumLikelihoodFunction == null || (searchMethod.usesGradient && !maximumLikelihoodFunction.canComputeGradient())) {
// Ensure no negative data for the Poisson likelihood method.
// Just truncate the counts for now. These are from noise in the count estimates that we do not model.
final double[] y2 = new double[n];
for (int i = 0; i < n; i++) {
if (y[i] < 0)
y2[i] = 0;
else
y2[i] = y[i];
}
PoissonLikelihoodWrapper function = new PoissonLikelihoodWrapper(f, a, y2, n, myAlpha);
// This will allow Powell searches. The effect on the gradient search algorithms may be weird so leave alone.
if (!searchMethod.usesGradient)
function.setAllowNegativeExpectedValues(true);
maximumLikelihoodFunction = function;
}
return maximumLikelihoodFunction;
}
Aggregations