2016-05-13 5 views
2

Wie vektorisiert dieser Code in MATLAB? Wenn möglich, möchte ich die Matrix B eine spärliche Matrix sein.Vektorisierungscode in MATLAB

%% Y is a matrix l*n 
%% X is a matrix k*n 
B = []; 
for i=1:l 
    for j=1:n 
     temp1 = zeros(1,n*l); 
     temp1((i-1)*n+j) = -1; 
     temp2 = zeros(1,l*k); 
     temp2((i-1)*k+1:i*k) = (-Y(i,j)).*(X(:,j)'); 
     B = [B;[temp1,temp2]]; 
    end 
end 

Ich weiß nicht, wie man diesen Code vektorisiert, bitte helfen! Vielen Dank!

+0

Sie eine Matrix erstellen, die 'l * n * (n * l + l * k) 'Elemente lang ... wolltest du das machen? – gariepy

+0

Ich möchte eine lineare Programmierung lösen. Matrix "B" repräsentiert lineare Beschränkungen. –

+0

@ZAlex Hat die veröffentlichte Lösung für Sie funktioniert? – Divakar

Antwort

0

Verwendung von bsxfun zur Maskierung und vektorisiert Berechnungen der elements Multiplikationen zu machen, ist hier ein vektorisiert Ansatz -

%// Create left part of the output that is basically an identity matrix 
parte1 = -eye(n*l); 

%// Setup right part of output 
parte2 = zeros(n*l,l*k); 

%// Mask to set elements from the calculations of (-Y(i,j)).*(X(:,j)') 
M = bsxfun(@eq,reshape(repmat(1:l,n,1),[],1),reshape(repmat(1:l,k,1),1,[])); 
%// OR concisely : M = kron(eye(l),ones(n,k))==1 

%// Perform vectorized calculations of (-Y(i,j)).*(X(:,j)') and set those 
%// into second part at masked places 
parte2(M) = -bsxfun(@times,permute(X,[2,1,3]),permute(Y,[2,3,1])); 

%// Finally concatenate those parts for final output 
out = [parte1,parte2]; 
+0

vielen Dank –

+0

@ZAlex So, hat es funktioniert oder hast du Speicherprobleme ? – Divakar

+0

Ich weiß nicht ... weil das Speicherlimit überschreitet ... –