forked from rrasheed/Rhythm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathphaseMap.m
executable file
·88 lines (86 loc) · 2.62 KB
/
phaseMap.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
function phaseMap(data,starttime,endtime,Fs,cmap)
%% Hilbert Transform Generated Phase Map
%
% INPUTS
% data = cmos data
% starttime = start time of viewing window
% endtime = end time of viewing window
% Fs = sampling frequency
% cmap = colormap (inverted/not inverted)
%
% OUTPUT
% A figure that has a color repersentation for phase
%
% REFERENCES
% None
%
% ADDITIONAL NOTES
% None
%
% RELEASE VERSION: 2014b v1.0
%
% AUTHOR: Jake Laughner
%
% MAINTED BY: Christopher Gloschat - ([email protected]) - [Jan. 2015 - Present]
%
% MODIFICATION LOG:
% February 12, 2015 - I restructured the code to first calculate phase,
% then request a directory and filename for the video, and finally to step
% through the phase images capturing them as a video. I also added a
% progress bar.
%
%% Code %%
% Calculate Hilbert Transform
data = data(:,:,round(starttime*Fs+1):round(endtime*Fs+1));
temp = reshape(data,[],size(data,3)) - repmat(mean(reshape(data,[],size(data,3)),2),[1 size(data,3)]);
hdata = hilbert(temp');
phase = -1*angle(hdata)';
phase = reshape(phase,size(data,1),size(data,2),[]);
% Choose location to save file and name of file
dir = uigetdir;
% If the cancel button is selected cancel the function
if dir == 0
return
end
% Request the desired name for the movie file
filename = inputdlg('Enter Filename:');
filename = char(filename);
% Check to make sure a value was entered
if isempty(filename)
error = 'A filename must be entered! Function cancelled.';
msgbox(error,'Incorrect Input','Error');
return
end
% Convert filename to a character string
filename = char(filename);
% Create path to file
movname = [dir,'/',filename,'.avi'];
% Capture video fo the Hilbert Transform represented phase over window
fig = figure('Name',filename,'Visible','off');
pa = axes;
vidObj = VideoWriter(movname,'Motion JPEG AVI');
open(vidObj);
movegui(fig,'center')
set(fig,'Visible','on');
% Create progress bar
gg = waitbar(0,'Producing Phase Map','Visible','off');
tmp = get(gg,'Position');
set(gg,'Position',[tmp(1) tmp(2)/4 tmp(3) tmp(4)],'Visible','on')
axes(pa)
for i = 1:size(data,3)
imagesc(phase(:,:,i),'Parent',pa);
colormap(fig,cmap)
colorbar(pa)
caxis(pa,[-pi pi])
axis(pa,'image')
axis(pa,'off')
pause(.05)
F = getframe(fig);
writeVideo(vidObj,F);% Write each frame to the file.
% Update progress bar
waitbar(i/size(data,3))
end
close(gg)
close(fig)
close(vidObj) % Close the file.
end