The following MATLAB code loops through all elements of a matrix with size 2IJ x 2IJ.
for i=1:(I-2)
for j=1:(J-2)
ij1 = i*J+j+1; % row
ij2 = i*J+j+1 + I*J; % col
D1(ij1,ij1) = 2;
D1(ij1,ij2) = -1;
end
end
Is there any way I can parallelize it use MATLAB's parfor command? You can assume any element not defined is 0. So this matrix ends up being sparse (mostly 0s).
Before using
parfor
it is recommended to read the guidelines related to decide when to use parfor. Specially this:Here vectorization can be used effectively to compute indices of the nonzero elements. Those indices are used in function
sparse
. For it you need to define one ofi
orj
to be a column vector and another a row vector. Implicit expansion takes effect and indices are computed.However for the comparison this can be a way of using
parfor
(not tested):Here
D1
used as reduction variable.