hello everyone .can anyone help me and explain to me this codes for real time ploting????please????

4 vues (au cours des 30 derniers jours)
arduino=serial('COM10','BaudRate',9600);
fopen(arduino);
CM(1)=0;
time(1)=0;
i=1;
tic;
while (toc<=100)
CM(2)=fscanf(arduino,'%f');
time(2)=toc;
figure(1);
grid on;
axis([toc-10, toc+10, 0, 35])
h(i)=plot(time,CM,'b','LineWidth',5);
hold on
CM(1)=CM(2);
time(1)=time(2);
if(i >= 300)
delete(h(i-299));
end
i=i+1;
end
fclose(arduino); % end communication with arduino
  3 commentaires
Walter Roberson
Walter Roberson le 29 Mai 2022
Bleh. That code should be rewritten to use animatedline()
mark spectre
mark spectre le 29 Mai 2022
I DONT UNDERSTAND the meaninig of i and i=i+1
and this line
h(i)
if(i >= 300)
delete(h(i-299));
end

Connectez-vous pour commenter.

Réponses (1)

Walter Roberson
Walter Roberson le 29 Mai 2022
As the code runs, data points come in, at times that are not going to be strictly regular (and might possibly be irregular.)
As each new point comes in, the code draws a line segment from the previous point to the new point, and it shifts the axis limits to show 10 seconds before and after the current time. It records the line handles, and after it has accumulated 300 line handles, as it goes it deletes the one that was created 299 ago. So it creates handle #300, deletes handle #1; creates handle #301, deletes handle #2, and so on.
This is all inefficient, and I would recommend that it be replaced with code that creates an animatedline with a limit of 300 points, and then each time a point comes in, uses addpoints() to add the new point to the animated line.
  6 commentaires
Walter Roberson
Walter Roberson le 30 Mai 2022
It is not good code. It would be much better to rewrite with animatedline()
dpb
dpb le 30 Mai 2022
Indeed. My first comment ended with precisely the same conclusion/recommendation.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Graphics Performance dans Help Center et File Exchange

Tags

Produits


Version

R2020b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by