Filter löschen
Filter löschen

Resize a matrix into another with different size

36 Ansichten (letzte 30 Tage)
Tiago Dias
Tiago Dias am 26 Nov. 2018
Bearbeitet: Stephen23 am 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

Akzeptierte Antwort

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

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (2)

Luna
Luna am 26 Nov. 2018
Bearbeitet: Luna am 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 Kommentar
Tiago Dias
Tiago Dias am 26 Nov. 2018
Bearbeitet: Tiago Dias am 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)

Melden Sie sich an, um zu kommentieren.


Stephen23
Stephen23 am 26 Nov. 2018
Bearbeitet: Stephen23 am 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

Kategorien

Mehr zu Matrices and Arrays finden Sie in Help Center und File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by