将毫秒转换为小时和绘图

时间:2017-05-01 10:18:59

标签: matlab plot time-series datetime-conversion

我正在尝试转换毫秒数组及其各自的数据。但是我希望在几小时和几分钟内完成。

Millis = [60000 120000 180000 240000....]
Power = [ 12 14 12 13 14 ...]

我已将其设置为每分钟记录数据,因此60000 millis(= 1最小值)。我试图在x轴上绘制时间并打开y的电源。我希望以小时和分钟显示x轴,每个相应的功率数据对应于其各自的时间。

我试过这个

for i=2:length(Millis)
Conv2Min(i) = Millis(i) / 60000;
Time(i) = startTime + Conv2Min(i);
if (Time(i-1) > Time(i) + 60)
Time(i) + 100;
end

end
s = num2str(Time);

这是为了尝试将毫秒转换为从08:00开始的小时,并且一旦60分钟已经过去了09:00,问题就在于此。我在08:59到09:00之间有差距。我也无法保持0=initial 0

2 个答案:

答案 0 :(得分:5)

在这种情况下,最好使用datenum值,然后使用datetick设置plot'HH:MM'的刻度标签格式。

假设您开始在t_1 = [HH_1, MM_1]进行测量并停止在t_2 = [HH_2, MM_2]进行测量。

生成datenum值数组的一个很酷的技巧是使用以下表达式:

time_datenums = HH_1/24 + MM_1/1440 : 1/1440 : HH_2/24 + MM_2/1440;

说明:

我们正在使用colon (:) operator创建一个定期间隔的向量time_datenums = A:B:C,其中A是起始datenum值,Bdatenum之间的增量{1}}值和C是结束datenum值。

由于您的测量是每分钟(60000毫秒)进行的,因此datenum值之间的增量也应为1分钟。由于一天有24小时,每天1440分钟,因此使用B = 1/1440作为向量元素之间的增量,以获得1分钟的增量。

对于AC,我们只需将小时数除以24,将分钟数除以1440,然后将它们相加:

  • A = HH_1/24 + MM_1/1440
  • C = HH_2/24 + MM_2/1440

例如,如果是t_1 = [08, 00],那么A = 08/24 + 00/1440。就这么简单。

请注意,此过程根本不使用datenum function,但仍会设法生成datenum值的有效数组,只考虑datenum的时间,无需担心datenum的日期。您可以详细了解herehere

回到原来的问题,让我们来看看代码:

time_millisec = 0:60000:9e6;             % Time array in milliseconds.
power = 10*rand(size(time_millisec));    % Random power data.

% Elapsed time in milliseconds.
elapsed_millisec = time_millisec(end) - time_millisec(1); 
% Integer part of elapsed hours.
elapsed_hours_int = fix(elapsed_millisec/(1000*60*60));
% Fractional part of elapsed hours.
elapsed_hours_frac = (elapsed_millisec/(1000*60*60)) - elapsed_hours_int;

t_1 = [08, 00]; % Start time 08:00
t_2 = [t_1(1) + elapsed_hours_int, t_1(2) + elapsed_hours_frac*60]; % Compute End time.

HH_1 = t_1(1); % Hour digits of t_1
MM_1 = t_1(2); % Minute digits of t_1

HH_2 = t_2(1); % Hour digits of t_2
MM_2 = t_2(2); % Minute digits of t_2

time_datenums = HH_1/24+MM_1/1440:1/1440:HH_2/24+MM_2/1440; % Array of datenums.

plot(time_datenums, power);    % Plot data.
datetick('x', 'HH:MM');        % Set 'HH:MM' datetick format for the x axis.

这是输出:

plot with dateticks in 'HH:MM? format

答案 1 :(得分:1)

我会使用datenums:

Millis = [60000 120000 180000 240000 360000];
Power = [ 12 14 12 13 14 ];
d = [2017 05 01 08 00 00]; %starting point (y,m,d,h,m,s)
d = repmat(d,[length(Millis),1]);
d(:,6)=Millis/1000; %add them as seconds
D=datenum(d); %convert to datenums
plot(D,Power) %plot
datetick('x','HH:MM') %set the x-axis to datenums with HH:MM as format

更短的方法是:(感谢codeaviator的想法)

Millis = [60000 120000 180000 240000 360000];
Power = [ 12 14 12 13 14 ];
D = 8/24+Millis/86400000; %24h / day, 86400000ms / day
plot(D,Power) %plot
datetick('x','HH:MM') %set the x-axis to datenums with HH:MM as format