Dynamic vectors into cell

1 visualizzazione (ultimi 30 giorni)
Juan Medved
Juan Medved il 31 Lug 2020
Commentato: Juan Medved il 1 Ago 2020
Hi!
I have 3 vectors (here A,B and C) that could have diferent size (are dynamics, size is not define) and i need to make a cell like "MyCorrectData" where the last column ist logical.
A=[1 1 1]
B=[2 2 2]
C=logical([1 0 1])
MyCorrectData={1 2 true; 1 2 false; 1 2 true}; %this is what i want
This works almost fine, but the last column lost the type and convert in double
A=[1 1 1]
B=[2 2 2]
C=logical([1 0 1])
MyCorrectData={1 2 true; 1 2 false; 1 2 true}; %this is what i want
MyData=[A B C]
MyData=num2cell(MyData)
How can i solve this?
Thanks!
  3 Commenti
Juan Medved
Juan Medved il 31 Lug 2020
Thanks for the answer!!
And how can i manage a table(from the GUI) with 2 columns of numbers and 1 column of logical data?
dpb
dpb il 31 Lug 2020
Modificato: dpb il 31 Lug 2020
Columns of tables can be of differing types...you just store what you want.
Never used the uitable in anger, dunno if it will allow cell input by table cell to mix random types or not. The table class must be the same type for the column if not a cell but will allow a cell so can mix. Generally if do so it gets much more difficult to write generic code, however, as then have to handle the cells differently depending upon content.

Accedi per commentare.

Risposta accettata

Stephen23
Stephen23 il 31 Lug 2020
Modificato: Stephen23 il 31 Lug 2020
It is very easy to get what you want, you just need to avoid concatenating all of the numeric/logical data together, e.g.:
>> D = [num2cell(A(:)),num2cell(B(:)),num2cell(C(:))]
D =
[1] [2] [1]
[1] [2] [0]
[1] [2] [1]
And checking:
>> MyCorrectData={1 2 true; 1 2 false; 1 2 true}; %this is what i want
>> isequal(D,MyCorrectData)
ans =
1
For an arbitrary number of arrays just put them into the cell array first, e.g.:
>> D = {A,B,C}; % any number of suitably-sized arrays.
>> D = cellfun(@(a)num2cell(a(:)),D,'uni',0);
>> D = [D{:}] % horzcat
D =
[1] [2] [1]
[1] [2] [0]
[1] [2] [1]

Più risposte (0)

Categorie

Scopri di più su Data Type Identification in Help Center e File Exchange

Prodotti


Release

R2015b

Community Treasure Hunt

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

Start Hunting!

Translated by