Error when using logical indexing to get a value from a table
30 views (last 30 days)
Show older comments
Robert Demyanovich
on 14 Feb 2026 at 18:06
Commented: Robert Demyanovich
about 3 hours ago
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 Comments
Accepted Answer
Stephen23
on 14 Feb 2026 at 18:18
Edited: Stephen23
about 23 hours ago
"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 Comments
Steven Lord
19 minutes ago
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.
More Answers (1)
Walter Roberson
about 1 hour ago
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)
See Also
Categories
Find more on Matrix Indexing in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!