Construct Power of Matrix without for loop

Hi, everyone:
Suppose I have a 2 by 2 matrix A, if I want construct a larger matrix B that is defined as:
B=[A, A^2, A^3, A^4, ... A^N];
is it possible to do it without for loop?
Thanks

 Respuesta aceptada

Azzi Abdelmalek
Azzi Abdelmalek el 11 de Ag. de 2013
Editada: Azzi Abdelmalek el 11 de Ag. de 2013
Example
A=magic(2);
N=3;
B=cell2mat(arrayfun(@(x) A^x,1:N,'un',0))

Más respuestas (2)

Jan
Jan el 12 de Ag. de 2013
Azzi's suggestion is fine for N=3. If you are talking about larger N, neither the repeated power operator nor arrayfun nor cell2mat are efficient:
N = 10000
A = rand(2, 2);
tic;
B = cell2mat(arrayfun(@(x) A^x,1:N,'un',0));
toc
tic;
B = zeros(2, 2, N);
P = 1;
for k = 1:N
P=P*A;
B(:,:,k) = P;
end
B = reshape(B, 2, N * 2);
toc
Elapsed time is 0.199776 seconds.
Elapsed time is 0.039983 seconds.
So I'd prefer the more efficient FOR loop.

2 comentarios

Andrei Bobrov
Andrei Bobrov el 12 de Ag. de 2013
+1
Azzi Abdelmalek
Azzi Abdelmalek el 12 de Ag. de 2013
Good idea to avoid repeating power operation.

Iniciar sesión para comentar.

Ming
Ming el 11 de Ag. de 2013
Editada: Ming el 11 de Ag. de 2013

0 votos

Thanks very much!
Do you know if A is a 2 by 2 by N matrix, can I use "arrayfun" or any other way to do:
B=[A(:,:,1), A(:,:,1)*A(:,:,2), A(:,:,1)*A(:,:,2)*A(:,:,3), ... , A(:,:,1)*A(:,:,2)*A(:,:,3)* ... *A(:,:,N)]
without for loop?

1 comentario

Walter Roberson
Walter Roberson el 11 de Ag. de 2013
Note: arrayfun() just hides the "for" loop. If you are willing to use it, then Azzi's example does what you ask.

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Centro de ayuda y File Exchange.

Productos

Etiquetas

Preguntada:

el 11 de Ag. de 2013

Community Treasure Hunt

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

Start Hunting!

Translated by