-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpath_statistics.m
30 lines (26 loc) · 1.7 KB
/
path_statistics.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
function [] = path_statistics ()
%%path_statistics (tracks.xvalscm, tracks.yvalscm, tracks)
% This function calculates pathlength, max displacement, distance ratio,
% and (if applicable) displacement relative to user provided reference ROIs
global tracks
global vals
%% Calculate path and max displacement for generating a distance ratio, in combination with the maximum distance moved.
% I currently don't need the pathlength data, but it might
% come in handy later. Since these values are already relative, I'm using
% the ones that aren't adjusted relative to the input ports.
[vals.maxdisplacement vals.pathlength vals.meanspeed vals.instantspeed vals.travelpath]= displace([tracks.xvalscm(1,:);tracks.yvalscm(1,:)], tracks.xvalscm, tracks.yvalscm);
vals.distanceratio=vals.pathlength./vals.maxdisplacement; %Calculation of distance ratio, as defined in Castelletto et al 2014. Total distance traveled/maximum displacement.
%% Calculating final resting place of each worm relative to the left and right alignment locations.
if exist("tracks.Lx")
%Calculating final displacement relative to left alignment mark
displacement.L =sqrt((tracks.Lx-0).^2 + (tracks.Ly-0).^2);
B= ~isnan(displacement.L);
Indices = arrayfun(@(x) find(B(:,x),1,'last'), 1:size(displacement.L,2));
vals.finaldisp.L = arrayfun(@(x,y) displacement.L(x,y), Indices, 1:size(displacement.L,2));
%Calculating final displacement relative to right alignment mark
displacement.R =sqrt((tracks.Rx).^2 + (tracks.Ry).^2);
B= ~isnan(displacement.R);
Indices = arrayfun(@(x) find(B(:,x),1,'last'), 1:size(displacement.R,2));
vals.finaldisp.R = arrayfun(@(x,y) displacement.R(x,y), Indices, 1:size(displacement.R,2));
end
end