-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapdCalc_NRPM.m
188 lines (148 loc) · 5.15 KB
/
apdCalc_NRPM.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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
function [apdC] = apdCalc_NRPM(data,start,endp,Fs,percent,maxAPD,minAPD,motion,coordinate,bg)
% The function [actC] = apdCalc() calculates the mean APD and the standard
%deviation in the area selected.
%INPUTS
%data= cmosdata(voltage,etc)
%start=windowed start time
%endp=windowed end time
%Fs=sampling frequency
%percent=percent repolarization
%maxAPD=maximum apd allowed
%minAPD=minimum apd allowed
%motion=boolean statement to allow motion to be removed
%coordinate=coordinates from selected box
%bg=background image
% OUTPUT
% A figure that has a color repersentation for action potential duration
% times that you selected. Mean and standard deviation APD in selected
%region
% METHOD
%We use the the maximum derivative of the upstroke as the initial point of
%activation. The time of repolarization is determine by finding the time
%at which the maximum of the signal falls to the desired percentage. APD is
%the difference between the two time points.
% REFERENCES
%None
% ADDITIONAL NOTES
% None
% RELEASE VERSION 1.0.0
% AUTHOR: Matt Sulkin (sulkin.matt@gmail.com)
%% Create initial variablesns
start=round(start*Fs);
endp=round(endp*Fs);
coordinate=round(coordinate);
%Use data only in your window
%apd_data = data(coordinate(2):coordinate(2)+coordinate(4),coordinate(1):coordinate(1)+coordinate(3),start:endp);
%% NON RECTANGULAR POLYGON MOD %%
m = (coordinate(2,2)-coordinate(1,2))/(coordinate(2,1)-coordinate(1,1));
top_b = coordinate (1,2)-m*coordinate(1,1);
low_b = coordinate(3,2)-m*coordinate(3,1);
xdiff = coordinate(3,1)-coordinate(2,1);
lb = m.*(coordinate(1,1):coordinate(2,1))+top_b;
lb = [lb repmat(coordinate(2,2),[1 xdiff])];
lb = round(lb);
ub= m.*(coordinate(1,1)+xdiff:coordinate(3,1))+low_b;
ub = [repmat(coordinate(1,2),[1 xdiff]) ub];
ub = round(ub);
%make an empty variable for storing the indices of the regional points
apd_data = [];
apd_ind = [];
for n = 0:coordinate(3,1)-coordinate(1,1)
for m = lb(n+1):ub(n+1)
apd_data = [apd_data; squeeze(data(m,coordinate(1,1)+n,start:endp))'];
apd_ind = [apd_ind; sub2ind([100 100],m,coordinate(1,1)+n)];
end
end
%% CONTINUE OLD CODE
apd_data = normalize_data_NRPM(apd_data,Fs); %re-normalize windowed data
% %REMOVE MOTION
%remove motion with peak finder
%makes an matrix of 10000 x the number of frames
if motion==1
apd_data=reshape(apd_data,(coordinate(3)+1)*(coordinate(4)+1),[]);
for i=1:coordinate(3)*coordinate(4)
[peaks,location] = findpeaks(apd_data(i,:), 'minpeakheight', .7);
if length(location)>1
apd_data(i,:)=nan;
end
end
apd_data=reshape(apd_data,coordinate(3)+1,coordinate(4)+1,[]);
end
%%Determining activation time point
% Find First Derivative and time of maximum
%apd_data2 = diff(apd_data,1,3); % first derivative
apd_data2 = diff(apd_data,1,2); %NON RECTANGULAR POLYGON MOD
%[max_der max_i] = max(apd_data2,[],3); % find location of max derivative
[max_der max_i] = max(apd_data2,[],2); %NON RECTANGULAR POLYGON MOD
%%Find location of repolarization
%%Find maximum of the signal
%[maxVal maxValI] = max(apd_data,[],3);
[maxVal maxValI] = max(apd_data,[],2); %NON RECTANGULAR POLYGON MOD
%locs is a temporary holding place
locs = zeros(size(apd_data,1),1);
%Define the baseline value you want to go down to
requiredVal = 1.0 - percent;
%%for each pixel
% for i = 1:size(apd_data,1)
% for j = 1:size(apd_data,2)
% %%starting from the peak of the signal, loop until we reach baseline
% for k = maxValI(i,j):size(apd_data,3)
% if apd_data(i,j,k) <= requiredVal
% locs(i,j) = k; %Save the index when the baseline is reached
% %this is the repolarizatin time point
% break;
% end
% end
% end
% end
%% NON RECTANGULAR POLYGON MOD
for i = 1:size(apd_data,1)
for j = maxValI(i):size(apd_data,2)
if apd_data(i,j) <= requiredVal
locs(i) = j;
break;
end
end
end
%%
%%account for different sampling frequencies
unitFix = 1000.0 / Fs;
% Calculate Action Potential Duration
apd = minus(locs,max_i);
apdMap = apd * unitFix;
apdMap(apdMap <= 0) = nan;
%remove APD that are out of imput values
apdMap(apdMap>maxAPD) = nan;
apdMap(apdMap<minAPD) = nan;
% %calculating mean and std
apd_mean = nanmean(apdMap(:));
apd_std = nanstd(apdMap(:));
apd_median = nanmedian(apdMap(:));
%Setting up values to use for color axis
APD_min = mean(apdMap(isfinite(apdMap))) - 2*std(apdMap(isfinite(apdMap)));
APD_max = mean(apdMap(isfinite(apdMap))) + 2*std(apdMap(isfinite(apdMap)));
% Plot APDMap
cc=figure('Name','APD Map');
% Create Mask
actMap_Mask = zeros(size(bg));
actMap_Mask(apd_ind) = 1;
actMap_Mask2 = zeros(size(bg));
actMap_Mask2(apd_ind) =apdMap;
%Build Image
G =real2rgb(bg, 'gray');
J=real2rgb(actMap_Mask2,'jet',[APD_min APD_max]);
A=real2rgb(actMap_Mask,'gray');
I = J .* A + G .* (1-A);
subplot(1,2,1)
image(I)
axis image
set(gca,'XTick',[],'YTick',[],'Xlim',[0 size(data,1)],'YLim',[0 size(data,2)])
%subplot(1,3,2)
%imagesc(apdMap)
%axis image
colorbar
caxis([APD_min APD_max])
subplot(1,2,2)
hist(reshape(apdMap,[],1),floor(APD_max-APD_min)*2)
xlim([APD_min APD_max])
end