parallel call external exe file?
5 ビュー (過去 30 日間)
古いコメントを表示
I have a for loop that runs well that I would like to convert to the a parfor (or alternative mode of parallelizing the code). The loop creates and saves a text data file and calls an exe file then reads results back into Matlab. The for loop that works is
for jloops=1:loops
estpars=startVals(:,jloops); %reads in updating parameters
ADMBmakeData; %reads in static parameters and writes data file
eval('!faustCC.exe'); %runs external code
ADMBgetResult; %reads in external results
resultVals(:,jloops)=xIn; %puts external results in a matrix
resultFvals(jloops)=meritB(xIn); %creates a secondary result based on external results
end
I understand there is a problem with transparency and the eval call. I have tried putting it in a function. I have tried batch. Both were recommended elsewhere, but neither worked.
Is there a straight forward way to run this in parallel? Simply replacing for with parfor does not work.
Thanks, EF
0 件のコメント
回答 (1 件)
Raymond Norris
2014 年 8 月 20 日
Have you tried calling system? By the way, as it's written, you don't need eval, you ought to be able to just use !
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Loops and Conditional Statements についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!