forked from rrasheed/Rhythm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapdMap.m
executable file
·126 lines (110 loc) · 3.68 KB
/
apdMap.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
function [apdMap] = apdMap(data,start,endp,Fs,percent,cmap,filename,dir)
%% the function apdMap creates a visual representation of the action potential duration
%
% INPUTS
% data=cmos data
% start=start time
% endp=end time
% Fs=sampling frequency
% percent=percent repolarization
%
% OUTPUT
% A figure that has a color repersentation for action potential duration
% times
%
% 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 ([email protected])
%
% MAINTED BY: Christopher Gloschat - ([email protected]) - [Jan. 2015 - Present]
%
% MODIFICATION LOG:
% Jan. 26, 2015 - The input cmap was added to input the colormap and code
% was added at the end of the function to set the colormap to the user
% determined values. In this case the most immediate purpose is to
% facilitate inversion of the default colormap.
%
%% Create initial variablesns
start=round(start*Fs);
endp=round(endp*Fs);
apd_data = data(:,:,start:endp); % window signal
apd_data = normalize_data(apd_data,Fs); %re-normalize windowed data
%%Determining activation time point
% Find First Derivative and its index of maximum
apd_data2 = diff(apd_data,1,3); % first derivative
[~,max_i] = max(apd_data2,[],3); % find location of max derivative
%%Find location of repolarization
%%Find maximum of the signal and its index
[~,maxValI] = max(apd_data,[],3);
%locs is a temporary holding place
locs = nan(size(apd_data,1),size(apd_data,2));
%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
%%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;
%Setting up values to use for color axis
APD_min = prctile(apdMap(isfinite(apdMap)),5);
APD_max = prctile(apdMap(isfinite(apdMap)),95);
% Plot APDMap
figure('Name','APD Map');
map_fig1 = subplot(1,1,1,'replace');
imagesc(apdMap,'Parent',map_fig1)
% contourf(flipud(apdMap))
title('APD Map')
axis image
set(gca,'XTick',[],'YTick',[],'Xlim',[0 size(data,1)],'YLim',[0 size(data,2)])
colormap(cmap);
colorbar
caxis([APD_min APD_max])
% Plot Histogram of APDMap
figure('Name','Histogram of APD')
hist(reshape(apdMap,[],1),floor(APD_max-APD_min))
%xlim([APD_min APD_max])
% User prompt for input to create csv
prompt1 = {'Save APD map?'};
dlg_title1 = 'Save APD map';
num_lines1 = [1 60];
file = strtok(filename,'.'); % Get filename without extension
def1 = {strcat(dir,'/APDMaps/APD-',file,'.csv')};
answer = inputdlg(prompt1,dlg_title1,num_lines1,def1);
% process user inputs
if isempty(answer) % cancel save if user clicks "cancel"
return
end
filename = answer{1};
% create the APDMaps folder if it doesn't exist already.
newSubFolder = strcat(dir,'/APDMaps/');
if ~exist(newSubFolder, 'dir')
mkdir(newSubFolder);
end
csvwrite(filename,apdMap);
end