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
parforit 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 ofiorjto 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
D1used as reduction variable.