Tabular assignment extremely slow
38 views (last 30 days)
Show older comments
I am using Matlab 2024a and tabular assignments (tabular.braceAssign as per Profiler) are making any code extremely slow compared to other computers with the same hardware, OS and Matlab version. A factor of 10x slower on my machine for the same piece of code. I tried to reset the cache, check for shadowed functions, but nothing helped.
0 Comments
Answers (1)
Matt J
on 12 Jun 2025
Edited: Matt J
on 7 Oct 2025 at 23:31
No demo code? Tsk...tsk..
But if I were to guess, it is because you are using brace indexing for row-wise access like in the code below. The overhead of brace indexing a single row is porportional to the size of the entire table, which means it will be slow if you have a large table. It is a known issue which I reported last September. Why you get different speeds on different computers I have no idea, but you should avoid row-wise assignment if you can.
T = combinations(1:100,1:100,1:40,1:40); %multi-row table
t=T(1,:); %one row table
timeit(@()assignTest(t))
timeit(@()assignTest(T))
function assignTest(T)
T{1,:}=[1,1,1,1];
end
5 Comments
Paul
on 6 Oct 2025 at 17:27
Regrardless of this particular question, is there any progress on improving tabular brace indexing as shown in this thread and this other thread?
Matt J
on 14 Oct 2025 at 17:10
Edited: Matt J
on 14 Oct 2025 at 18:45
This is unlikely to be the problem, given that the OP said, "A factor of 10x slower on my machine for the same piece of code."
Since the OP said they are doing row-wise indexing, I think it has to be at least a major contributor to the problem. If I had to guess, I would say some of the different computers being compared are doing a better job of caching the large table2array result that table.braceReference computes. The OP said they are using similar hardware on all machines, but we don't know how similar...
See Also
Categories
Find more on Data Type Conversion 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!