Resize a matrix into another with different size

38 vues (au cours des 30 derniers jours)
Tiago Dias
Tiago Dias le 26 Nov 2018
Modifié(e) : Stephen23 le 26 Nov 2018
Hello, i got a matrix X and I want to transform X into a matrix rows x collumns, in this case into a 4 by 7 matrix. I used reshape but it doesnt work because of the 2 nans i must create i assume.
k = 26;
X = [1:k]';
[n,m] = size(X);
rows = 4;
columns = ceil(n/rows);
Into something like that, if possible:
x(1) x(5) x(9) x(13) x(17) x(21) x(25)
x(2) x(6) x(10) x(14) x(18) x(22) x(26)
x(3) x(7) x(11) x(15) x(19) x(23) NaN
x(4) x(8) x(12) x(16) x(20) x(24) NaN

Réponse acceptée

Matt J
Matt J le 26 Nov 2018
Modifié(e) : Matt J le 26 Nov 2018
extra = rows*ceil(numel(X)/rows) - numel(X);
reshape([X(:);nan(extra,1)],rows,columns)
  3 commentaires
Stephen23
Stephen23 le 26 Nov 2018
([X(:);nan(extra,1)]
^ needs a semicolon here!
Tiago Dias
Tiago Dias le 26 Nov 2018
Thanks for your help!

Connectez-vous pour commenter.

Plus de réponses (2)

Luna
Luna le 26 Nov 2018
Modifié(e) : Luna le 26 Nov 2018
Hi,
Try this:
k = 26;
X = [1:k]';
[n,m] = size(X);
rows = 4;
columns = ceil(n/rows);
X(numel(X):(rows*columns)) = NaN;
reshape(X,rows,columns)
  1 commentaire
Tiago Dias
Tiago Dias le 26 Nov 2018
Modifié(e) : Tiago Dias le 26 Nov 2018
this one works 95% i would say, the number 26 doesnt show up :/
ans =
1 5 9 13 17 21 25
2 6 10 14 18 22 NaN
3 7 11 15 19 23 NaN
4 8 12 16 20 24 NaN
I tried this and i think it works
extra_row = rows * columns;
X(n+1:extra_row) = NaN;
X_new = reshape(X,rows,columns)

Connectez-vous pour commenter.


Stephen23
Stephen23 le 26 Nov 2018
Modifié(e) : Stephen23 le 26 Nov 2018
A simpler solution:
>> X = 1:26;
>> R = 4;
>> N = numel(X);
>> M = nan(R,ceil(N/R));
>> M(1:N) = X
M =
1 5 9 13 17 21 25
2 6 10 14 18 22 26
3 7 11 15 19 23 NaN
4 8 12 16 20 24 NaN

Catégories

En savoir plus sur Matrices and Arrays dans Help Center et File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by