How to plot a curved signal ?

Can anybody tell me how can I plot a signal like that one represented in the figure below ? I just need the part of the signal from 10 to 15. I have the following code until now :
time = 0:0.1:15;
xArray = zeros(1,numel(time)); %numel gives the number of the elements that an array has
for index = 1:numel(time)
if(time(index)>5 && time(index)<7)
xArray(index) = (time(index)-5)/2;
elseif(time(index))>= 7 && (time(index))<10
xArray(index) = 1;
elseif ((time(index) >= 10 && time(index)<15))
xArray(index) = (15 - time(index))/5;
end
end
figure (2)
plot(time,xArray);
axis([0 15 0 5]);

 Respuesta aceptada

Image Analyst
Image Analyst el 15 de Oct. de 2018

1 voto

Try this:
numPoints = 1000;
times = linspace(0, 15, numPoints);
xArray = zeros(1,numel(times)); % numel gives the number of the elements that an array has
for index = 1 : numel(times)
if times(index) > 5 && times(index) < 7
xArray(index) = (times(index)-5)/2;
elseif times(index) >= 7 && times(index) < 10
xArray(index) = 1;
elseif ((times(index) >= 10 && times(index)<15))
a = 0.7; % Smaller for flatter, larger for steeper
xArray(index) = exp(-a * (times(index) - 10));
end
end
plot(times, xArray, 'b-', 'LineWidth', 2);
xlim([0, 15]);
ylim([0, 2]);
ax = gca;
ax.YTick = [0 1];
ax.XTick = [5 7 10 15];
ax.FontSize = 15;
grid on;
xlabel('f[Hz]', 'FontSize', 15);
ylabel('x', 'FontSize', 15);
title('xArray vs. Time', 'FontSize', 15);

1 comentario

Biro Darius
Biro Darius el 16 de Oct. de 2018
Thank you very much. I'm new in MATLAB and I'm still learning things. Thanks.

Iniciar sesión para comentar.

Más respuestas (2)

Akira Agata
Akira Agata el 15 de Oct. de 2018

0 votos

How about the following?
figure
plot(time,xArray)
ax = gca;
ax.YTick = [0 1];
ax.XTick = [5 7 10 15];
Biro Darius
Biro Darius el 18 de Oct. de 2018

0 votos

I've came back with another question related to this subject. Now I have to build a signal such that it's spectrum looks like that one represented in the picture attached above. I mean I must have a signal and if I want to obtain the spectrum of my signal, his spectrum should looks like that one in the picture. I hope I was pretty clear. Thanks.

3 comentarios

Image Analyst
Image Analyst el 18 de Oct. de 2018
Call ifft() on the signal.
Biro Darius
Biro Darius el 25 de Oct. de 2018
Hi, I've tried before but it's not what I needed. My teacher suggested that I should build a sum of sinusoids for each part of the figure ( a sum of sinusoids from 5 to 7, another sum from 7 to 10 and the last sum from 10 to 15). He also suggested to use some iterations for frequency and amplitude. After all of this I should be able to build a unique signal consisting of the sum of the three sums of sinusoides and after I will call fft() on the final signal I should obtain a spectrum which has almost the same pattern like that one from the image. I hope I was pretty clear. Thanks.
Image Analyst
Image Analyst el 25 de Oct. de 2018
Yes, he wants you to do it "manually" instead of having the ifft() function do it for you.

Iniciar sesión para comentar.

Categorías

Más información sobre Data Distribution Plots en Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 15 de Oct. de 2018

Comentada:

el 25 de Oct. de 2018

Community Treasure Hunt

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

Start Hunting!

Translated by