Plot over time milliseconds
45 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Eduardo Santos
el 11 de Oct. de 2019
Comentada: Jon
el 11 de Oct. de 2019
I'm trying to plot a number over time. The idea is to show on X-axis the date with milliseconds format.
The code below is not working properly, could some one help me?
figure(1)
while(1)
timestr = datetime(clock,'InputFormat','yyyy-MM-dd HH:mm:ss.S', 'Format', 'yyyy-MM-dd HH:mm:ss.SSS');
plot(timestr, rand(1));
pause(0.01)
end
0 comentarios
Respuesta aceptada
Jon
el 11 de Oct. de 2019
Editada: Jon
el 11 de Oct. de 2019
I'm not quite clear on what you are trying to accomplish but it looks like some how you want to see the plot continue to evolve as time goes along.
You could modify your code as follows and see the points continuously updated, the key is to use the hold on command:
% assign number of iterations
numIter = 1000;
% open new figure
figure
hold on % so figure isn't cleared with each plot command
% initialize previous values for connecting the dots
tOld = datetime('now');
yOld = rand(1);
% enter plotting loop
for k = 1:numIter
t= datetime('now');
y = rand(1);
% plot data up to the current iteration
plot([tOld,t], [yOld,y],'-bo');
xtickformat('yyyy-MM-dd HH:mm:ss.SSS')
tOld = t;
yOld = y;
pause(0.01)
end
hold off
Note, I made the code loop for a fixed number of iterations rather than have to ctrl-c to end the infinite while loop that you had.
Also a few other cleanup items, the clock command returns a six element date vector. If you call datetime(clock) it must first convert the clock value to a datetime. Instead just use datetime('now'). There is no need for formatting the value returned by calling datetime('now'), that is handled by the xtickformat
In the above code I connected the data points with lines. If you don't need the dots connected by lines then you don't need to save the previous values, you can just plot t and y with a symbol
4 comentarios
Más respuestas (0)
Ver también
Categorías
Más información sobre Dates and Time en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!