Creating table columns in a parfor loop

2 views (last 30 days)
asdfg asdfg
asdfg asdfg on 6 Jan 2024
Commented: Raymond Norris on 10 Jan 2024
Found this buggy behaviour when creating tables in a parfor loop. The first example (doesn't work) causes the parallel pool worker to crash and gives a "Segmentation Violation" error in the crash dump file. However, in the second example (works), including any character that needs escaping (i.e. -, +, etc) in the table column title avoids the error.
%doesnt work
parpool('local', 1);
parfor i=1
temptab = table();
temptab.('var1') = ['a';'b'];
end
%works
parpool('local', 1);
parfor i=1
temptab = table();
temptab.('var-1') = ['a';'b'];
end
  6 Comments
Raymond Norris
Raymond Norris on 10 Jan 2024
Good thought, @Damian Pietrus. R2024a prerelease also works for me. So,
@asdfg asdfg has problems with R2023b (Mac)
@Damian Pietrus and @Raymond Norris have problems with R2023b (Windows 11)
@Matt J works fine with R2023b (Windows 10)
My next thought is the release Update. But I'm runnig GR (Update 0) and Damian's running the latest (Update 5).
@asdfg asdfg if you need this working on macOS R2023b, I'd suggest contacting MathWorks Technical Support. Otherwise, consider trying R2024a Prerelease.

Sign in to comment.

Answers (0)

Categories

Find more on Parallel for-Loops (parfor) in Help Center and File Exchange

Products


Release

R2023b

Community Treasure Hunt

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

Start Hunting!