//Example macro that does a diffusion analysis on a results table of tracking data
//The required format is as generated by the Manual Tracking plugin 
//http://rsbweb.nih.gov/ij/plugins/track/track.html
//assuming Results Table column headings; Track > Slice > X > Y
//It requires many tracks and many time points!
//Plots the cumulative mean squared displacement (MSD) per time point
//For a more accurate approach see the time ensemble average example

dis2 = 0;
for (i=0; i<nResults(); i++){
	if (getResult("Slice", i)==1) {setResult("Dis^2", i, 0);}

	else{ if (getResult("Track", i)>getResult("Track", i-1)) {setResult("Dis^2", i, 0);} 
	
	else {
	B9 = getResult("X", i);
	B8 = getResult("X", i-1);
	C9 = getResult("Y", i);
	C8 = getResult("Y", i-1);
	disx=(B9-B8)*(B9-B8);
	disy=(C9-C8)*(C9-C8);
	dis2 = (disx+disy);
	setResult("Dis^2", i, dis2);
		}
	}
}
updateResults;

//get last slice
maxslice = 0;
for (b=0; b<nResults(); b++) {
    if (getResult("Slice",b)>maxslice)
    {
     maxslice = getResult("Slice",b);
    	}
    	else{};
}

//get first slice
minslice = maxslice;
for (c=0; c<nResults(); c++) {
    if (getResult("Slice",c)<minslice)
    {
     minslice = getResult("Slice",c);
    	}
    	else{};
}

//Calculate MSD for each slice and append to a new array (MSD)
MSD = newArray();
t=0;
time = newArray();
z = 0;

for (m=minslice; m<maxslice; m++){
	slice = newArray();
	for (l=0; l<nResults(); l++) {if (getResult("Slice", l)==m) {	
		x = getResult("Dis^2", l);
		slice = Array.concat(slice, x);
	}
}
t++;
Array.getStatistics(slice, min, max, mean, std);
z = mean+z;
MSD = Array.concat(MSD, z);
time = Array.concat(time, t);
}
//Plot cumulative MSD against time
Fit.doFit("Straight Line", time, MSD);
Fit.plot();

//Richard Mort 26/01/2013