How can I create a set of N diagnal matrices range from diag(1, 1, ... , 1) to diag(-1, -1, ... , -1) for testing purposes?
1 visualización (últimos 30 días)
Mostrar comentarios más antiguos
Zac Minson
el 20 de Sept. de 2021
I am needing to create 16 4x4 diagnal matrices consisting of all of the combinations of "1" and "-1" and have them be able to be called for use in a loop. Besides creating each individual matrix, how can I go about accomplishing this?
for instance:
Z1 = diag(1,1,1,1);
.
Z8 = diag(1,-1,-1,1);
.
Z16 = diag(-1,-1,-1,-1);
Thank you for any guidance.
3 comentarios
Stephen23
el 21 de Sept. de 2021
@Zac Minson: using a cell array is a very general method, which works for any number of matrices.
Respuesta aceptada
Matt J
el 20 de Sept. de 2021
Editada: Matt J
el 21 de Sept. de 2021
Do you really need all Z{i} at the same time?
[C{1:N}]=ndgrid([-1,1]);
C=reshape( cat(N+1,C{:}) ,[],N);
Z=zeros(N^2,2^N); %EDITED - removed loops
Z(1:N+1:N^2,:)=C;
Z=reshape(Z, N,N,[])
3 comentarios
Matt J
el 20 de Sept. de 2021
Here's a loop-free version:
N = 4; % Set this value
[C{1:N}]=ndgrid([-1,1]);
C=reshape( cat(N+1,C{:}) ,[],N).';
Z=zeros(N^2,2^N);
Z(1:N+1:N^2,:)=C;
Z=reshape(Z, N,N,[])
Más respuestas (2)
Fangjun Jiang
el 20 de Sept. de 2021
a=(dec2bin(15:-1:0)-48)*2-1;
z=zeros(4,4,16);
for k=1:16
z(:,:,k)=diag(a(k,:));
end
1 comentario
the cyclist
el 20 de Sept. de 2021
Here is a generalization of this solution:
N = 4; % Set this value
a=(dec2bin((2^N-1):-1:0)-48)*2-1;
z=zeros(N,N,2^N);
for k=1:2^N
z(:,:,k)=diag(a(k,:));
end
Jan
el 20 de Sept. de 2021
Editada: Jan
el 21 de Sept. de 2021
z = repmat(eye(4), 1, 1, 16);
z(z==1) = 1 - rem(floor((0:15) ./ [1; 2; 4; 8]), 2) * 2; % Inlined DEC2BIN
Generalized:
n = 3;
z = repmat(eye(n), 1, 1, 2^n);
z(z==1) = 1 - rem(floor((0:2^n-1) ./ pow2(0:n-1).'), 2) * 2;
Now z(:,:,i) is the i.th matrix. This is more efficient than storing them in a cell. But if you want this:
zC = num2cell(z, [1,2]);
0 comentarios
Ver también
Categorías
Más información sobre Logical en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!