speed up 'for' loops
1 visualización (últimos 30 días)
Mostrar comentarios más antiguos
Hi,
How can I speed up following 'for' loops? Help me please.
P=200;
N=40000000;
y(1:P)=3;
% a: P X 1 matrix (vector)
% Z: P X 1 matrix (vector)
% x: N X 1 matrix (vector)
%%%%%Loops
y(P+1:N)=0;
for i=P+1:N
for j=1:P
y(i)=y(i)-a(j)*x(i-j);
end
end
for i=1:N
for j=1:P
f(i,j)=Z(j)^(i-1);
end
end
Thanks in advance.
0 comentarios
Respuesta aceptada
Jan
el 7 de Sept. de 2012
Editada: Jan
el 7 de Sept. de 2012
P = 200;
N = 40000000;
a = rand(P, 1);
Z = rand(P, 1);
x = rand(N, 1);
y(P+1:N) = 0; % This one at first! -> pre-allocation
y(1:P) = 3;
at = transpose(a);
for i=P+1:N
y(i) = y(i) - at * x(i-1:-1:i-P); % Dot-product of vectors => SUM
end
f = ones(P, N);
for i = 2:N
f(:, i) = f(:, i - 1) .* Z;
end
f = transpose(f);
5 comentarios
Más respuestas (1)
Azzi Abdelmalek
el 7 de Sept. de 2012
for the second loop
c=repmat(Z',N,1)
f=bsxfun(@power,c,[0:N-1]')
4 comentarios
Matt Fig
el 7 de Sept. de 2012
No need for REPMAT or [].
f = bsxfun(@power,Z.',(0:N-1).');
Ver también
Categorías
Más información sobre Loops and Conditional Statements en Help Center y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!