anyway to cat specific column using horzcat?

1 visualización (últimos 30 días)
Yu Li
Yu Li el 2 de Sept. de 2019
Comentada: Walter Roberson el 2 de Sept. de 2019
Hi:
I have a cell array, the size is not determined, but each array is a 1000*3 matrix.
I want to merge the 3rd column of each array into a new matrix, is there anyway to do it?
below are what I have tried:
A{1}=rand(1000,3);
A{2}=rand(1000,3);
A{3}=rand(1000,3);
result= horzcat(A{:}(:,3))
or result= [A{:}(:,3)];
but Matlab reported error: Expected one output from a curly brace or dot indexing expression, but there were 3 results.
Thanks!
Yu
  1 comentario
Rik
Rik el 2 de Sept. de 2019
As far as I'm aware, there is currently no way to do this directly in Matlab.
What you could do in this specific case is to cat A to the third dimension, and then select your data from the 3D array.

Iniciar sesión para comentar.

Respuesta aceptada

Walter Roberson
Walter Roberson el 2 de Sept. de 2019
res = cell2mat(cellfun(@(x) x(:,3), A, 'uniform', 0));
  4 comentarios
Guillaume
Guillaume el 2 de Sept. de 2019
your answer works
As I commented in dpb's answer, only if the cell array is a row vector.
Walter Roberson
Walter Roberson el 2 de Sept. de 2019
res = cell2mat(cellfun(@(x) x(:,3), A(:).', 'uniform', 0));
This will work even with cell arrays that are column vectors.

Iniciar sesión para comentar.

Más respuestas (1)

Guillaume
Guillaume el 2 de Sept. de 2019
As others have said, no you can't do that with a single statement.
Assuming a cell array of any shape and size, rik's suggestion is probably the shortest to write:
result = cat(3, yourcellarray{:});
result = squeeze(result(:, 3, :));
The other option is cellfun indeed but without cell2mat if the cell array is not a row vector:
result = cellfun(@(m) m(:, 3), 'UniformOutput', false);
result = [result{:}];

Categorías

Más información sobre Creating and Concatenating Matrices 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!

Translated by