forked from irfu/irfu-matlab
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEpochCdf16.m
68 lines (65 loc) · 2.18 KB
/
EpochCdf16.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
classdef EpochCdf16 < GenericTimeArray
%EpochCdf16 Class representing CDF epoch16, seconds and picoseconds.
% Detailed explanation goes here
% ----------------------------------------------------------------------------
% "THE BEER-WARE LICENSE" (Revision 42):
% <yuri@irfu.se> 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
% ----------------------------------------------------------------------------
properties
ps
end
methods
function obj = EpochCdf16(inp,inp2)
if nargin==0, return, end
if nargin==2, obj.ps = inp2; 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 = 3; end
d = cdflib.epoch16Breakdown([obj.epoch; obj.ps]);
switch format
case 0
s = num2str(d,'%04d-%02d-%02dT%02d:%02d:%02d.%03d%03dZ');
case 1
s = num2str(d,'%04d-%02d-%02dT%02d:%02d:%02d.%03dZ');
case 2
s = num2str(d,'%04d-%02d-%02dT%02d:%02d:%02d.%03d%03d%03dZ');
case 3
s = num2str(d,'%04d-%02d-%02dT%02d:%02d:%02d.%03d%03d%03d%03dZ');
otherwise
error('wrong format')
end
end
function res = toEpochUnix(obj)
res = EpochUnix(EpochCdf.cdfepoch2epoch(obj.epoch));
end
end
methods (Static)
function t_out = cdfepoch162epoch(s,ps)
t_out = (s-62167219200)+ps*1e-12;
end
function [s_out,ps_out] = epoch2cdfepoch16(t_in)
s_out = fix(t_in)+62167219200; ps_out = mod(t_in,1)*1e12;
end
end
end