Class with static variables in parallel global optimization algorithm
显示 更早的评论
Hello,
I have a global optimization program dealing with large matrices (several gigabytes of data), so in order to save memory, a class with static variables was implemented similar to the implementation in Static Data, and then one object of this class is created, initialized and passed as an argument to a function handle acting as the objective function of global multistage optimization algorithm (Particle Swarm + Pattern Search). When parallelization in optimoptions is true:
optimoptions( ...
'UseParallel', true);
The optimization always yields false results, but when parallelization is turned off, it works correctly.
Thanks in advance!
回答(2 个)
All variables are cloned when parallelization is used. Each parallel worker operates with an independent copy of any variable sent to it.
5 个评论
Omar Kamel
2019-2-8
Matt J
2019-2-8
We need to see code...
Omar Kamel
2019-2-8
Matt J
2019-2-8
Okay, but we also need to see how it is used in the optimization.
Omar Kamel
2019-2-14
编辑:Omar Kamel
2019-2-14
Walter Roberson
2019-2-14
0 个投票
Look again at the link you provided . Notice the point about static data not being saved with an object . The process of sending variables to parallel workers involves save and load.
3 个评论
Omar Kamel
2019-3-21
编辑:Omar Kamel
2019-3-21
Walter Roberson
2019-3-21
However, that saves the matrix once per worker, not "only 1 time in the memory". If you strictly need "only 1 time in the memory" then you should look in the File Exchange for https://www.mathworks.com/matlabcentral/fileexchange/28572-sharedmatrix which uses operating system shared memory.
类别
在 帮助中心 和 File Exchange 中查找有关 Surrogate Optimization 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!