Error when using logical indexing to get a value from a table
31 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Robert Demyanovich
el 14 de Feb. de 2026 a las 18:06
Comentada: Robert Demyanovich
el 15 de Feb. de 2026 a las 18:59
I have the following snippet of code, which I created based on online tutorial:
theta = pi/4
%Create the table
Angles = {pi/2;pi/3;pi/4;pi/6;pi/12};
wValues = {0;0.8846;1.318;1.973;3.782};
%Create a table of w values at specific angles
T = table(Angles,wValues);
%Read the value of w from the table
logical_index = T.Angles == theta;
w = T.wValues(logical_index);
I keep getting the following error on the line:
logical_index = T.Angles == theta;
Operator '==' is not supported for operands of type 'cell'.
I don't understand why this is happening since I am following a code example.
0 comentarios
Respuesta aceptada
Stephen23
el 14 de Feb. de 2026 a las 18:18
Editada: Stephen23
el 14 de Feb. de 2026 a las 20:19
"Operator '==' is not supported for operands of type 'cell'."
Why are you using a cell array to store scalar numeric data?
"I don't understand why this is happening since I am following a code example."
Cell arrays are not defined for logical operations like EQ. Use numeric vectors instead:
theta = pi/3;
Angles = [pi/2;pi/3;pi/4;pi/6;pi/12]; % numeric vector, NOT a cell array!
wValues = [0;0.8846;1.318;1.973;3.782]; % numeric vector, NOT a cell array!
T = table(Angles,wValues);
logical_index = T.Angles == theta;
w = T.wValues(logical_index)
3 comentarios
Steven Lord
hace 42 minutos
A cell array is a data type that can store different types and sizes together in one array. This flexibility (you can store anything in it) comes with some cost (you can store anything in it, so certain operations don't make sense to perform on it and aren't defined on it, and some operations have extra overhead as they check if the data in the array has certain characteristics the operation requires the data to have.)
For example, want to check the length of pieces of text in an array? If you use the strlength function on a string array, MATLAB knows (from its class) that it does contain text data rather than (say) numeric data.
S = "abracadabra";
strlength(S)
But if you pass in a cell array, it might work or it might not, depending on whether the cell array contains text data. MATLAB has to check and throw an error if the cell doesn't have text data. Imagine you had a large cell array where only the last element was not text data; MATLAB would have to look through the whole thing before deciding "The question doesn't make sense, I'll throw an error."
C = {'abracadabra'};
strlength(C) % works
D = {42};
strlength(D) % errors
Trying to figure out what == equality means for a cell (which again could contain just about anything) and another piece of data would have so many edge/corner cases that I believe trying to explain it would just confuse people even more. So == isn't defined for cell arrays.
Más respuestas (1)
Walter Roberson
hace alrededor de 2 horas
Examine the table that gets created:
%Create the table
Angles = {pi/2;pi/3;pi/4;pi/6;pi/12};
wValues = {0;0.8846;1.318;1.973;3.782};
%Create a table of w values at specific angles
T = table(Angles,wValues)
Notice that it is a 5 x 2 table, with the entries being cell arrays. Those cell array entries cannot be compared to numeric values.
There is a connection between cell arrays and tables, but it has to do with appending data to tables.
T1 = table((1:5).', (101:105).')
data_to_add = [Angles,wValues]
T1(end+1:end+5,:) = data_to_add
So, an existing table can be extended by assigning a cell array.
Or you can
T2 = cell2table(data_to_add)
Ver también
Categorías
Más información sobre Data Type Identification 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!