data:image/s3,"s3://crabby-images/d7a86/d7a86ab8e7fb8423b56c702bb852f247ea86fe0d" alt=""
Centre of mass of an N-D image (1 < N < 3)
data:image/s3,"s3://crabby-images/15cde/15cdeed7b875902a2a203a47bb9174db5daf8323" alt=""
andyfaff
Function test() make/n=(100,100, 100)/free w w = gauss(x, 10, 3, y, 20, 3, z, 30, 3) wave temp = com3D(w) print temp End Function/wave com3D(w) Wave w variable ii, t1, t2, t3 make/n=(wavedims(w))/free/d COM switch(wavedims(w)) case 1: COM[0] = Pla_peakcentroid(w) break case 2: imagetransform sumallrows w COM[0] = Pla_peakcentroid(W_sumrows) imagetransform sumallcols w COM[1] = Pla_peakcentroid(W_sumcols) break case 3: imagetransform sumplanes w Wave temp = com3D(M_SumPlanes) COM[0] = temp[0] COM[1] = temp[1] imagetransform/g = 2 transposeVol w imagetransform sumplanes M_volumetranspose imagetransform sumallrows M_sumplanes COM[2] = Pla_peakcentroid(W_sumrows) break default: break endswitch return COM End Threadsafe Function Pla_peakCentroid(ywave) Wave ywave variable retval duplicate/free ywave, W_integrate W_integrate = 0 multithread W_integrate[] = Area(tempy, 0, p) W_integrate /= W_integrate[numpnts(W_tempy)-1] variable centroid = binarysearchinterp(W_integrate,0.5) if(numtype(centroid)) retval = NaN else retval = centroid endif return retval End
data:image/s3,"s3://crabby-images/fd1c6/fd1c688056bb8a3246365d55086ce03870de4c15" alt=""
Forum
data:image/s3,"s3://crabby-images/be58a/be58a354e643dd8b9d5e62ca67ded2fcd16ebd75" alt=""
Support
data:image/s3,"s3://crabby-images/48942/48942865fbf258cbebad94b47eb736d1918aad72" alt=""
Gallery
Igor Pro 9
Learn More
Igor XOP Toolkit
Learn More
Igor NIDAQ Tools MX
Learn More