Borrar filtros
Borrar filtros

Combining sub-matrices diagonally within a for loop

1 visualización (últimos 30 días)
Rengin
Rengin el 13 de Ag. de 2019
Comentada: Rengin el 13 de Ag. de 2019
clear all;
clc;
close all;
n=[3 1 2];
for kk=1:length(n)
matrix=zeros(n(kk),n(kk));
for ii=1:n(kk)
for jj=1:n(kk)
val=2*ii+jj;
matrix(ii,jj)=val;
end
end
end
% Dear users, if you put a debug at the very last "end" (row 13), you can
% see that I aim to generate 3 sub-matrices having the size of 3x3, 1x1 and
% 2x2 (see n=[3 1 2]). I want to combine each sub-matrix one each other diagonally.
% I want to get the matrix as a result below:
matrix=[3 4 5 0 0 0;5 6 7 0 0 0;7 8 9 0 0 0;0 0 0 3 0 0;0 0 0 0 3 4;0 0 0 0 5 6];
%Is there any simple way to do it?
%Thanks in advance!

Respuesta aceptada

Bruno Luong
Bruno Luong el 13 de Ag. de 2019
submats = arrayfun(@(n) 2*(1:n)'+(1:n),[3 1 2],'unif',0)
matrix = blkdiag(submats{:})
  4 comentarios
Rengin
Rengin el 13 de Ag. de 2019
I would really appreciate if you can look at my similar question on https://www.mathworks.com/matlabcentral/answers/475992-combination-of-sub-matrices-generated-within-a-for-loop? Your suggestion is cool, I really like to apply it!
Bruno Luong
Bruno Luong el 13 de Ag. de 2019
I actually wait to see what do you learn and how you manage to adatp the above code to this tiny change.

Iniciar sesión para comentar.

Más respuestas (1)

Rengin
Rengin el 13 de Ag. de 2019
I actually tried the combination of submats = arrayfun(@(n) rad(1:n)*h(1:n),n,'unif',0) but it didn't work.
  2 comentarios
Bruno Luong
Bruno Luong el 13 de Ag. de 2019
Editada: Bruno Luong el 13 de Ag. de 2019
n=[3 1 2];
rad=[0.04 0.02 0.01];
h=[10 12 15];
submats = arrayfun(@(n,r,h) r*h*ones(n),n,rad,h,'unif',0);
...
Rengin
Rengin el 13 de Ag. de 2019
Now I understand better! Thanks a lot

Iniciar sesión para comentar.

Categorías

Más información sobre Creating and Concatenating Matrices en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by