"Intermediate dot indexing produced a comma-separated list.." error prevents extracting values from nested indexed fields
405 ビュー (過去 30 日間)
古いコメントを表示
The following minimum working example illustrates a very common situation in Matlab, and shows the error produced when trying to aggregate values from across indexed fields that are themselves nested within other indexed fields.
a.students(1).grades = [7 8 9];
a.students(2).grades = [6 7 8];
max(a.students(:).grades(:)) % obtain maximum of ALL grades, from ALL students
% gives the error:
% Intermediate dot '.' indexing produced a comma-separated list with 2 values, but it must produce a single value when followed by subsequent indexing operations.
The same error is produced if I simply try to print out those values, without applying max or any other function, and putting the expression in square brackets doesn't help:
[ a.students(:).grades(:) ]
The only way to go around this is to keep using for loops, which makes code inelegant and error-prone. This seems too basic a feature to not have a built-in solution in Matlab. Would appreciate any suggestions how this could be achieved.
1 件のコメント
Stephen23
2022 年 5 月 18 日
編集済み: Stephen23
2022 年 5 月 18 日
Your code does not work because you are trying to apply one index onto multiple variables. MATLAB does not have such a command that applies one index to all members of a comma-separated list, nor is it likely to in the near future (that would be a major change in how commas and lists are interpreted).
a.students(1).grades = [7 8 9];
a.students(2).grades = [6 7 8];
a.students(:).grades % this returns multiple separate variables, not one array.
a.students(:).grades(:) % how can we apply one index to multiple arrays?
Basically your code is doing something a bit like this (pseudo-code):
[7 8 9],[6 7 8](:)
with the expectation that the colon index would be applied to both members of the comma-separated list.
採用された回答
参考
カテゴリ
Help Center および File Exchange で Matrix Indexing についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!