How to convolve two equations

11 vues (au cours des 30 derniers jours)
Asima Warner
Asima Warner le 31 Oct 2017
Commenté : Taylor Artunian le 13 Déc 2019
I am trying to convolve two functions.
f(s) = (1-4s^2)^0.5
v(s) = sinc(s/pi)-0.5(sinc(s/2*pi))^2
I followed with entering in this:
w = conv(f,v,'full');
I keep getting an error. Would anyone know how to help? I'm not sure where I am going wrong?
  6 commentaires
Walter Roberson
Walter Roberson le 31 Oct 2017
Did you create
s = tf('s')
or using
syms s
? Either way, conv() is not valid for those.
Asima Warner
Asima Warner le 31 Oct 2017
I used syms s on a previous section of this problem. I was plotting a ram-lak filter and used this code:
syms s v
f(s, v) = sinc(s./pi)-0.5*sinc(s./(2*pi))^2;
ezplot(f, [-1,1])
Would that be affecting the conv? If so, would you have any suggestions on what to do?

Connectez-vous pour commenter.

Réponse acceptée

Walter Roberson
Walter Roberson le 31 Oct 2017
conv() is for discrete convolution. The use of symbolic variables implies continuous convolution. For that, you can use the fourier equivalence, that convolution in time is equivalent to addition in frequency.
syms s t
f(s) = sqrt(1-4*s^2)
v(s) = sinc(s/pi)-0.5*(sinc(s/2*pi))^2
fv = simplify(ifourier(fourier(f,s,t)+fourier(v,s,t),t,s))
  2 commentaires
Asima Warner
Asima Warner le 31 Oct 2017
I entered what you have provided and added
imshow(fv)
to display fv, but am receiving this error
Error using imageDisplayValidateParams Expected input number 1, I, to be one of these types:
numeric, logical
Instead its type was sym.
Error in images.internal.imageDisplayValidateParams (line 11) validateattributes(common_args.CData, {'numeric','logical'},...
Error in images.internal.imageDisplayParseInputs (line 78) common_args = images.internal.imageDisplayValidateParams(common_args);
Error in imshow (line 241) images.internal.imageDisplayParseInputs({'Parent','Border','Reduce'},preparsed_varargin{:});
Error in CT_ComputerProject_Week8 (line 62) imshow(fv)
Am I interpreting your code incorrectly? fv is the convolution between f(s) and v(s) and should be able to be displayed via imshow.
Taylor Artunian
Taylor Artunian le 13 Déc 2019
Convolution in time domain is equivalent to multiplication in frequency.

Connectez-vous pour commenter.

Plus de réponses (0)

Community Treasure Hunt

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

Start Hunting!

Translated by