How can I implement these for loops efficiently using covolution?

조회 수: 1 (최근 30일)
MAWE
MAWE 2023년 8월 1일
편집: Bruno Luong 2023년 8월 25일
I have this code
for xx=1:length(x)
for kk=1:length(x)
xSinc(xx) = xSinc(xx)+x(kk)*sinc(xx-kk-delta/T);
end
end
How can implement this efficiently using convultion in MATLAB?
  댓글 수: 1
Torsten
Torsten 2023년 8월 1일
If you don't know how to spell the method, you'd better stick to your loop solution.

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

채택된 답변

Dyuman Joshi
Dyuman Joshi 2023년 8월 1일
편집: Dyuman Joshi 2023년 8월 1일
Simple multiplication would be good enough -
xx = 1:length(x);
kk = 1:length(x);
xSinc(xx) = xSinc(xx) + x(kk)*sinc(xx-kk'-delta/T);
  댓글 수: 5
Dyuman Joshi
Dyuman Joshi 2023년 8월 22일
Please attach your code, so that I can reproduce the error and suggest solutions to tackle the issue.
MAWE
MAWE 2023년 8월 23일
OK, it is working. I just needed to transpose one vector. Here another problem I have, the second vector depends on the first as
for xx = 1:length(x)
for kk=max(xx-L,1):min(xx+L,length(x))
xSinc(xx) = xSinc(xx)+x(kk)*sinc(xx-kk-delta/T);
end
end
Currently I am doing this
for xx = 1:length(x)
kk=max(xx-L,1):min(xx+L,length(x))
xSinc(xx) = xSinc(xx)+x(kk)*sinc(xx-kk'-delta/T);
end
Is it possible to write this for loop in vector form for efficient implementtaion?

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

추가 답변 (1개)

Bruno Luong
Bruno Luong 2023년 8월 23일
편집: Bruno Luong 2023년 8월 25일
Use conv
x = (0:0.2:5).^2;
L = 3;
delta = rand; T = rand;
% Your method
xSinc = zeros(size(x));
for xx = 1:length(x)
for kk=max(xx-L,1):min(xx+L,length(x))
xSinc(xx) = xSinc(xx)+x(kk)*sinc(xx-kk-delta/T);
end
end
xSinc
xSinc = 1×26
-0.0051 -0.0070 0.0352 0.1578 0.3593 0.6413 1.0038 1.4468 1.9704 2.5745 3.2591 4.0243 4.8700 5.7962 6.8029 7.8902 9.0580 10.3063 11.6351 13.0445 14.5344 16.1048 17.7558 20.0963 21.1378 24.2622
% conv method
xSinc2 = conv(x, sinc((L:-1:-L)+delta/T), 'same')
xSinc2 = 1×26
-0.0051 -0.0070 0.0352 0.1578 0.3593 0.6413 1.0038 1.4468 1.9704 2.5745 3.2591 4.0243 4.8700 5.7962 6.8029 7.8902 9.0580 10.3063 11.6351 13.0445 14.5344 16.1048 17.7558 20.0963 21.1378 24.2622
norm(xSinc2-xSinc)
ans = 5.7220e-15
plot(xSinc, 'b')
hold on;
plot(xSinc2, 'r.')
  댓글 수: 3
MAWE
MAWE 2023년 8월 23일
Can I ask about the undelying logic you used? Why for exampled you defined
kk = -L:L;
and then fliped the order in
K = flip(sinc(kk+delta/T));
Bruno Luong
Bruno Luong 2023년 8월 23일
편집: Bruno Luong 2023년 8월 25일
I can't explain more than it comes from definition of conv adapted to your code.
Have you tried to do some study of the code or you just ask without study conv?

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

카테고리

Help CenterFile Exchange에서 Loops and Conditional Statements에 대해 자세히 알아보기

제품


릴리스

R2019b

Community Treasure Hunt

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

Start Hunting!

Translated by