Struct variable save in parfor loop
Show older comments
I made simple code to test for saving struct variable in parfor loop.
parfor k=1:3
my_field = sprintf('v%d', k);
variable.(my_field) = k*2;
end
But, i did not get the results I wanted, and there was only a variable with an empty value in the workspace.
If I use for instead of parfor, I get the result I want perfectly. However, the function(not the simple like above code) actually used takes a long time, so I want to use parfor.
How do I save a struct variable such as variable.v1, variable.v2 in a struct variable using parfor?
3 Comments
KSSV
on 1 Feb 2019
YOu should first try to vectorise and see the possibilites of avoiding loop..won't you think you can achieve your code without loop?
"If I use for instead of parfor, I get the result I want perfectly. "
I very much doubt that. Lets try it:
variable=struct();
for k=1:3
my_field = sprintf('v%d', k);
variable=struct(); % why do you overwrite this on every iteration?
variable.(my_field) = k*2;
end
On every loop iteration you completely overwrite variable, discarding anything that was stored in the variable on other loop iterations. Is that really what you mean by "I get the results I want perfectly" ?:
>> fieldnames(variable)
ans =
'v3'
"However, the function(not the simple like above code) actually used takes a long time, so I want to use parfor."
I very much doubt that parfor is a magic silver bullet for your runtime. Have you profiled your code to identify which lines take the most time? Have you followed the guidelines for writing efficient MATLAB code?:
Do you understand the overhead involved in running parallel code?
seung ho yeom
on 1 Feb 2019
Accepted Answer
More Answers (0)
Categories
Find more on Loops and Conditional Statements 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!