How do I replace "for" loops by matrix multiplication? I am getting confused because of 4 "for" loops. Any suggestions?

Hello, the code is as follows.
value = zeros();
E2 = zeros();
dxdy = 1;
x1=1;y1=1;u1=1;v1=1;
for u = -1:1:1
for v = -1:1:1
for x = -1:1:1
for y = -1:1:1
value(x1,y1) = input_data(x1,y1)*exp( ( -1i*k*(((u-x)^2) + (v-y)^2)) / (2*0.2))*(dxdy);
y1 = y1+1;
end
x1 = x1+1;
y1 = 1;
end
S_rows = sum(value,2); %Adding components of matrix "value"
S_complete = sum(S_rows);
E2(u1,v1) = S_complete;
x1 = 1;
v1 = v1 + 1;
end
u1 = u1+1;
v1 = 1;
end
disp(E2)

4 Kommentare

input_data = [1 2 3 ; 4 5 6 ; 7 8 9]
"input_data" must be 27x3, not 3x3.
If you see the program the values of u1 and v1 is reset everytime. Hence the input is 3*3. And the output is also 3*3

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Miriam
Miriam am 12 Okt. 2018
Bearbeitet: Miriam am 12 Okt. 2018
dxdy = 1;
[x,y,u,v] = ndgrid(-1:1);
value = input_data.*exp((-1i*k*(((u-x).^2) + (v-y).^2))/(2*0.2))*(dxdy);
S_rows = sum(value,2);
S_complete = sum(S_rows);
E2 = squeeze(S_complete);
disp(E2)

8 Kommentare

Thanks a lot for your answer. However when I use the code it throws an error saying : Any insights? Thank you
Error using -
Matrix dimensions must agree.
What is k in your code? I assumed it was scalar and just used 1.
k is a scalar quantity. However the input data is 3*3 matrix. Hence now I am getting the error :
Error using .*
Matrix dimensions must agree.
Do you get the same error with the following command?
[1 2].*[3 4;5 6]
This causes no issues with my version of MATLAB.
Yes, i get the same error using [1 2].*[3 4;5 6].
Odd there are no issues on my end. Perhaps try this instead:
value = repmat(input_data,1,1,3,3).*exp((-1i*k*(((u-x).^2) + (v-y).^2))/(2*0.2))*(dxdy);
Now I don't get any error but the answer doesn't matches for both the codes.
I'm not sure what to tell you then. It works fine for me.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Loops and Conditional Statements finden Sie in Hilfe-Center und File Exchange

Gefragt:

am 11 Okt. 2018

Kommentiert:

am 12 Okt. 2018

Community Treasure Hunt

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

Start Hunting!

Translated by