use of gdsc.core.test.TimingService in project GDSC-SMLM by aherbert.
the class EJMLLinearSolverTest method runSolverSpeedTest.
private void runSolverSpeedTest(int flags) {
final Gaussian2DFunction f0 = GaussianFunctionFactory.create2D(1, 10, 10, flags, null);
int n = f0.size();
final double[] y = new double[n];
final TurboList<DenseMatrix64F> aList = new TurboList<DenseMatrix64F>();
final TurboList<DenseMatrix64F> bList = new TurboList<DenseMatrix64F>();
double[] testbackground = new double[] { 0.2, 0.7 };
double[] testsignal1 = new double[] { 30, 100, 300 };
double[] testcx1 = new double[] { 4.9, 5.3 };
double[] testcy1 = new double[] { 4.8, 5.2 };
double[] testw1 = new double[] { 1.1, 1.2, 1.5 };
int np = f0.getNumberOfGradients();
GradientCalculator calc = GradientCalculatorFactory.newCalculator(np);
final RandomDataGenerator rdg = new RandomDataGenerator(new Well19937c(30051977));
//double lambda = 10;
for (double background : testbackground) // Peak 1
for (double signal1 : testsignal1) for (double cx1 : testcx1) for (double cy1 : testcy1) for (double w1 : testw1) {
double[] p = new double[] { background, signal1, 0, cx1, cy1, w1, w1 };
f0.initialise(p);
f0.forEach(new ValueProcedure() {
int i = 0;
public void execute(double value) {
// Poisson data
y[i++] = rdg.nextPoisson(value);
}
});
double[][] alpha = new double[np][np];
double[] beta = new double[np];
//double ss =
calc.findLinearised(n, y, p, alpha, beta, f0);
//System.out.printf("SS = %f\n", ss);
// As per the LVM algorithm
//for (int i = 0; i < np; i++)
// alpha[i][i] *= lambda;
aList.add(EJMLLinearSolver.toA(alpha));
bList.add(EJMLLinearSolver.toB(beta));
}
DenseMatrix64F[] a = aList.toArray(new DenseMatrix64F[aList.size()]);
DenseMatrix64F[] b = bList.toArray(new DenseMatrix64F[bList.size()]);
int runs = 100000 / a.length;
TimingService ts = new TimingService(runs);
TurboList<SolverTimingTask> tasks = new TurboList<SolverTimingTask>();
tasks.add(new PseudoInverseSolverTimingTask(a, b));
tasks.add(new LinearSolverTimingTask(a, b));
tasks.add(new CholeskySolverTimingTask(a, b));
tasks.add(new CholeskyLDLTSolverTimingTask(a, b));
tasks.add(new DirectInversionSolverTimingTask(a, b));
for (SolverTimingTask task : tasks) if (!task.badSolver)
ts.execute(task);
ts.repeat();
ts.report();
}
use of gdsc.core.test.TimingService in project GDSC-SMLM by aherbert.
the class CustomGammaDistributionTest method customDistributionIsFaster.
@Test
public void customDistributionIsFaster() {
TimingService ts = new TimingService(5);
ts.execute(new StaticTimingTask());
ts.execute(new InstanceTimingTask());
int size = ts.getSize();
ts.repeat(size);
ts.report(size);
Assert.assertTrue(ts.get(-1).getMean() < ts.get(-2).getMean());
}
use of gdsc.core.test.TimingService in project GDSC-SMLM by aherbert.
the class CustomPoissonDistributionTest method customDistributionIsFasterWithSmallMean.
@Test
public void customDistributionIsFasterWithSmallMean() {
TimingService ts = new TimingService(5);
ts.execute(new StaticTimingTask(10, 38));
ts.execute(new InstanceTimingTask(10, 38));
int size = ts.getSize();
ts.repeat(size);
ts.report(size);
Assert.assertTrue(ts.get(-1).getMean() < ts.get(-2).getMean());
}
use of gdsc.core.test.TimingService in project GDSC-SMLM by aherbert.
the class CustomPoissonDistributionTest method customDistributionIsFasterWithTinyMean.
@Test
public void customDistributionIsFasterWithTinyMean() {
TimingService ts = new TimingService(5);
ts.execute(new StaticTimingTask(0.5, 10));
ts.execute(new InstanceTimingTask(0.5, 10));
int size = ts.getSize();
ts.repeat(size);
ts.report(size);
Assert.assertTrue(ts.get(-1).getMean() < ts.get(-2).getMean());
}
Aggregations