Skip to content

Commit dbd0628

Browse files
committed
Add SACA PValue heatmatp op
1 parent c419f28 commit dbd0628

File tree

2 files changed

+135
-0
lines changed

2 files changed

+135
-0
lines changed
Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
/*-
2+
* #%L
3+
* ImageJ2 software for multidimensional image processing and analysis.
4+
* %%
5+
* Copyright (C) 2014 - 2024 ImageJ2 developers.
6+
* %%
7+
* Redistribution and use in source and binary forms, with or without
8+
* modification, are permitted provided that the following conditions are met:
9+
*
10+
* 1. Redistributions of source code must retain the above copyright notice,
11+
* this list of conditions and the following disclaimer.
12+
* 2. Redistributions in binary form must reproduce the above copyright notice,
13+
* this list of conditions and the following disclaimer in the documentation
14+
* and/or other materials provided with the distribution.
15+
*
16+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
20+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26+
* POSSIBILITY OF SUCH DAMAGE.
27+
* #L%
28+
*/
29+
30+
package org.scijava.ops.image.coloc.saca;
31+
32+
import net.imglib2.loops.LoopBuilder;
33+
import net.imglib2.RandomAccessibleInterval;
34+
import net.imglib2.type.numeric.real.DoubleType;
35+
36+
import org.apache.commons.math3.distribution.NormalDistribution;
37+
38+
/**
39+
* Helper class for Spatially Adaptive Colocalization Analysis (SACA) op.
40+
*
41+
* @author Edward Evans
42+
*/
43+
44+
public final class PNorm {
45+
46+
private PNorm() {}
47+
48+
public static void compute(RandomAccessibleInterval<DoubleType> input,
49+
boolean lowerTail, RandomAccessibleInterval<DoubleType> output)
50+
{
51+
// compute normal distribution over the image
52+
NormalDistribution normalDistribution = new NormalDistribution();
53+
54+
LoopBuilder.setImages(input, output).multiThreaded().forEachPixel((i, o) -> {
55+
double normDistValue = normalDistribution.cumulativeProbability(i.get());
56+
if (!lowerTail) {
57+
normDistValue = 1 - normDistValue;
58+
}
59+
o.set(normDistValue);
60+
});
61+
}
62+
}
Lines changed: 73 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,73 @@
1+
/*-
2+
* #%L
3+
* ImageJ software for multidimensional image processing and analysis.
4+
* %%
5+
* Copyright (C) 2014 - 2024 ImageJ developers.
6+
* %%
7+
* Redistribution and use in source and binary forms, with or without
8+
* modification, are permitted provided that the following conditions are met:
9+
*
10+
* 1. Redistributions of source code must retain the above copyright notice,
11+
* this list of conditions and the following disclaimer.
12+
* 2. Redistributions in binary form must reproduce the above copyright notice,
13+
* this list of conditions and the following disclaimer in the documentation
14+
* and/or other materials provided with the distribution.
15+
*
16+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
20+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26+
* POSSIBILITY OF SUCH DAMAGE.
27+
* #L%
28+
*/
29+
30+
package org.scijava.ops.image.coloc.saca;
31+
32+
import net.imglib2.RandomAccessibleInterval;
33+
import net.imglib2.type.numeric.real.DoubleType;
34+
35+
import org.scijava.function.Computers;
36+
import org.scijava.ops.spi.Nullable;
37+
38+
/**
39+
* Spatially Adaptive Colocalization Analysis (SACA) Adapted from Shulei's
40+
* original Java code for AdaptiveSmoothedKendallTau from his RKColocal R
41+
* package.
42+
* (https://github.com/lakerwsl/RKColocal/blob/master/RKColocal_0.0.1.0000.tar.gz)
43+
*
44+
* @author Shulei Wang
45+
* @author Curtis Rueden
46+
* @author Ellen TA Dobson
47+
* @author Edward Evans
48+
* @implNote op names='coloc.saca.heatmapPValue', priority='100.'
49+
*/
50+
51+
public class SACAHeatmapPValue implements
52+
Computers.Arity2<RandomAccessibleInterval<DoubleType>, Boolean, RandomAccessibleInterval<DoubleType>>
53+
{
54+
55+
/**
56+
* Spatially Adaptive Colocalization Analysis (SACA) P Value heatmap
57+
*
58+
* @param heatmap input heatmap returned from 'coloc.saca.heatmapZScore'
59+
* @param lowerTail lower tail (default=false)
60+
* @param result P value heatmap output
61+
*/
62+
63+
@Override
64+
public void compute(final RandomAccessibleInterval<DoubleType> heatmap,
65+
@Nullable Boolean lowerTail, RandomAccessibleInterval<DoubleType> result)
66+
{
67+
// set lowerTail if necessary
68+
if (lowerTail == null) lowerTail = true;
69+
70+
// compute the normal distribution
71+
PNorm.compute(heatmap, lowerTail, result);
72+
}
73+
}

0 commit comments

Comments
 (0)