forked from irfu/irfu-matlab
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEpochCdf.m
52 lines (50 loc) · 1.85 KB
/
EpochCdf.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
classdef EpochCdf < GenericTimeArray
%EpochCdf Class representing CDF epoch
% Detailed explanation goes here
% ----------------------------------------------------------------------------
% "THE BEER-WARE LICENSE" (Revision 42):
% <[email protected]> wrote this file. As long as you retain this notice you
% can do whatever you want with this stuff. If we meet some day, and you think
% this stuff is worth it, you can buy me a beer in return. Yuri Khotyaintsev
% ----------------------------------------------------------------------------
methods
function obj = EpochCdf(inp)
if nargin==0, return, end
if isa(inp,'double'),
if min(size(inp))>1
error('irf:EpochCdf:EpochCdf:badInputs',...
'double input (CDF epoch) must be a columt or row vector')
end
obj.epoch = inp(:); % column vector
elseif isa(inp,'char')
if GenericTimeArray.validate_utc(inp)
epochTmp = iso2epoch(inp);
obj.epoch = EpochCdf.epoch2cdfepoch(epochTmp);
else
error('irf:EpochCdf:EpochCdf:badInputs',...
'UTC string input (char) must be in the form yyyy-mm-ddThh:mm:ss.mmmuuunnnZ')
end
else
error('irf:EpochCdf:EpochCdf:badInputs',...
'Expected inputs: double (CDF epoch) or char (yyyy-mm-ddThh:mm:ss.mmmuuunnnZ)')
end
end
function s = toUtc(obj,format)
% s = toUtc(obj,format)
if nargin<2, format = 0; end
epochTmp = EpochCdf.cdfepoch2epoch(obj.epoch);
s = epoch2iso(epochTmp,format);
end
function res = toEpochUnix(obj)
res = EpochUnix(EpochCdf.cdfepoch2epoch(obj.epoch));
end
end
methods (Static)
function t_out = cdfepoch2epoch(t_in)
t_out = (t_in-62167219200000)/1000;
end
function t_out = epoch2cdfepoch(t_in)
t_out = t_in*1000 + 62167219200000;
end
end
end