Compute convolution y[n]=x[n]*h[n]: x[n]={2,0,1,-1,3}; h[n]={1,2,0,1}

조회 수: 61 (최근 30일)
Li Hui Chew
Li Hui Chew 2021년 6월 24일
편집: Paul 2023년 12월 3일
My approach:
x=[2 0 1 -1 3];
h=[1 2 0 1];
% therefore
y=conv(x,h)
y =
2 4 1 3 1 7 -1 3
  댓글 수: 4
Walter Roberson
Walter Roberson 2023년 12월 2일
It would depend on whether that u[n-1] is the unit step function or not.
If it is then x[n] would be 0 for n < 0, and 1 for n >= 0 -- an infinite stream of 1's. And h[n] would be 0 for n <= 1, and 0.9^n for n > 1 -- an infinite stream of non-negative numbers. You cannot express that as a finite convolution sequence.
Let us see what it would turn out like for continuous functions:
sympref('heavisideatorigin', 1)
ans = 
1
syms n integer
x(n) = heaviside(n)
x(n) = 
h(n) = (sym(9)/sym(10))^n * heaviside(n-1)
h(n) = 
syms t tau
C(t) = int(x(tau) * h(t-tau), tau, 0, t)
C(t) = 
[C(-1), C(0), C(1)]
ans = 
assume(sign(t-1) == 1)
simplify(C)
ans(t) = 
Paul
Paul 2023년 12월 2일
편집: Paul 2023년 12월 3일
The follow-up problem posed by James can be solved for a closed form solution using symsum and the shift property of the convolution sum. Seem like a HW problem so won't show it now.

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

답변 (1개)

Image Analyst
Image Analyst 2023년 12월 2일
@Li Hui Chew, yes your approach is correct. Is that all you wanted - confirmation of your approach?

카테고리

Help CenterFile Exchange에서 Calculus에 대해 자세히 알아보기

태그

제품


릴리스

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by