//Example macro calculating stats from a results table column //Import any data into a results table and then use the following to extract summary stats //The examples use "Area" as the column heading //All results checked with OpenOffice Calc, note: variance uses n-1 to correct for sample bias //Some variables N=0; total_area=0; mean_area=0; total_variance=0; variance_area=0; SD_Area=0; SE_Area=0; CI95_Area=0; max_area=0; min_area=0; //Generate a results table run("Clear Results"); run("Blobs (25K)"); run("Make Binary"); run("Set Measurements...", "area redirect=None decimal=4"); run("Analyze Particles...", "size=0-Infinity circularity=0.00-1.00 show=Nothing display exclude"); //Number of results in "Area" Column N = nResults; //Mean "Area"column for (a=0; a<nResults(); a++) { total_area=total_area+getResult("Area",a); mean_area=total_area/nResults; } //Max value in "Area" column for (a=0; a<nResults(); a++) { if (getResult("Area",a)>max_area) { max_area = getResult("Area",a); } else{}; } //Min value in "Area" column (note: requires max value) min_area=max_area; for (a=0; a<nResults(); a++) { if (getResult("Area",a)<min_area) { min_area = getResult("Area",a); } else{}; } //Variance of "Area" column for (a=0; a<nResults(); a++) { total_variance=total_variance+(getResult("Area",a)-(mean_area))*(getResult("Area",a)-(mean_area)); variance_area=total_variance/(nResults-1); } //SD of "Area" column (note: requires variance) SD_Area=sqrt(variance_area); //SE of "Area" column (note: requires SD) SE_Area = (SD_Area/(sqrt(N))); //95% CI of column "Area" (note: requires SE) CI95_Area = 1.96*SE_Area; //Return values print("N = "+N); print("Mean = "+mean_area); print("Var = "+variance_area); print("SD = "+SD_Area); print("SE = "+SE_Area); print("95% CI = "+CI95_Area); print("Max = "+max_area); print("Min = "+min_area); //Richard Mort 13/04/2012