-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathcheck_ltsa_time.m
94 lines (90 loc) · 4.9 KB
/
check_ltsa_time.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
function check_ltsa_time
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% check_ltsa_time.m
%
% checks to see if plot time is within file limits
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
global PARAMS HANDLES
if PARAMS.ltsa.tseg.step == -1
tbin = floor((PARAMS.ltsa.tseg.hr * 60 *60 ) / PARAMS.ltsa.tave);
cindex = PARAMS.ltsa.plotStartRawIndex;
cbin = tbin + PARAMS.ltsa.plotStartBin;
while cbin > PARAMS.ltsa.nave(cindex) && cindex < PARAMS.ltsa.nrftot
cbin = cbin - PARAMS.ltsa.nave(cindex);
cindex = cindex + 1;
end
plotend = PARAMS.ltsa.dnumStart(cindex) + datenum([0 0 0 0 0 (cbin)*PARAMS.ltsa.tave]);
else
plotend = PARAMS.ltsa.plot.dnum + datenum([0 0 0 PARAMS.ltsa.tseg.hr 0 0]);
end
%plot start time less than data start time
if PARAMS.ltsa.plot.dnum < PARAMS.ltsa.start.dnum
% Motion Buttons pushed - Backwards and AutoBackwards
if get(HANDLES.ltsa.motion.autoback,'Value') == 1 || get(HANDLES.ltsa.motion.back,'Value') == 1
disp_msg('Beginning of File')
PARAMS.ltsa.plot.dnum = PARAMS.ltsa.start.dnum;
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback HANDLES.ltsa.motion.stop],'Enable','off');
set([HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd],'Enable','on');
set(HANDLES.ltsa.motion.stop,'Userdata',0); % turn off while loop in autoback/fwd
else
% User input Plot Start Time and/or Plot Length
disp_msg('Too early - Stay at current time')
PARAMS.ltsa.plot.dnum = PARAMS.ltsa.save.dnum;
set(HANDLES.ltsa.motion.stop,'Userdata',0); % turn off while loop in autoback/fwd
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback HANDLES.ltsa.motion.stop],'Enable','off');
set([HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd],'Enable','on');
return
end
% plot start time same as data start time
elseif PARAMS.ltsa.plot.dnum == PARAMS.ltsa.start.dnum
disp_msg('Beginning of File')
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback HANDLES.ltsa.motion.stop],'Enable','off');
set([HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd],'Enable','on');
set(HANDLES.ltsa.motion.stop,'Userdata',0); % turn off while loop in autoback/fwd
% plot start time + plot duration greater than end of data time
% bogus for scheduled data
% elseif PARAMS.ltsa.plot.dnum + datenum([0 0 0 PARAMS.ltsa.tseg.hr 0 0]) > PARAMS.ltsa.end.dnum
elseif plotend > PARAMS.ltsa.end.dnum
if PARAMS.ltsa.tseg.step ~= -1
disp_msg('Too late - Stay at current time')
PARAMS.ltsa.plot.dnum = PARAMS.ltsa.save.dnum;
if PARAMS.ltsa.tseg.hr * 60 *60 > PARAMS.ltsa.durtot
PARAMS.ltsa.tseg.hr = PARAMS.ltsa.durtot / (60 * 60);
PARAMS.ltsa.tseg.sec = PARAMS.ltsa.durtot;
else
PARAMS.ltsa.tseg.hr = 2;
end
end
disp_msg('End of File')
set(HANDLES.ltsa.motion.stop,'Userdata',0); % turn off while loop in autoback/fwd
set([HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd HANDLES.ltsa.motion.stop],'Enable','off');
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback],'Enable','on');
return
% plot start time + plot duration same as data end time
% bogus for scheduled data
% turn on backs, off fwds and stop
elseif plotend == PARAMS.ltsa.end.dnum
disp_msg('End of File')
set([HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd HANDLES.ltsa.motion.stop],'Enable','off');
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback],'Enable','on');
set(HANDLES.ltsa.motion.stop,'Userdata',0); % turn off while loop in autoback/fwd
% disp_msg(['end.dnum= ',num2str(PARAMS.ltsa.plot.dnum)])
% not auto back and not auto forward
% turn all on except stop
else
if ~get(HANDLES.ltsa.motion.autoback,'Value') && ~get(HANDLES.ltsa.motion.autofwd,'Value')
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback...
HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd],'Enable','on')
end
end
% check to see if too large of a time segment to display
if PARAMS.ltsa.tseg.hr * 60 *60 > PARAMS.ltsa.durtot
PARAMS.ltsa.tseg.hr = PARAMS.ltsa.durtot / (60 * 60);
PARAMS.ltsa.tseg.sec = PARAMS.ltsa.durtot;
disp_msg('Time segment too Large, set to full file')
set(HANDLES.ltsa.time.edtxt3,'String',num2str(PARAMS.ltsa.tseg.hr));
set([HANDLES.ltsa.motion.seekbof HANDLES.ltsa.motion.back HANDLES.ltsa.motion.autoback...
HANDLES.ltsa.motion.seekeof HANDLES.ltsa.motion.fwd HANDLES.ltsa.motion.autofwd],'Enable','off')
end