Replace a value with matrix n x m

3 次查看(过去 30 天)
Hii.... I want to ask how to replace a value with a matrix n x m. Ex: a = (perms[2])', if a(1)=1, replace a(1)with [1 1;1 1], if a(1)=2, replace it with [2 2;2 2].
Thank you
Muammar

采纳的回答

Walter Roberson
Walter Roberson 2011-12-5
You cannot replace a scalar element of a numeric matrix with a non-scalar.
What you could do is
a = num2cell((perms[2])');
Then
a{1} = a{1} * ones(2,2);
Notice the curly-bracket indexing rather than round-bracket indexing.
  7 个评论
Walter Roberson
Walter Roberson 2011-12-5
Your comment about permutations would seem to indicate that you want to get out the matrix
[[1 1;1 1],[2 2;2 2]; [2 2;2 2], [1 1; 1 1]]
which would be
[1 1 2 2; 1 1 2 2; 2 2 1 1; 2 2 1 1]
which would be a 4 x 4 matrix, not a 1 x 2 matrix.
My *guess* is that what you really are looking for is ndgrid:
[P,Q] = ndgrid(numel(data), numel(data));
P = P(:);
Q = Q(:);
Then permutation #K would be
[data(P(K)), data(Q(K))]
so the n x 2 matrix formed by [P,Q] would be pairwise indices in to the data:
PQ = [P,Q];
the K'th row of which would be used to fetch the K'th permutation:
data(PQ(K,:))
Muammar
Muammar 2011-12-5
I will try this one, actually what i need is similar to your first answer,"a{1} = a{1} * ones(2,2);", but i cant make it a numerical values. But, thank you..

请先登录,再进行评论。

更多回答(2 个)

Sean de Wolski
Sean de Wolski 2011-12-5
Maybe:
data1 = ones(2);
data2 = magic(2);
D = [data1;data2];
D2 = reshape(flipdim(reshape(D',size(data1,1),size(data1,2),[]),3),size(D))
?
  9 个评论
Muammar
Muammar 2011-12-5
All.. I am sorry if its not clear
Muammar
Muammar 2011-12-5
it should be 2 x 2 matrix

请先登录,再进行评论。


Image Analyst
Image Analyst 2011-12-5
I agree with the others - unclear. Perhaps you mean this:
m = randi(9, [1 4]) % Sample row vector with random integers
m2 = imresize(m, 2, 'nearest') % Do the replication.
Results:
m =
7 8 2 5
m2 =
7 7 8 8 2 2 5 5
7 7 8 8 2 2 5 5
So maybe you can just simply use imresize to get what you want.

类别

Help CenterFile Exchange 中查找有关 Logical 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by