Hey guys, thanks in advance for reading this
I have this code, that finds in surv_matrix the indixes where the matrix is different from zero. but for each one of them indices, I want to create a plot, like that, and see one plot for each indice. Is there anyway of creating a better loop, since this one only gives me the last plot. Imagining that ic=3,4,5. I want to see 3 plots, and with this code I m only seeing 1.
Thank you,
ic=find(~all(surv_matrix==0));
for idx=ic
surveillance_column=surv_matrix(:,idx)
plot(abs(freq_XQPSK),(abs(surveillance_column)),'b','linewidth',2);
continue
end

답변 (1개)

Mustafa Abu-Mallouh
Mustafa Abu-Mallouh 2022년 5월 24일
편집: Mustafa Abu-Mallouh 2022년 5월 24일

0 개 추천

Use the 'hold on' command after your plot command, this will put all of your plots on the same axes
hold on

댓글 수: 3

Miguel Albuquerque
Miguel Albuquerque 2022년 5월 24일
편집: Miguel Albuquerque 2022년 5월 24일
I still have only one plot, with that
You should remove the color designation or at least have different designations for each iteration or else your plots will be the same color.
You also do not need the continue command, the for loop will automatically continue to the next value when it reaches the end of the iteration.
I'm not sure where you put the hold command but I get multiple lines on a single plot with the following
% Create random data with 0's in the third column
freq_XQPSK = (1:5)';
surv_matrix = rand(5,5);
surv_matrix(:,3) = 0;
% Find nonzero columns
ic=find(~all(surv_matrix==0));
% Loop
for idx=ic
surveillance_column = surv_matrix( : , idx );
figure(1) % I always designate a figure, especially when using hold commands
plot( abs(freq_XQPSK) , abs(surveillance_column) , 'LineWidth' , 2 ); hold on
end
Alright im doing this:
In the case of my example, ic= 197,198,199,200,201,202,203 . But with this code im only seeing the last plot of ic=203, Is there anyway I could see all the 7 plots, without doing it mannually, which means, replacing ic myself.
ic=find(~all(surv_matrix==0));
for idx=ic
surveillance_column=surv_matrix(:,idx);
figure(1);
plot(abs(freq_XQPSK),(abs(surveillance_column)),'b','linewidth',2); hold on
end

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 MATLAB에 대해 자세히 알아보기

제품

릴리스

R2021b

질문:

2022년 5월 24일

댓글:

2022년 5월 24일

Community Treasure Hunt

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

Start Hunting!

Translated by