Avoide imaginary part in cell matrix

1 visualización (últimos 30 días)
EldaEbrithil
EldaEbrithil el 13 de Oct. de 2020
Comentada: Ameer Hamza el 14 de Oct. de 2020
Hi all
i have a cell matrix A like that:
val(:,:,1,1,1) =
Columns 1 through 10
{n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double}
Columns 11 through 20
{n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double} {n×2 double}........
i want to obtain another cell matrix with the same global dimension of the previous one but with only the first column values: so i want to obtain a matrix where each cell has dimension equal to {nx1} . I also want to estrapolate from A only those cells that contain elements with imaginary part less than 0.1 setting to zero all the cells that don't satisfy this condition. Is there an easy way for doing that?
Thank you for the help
Regards

Respuesta aceptada

Ameer Hamza
Ameer Hamza el 13 de Oct. de 2020
Editada: Ameer Hamza el 13 de Oct. de 2020
Here is the solution to the first part
A; % 1x20 cell array
A_new = cellfun(@(x) {x(:,1)}, A);
All cell in A_new will contain first column of matrices in A.
I didn't understand the 2nd question related to setting the imaginary part to zero.
  7 comentarios
EldaEbrithil
EldaEbrithil el 13 de Oct. de 2020
The first and the second column contain complex values. I would like to perform the following operations in order:
  • stay with one column instead of two
  • take those cells (made up of only one column each) that respect that condition on the imaginary part
Ameer Hamza
Ameer Hamza el 14 de Oct. de 2020
Ok. Following should work in this case
A; % 1x20 cell array
A_new1 = cellfun(@(x) {x(:,1)}, A); % only contain 1st columns
A_new2 = cellfun(@(x) {x.*(imag(x)<0.1)}, A_new1); % set the rows which does not satisfy the imaginary number conditions to 0.

Iniciar sesión para comentar.

Más respuestas (0)

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