Effacer les filtres
Effacer les filtres

How do I add a for loop to do subplots

37 vues (au cours des 30 derniers jours)
Dalton Houghton-Schaffer
Dalton Houghton-Schaffer le 20 Fév 2020
Modifié(e) : Adam Danz le 21 Fév 2020
Create a subplot with two graphs subplot(2,1,x). The top plot will be your summed sinusoids and the bottom will show all the sinusoids used to create the final sinusoid. To do this, use the for loop to create a matrix that contains three vectors, one for each of the base sinusoids. Then use one command (outside your function) to plot all three together on the bottom subplot.
My code is below but I am unsure how or where to add a for loop to execute this. My thought was to store the "x" value and then plot it.
function [xx,tt] = syn_sin(fk,xk,fs,dur,tstart)
if nargin <5, tstart=0, end
if length (xk)~= length(fk)
error ('error', 'fk~=xk');
end
t= tstart: 1/(fs):dur;
x=xk(1)* exp(2*j*pi*fk(1)*t);
for k=2:length(fk);
x=xk(k) *exp(2*j*pi*fk(k)*t) +x;
end
plot(t,x),grid on

Réponse acceptée

Adam Danz
Adam Danz le 20 Fév 2020
Modifié(e) : Adam Danz le 20 Fév 2020
The general template to build subplots within a loop
nrows = 2; % number of subplot rows
ncols = 1; % number of subplot columns
nsubs = nrows * ncols; % total number of subplots
for i = 1:nsubs
subplot(nrows, ncols, i)
plot(. . .)
end
For r2019b or later, you can used tiledlayout
nrows = 2; % number of subplot rows
ncols = 1; % number of subplot columns
nsubs = nrows * ncols; % total number of subplots
tiledlayout(nrows, ncols)
for i = 1:nsubs
nexttile()
plot(. . .)
end
Let me know if there are any questions | problems.
  3 commentaires
Adam Danz
Adam Danz le 21 Fév 2020
Modifié(e) : Adam Danz le 21 Fév 2020
My bet is that the variable j was not assigned a value. By default, j is an imaginary unit.
Dalton Houghton-Schaffer
Dalton Houghton-Schaffer le 21 Fév 2020
Thank you so much!!! Yes I always forget to reassign j for i.

Connectez-vous pour commenter.

Plus de réponses (0)

Produits


Version

R2019b

Community Treasure Hunt

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

Start Hunting!

Translated by