how to know if I can use parfor

9 次查看(过去 30 天)
mingcheng nie
mingcheng nie 2023-1-12
评论: Luca Ferro 2023-1-16
hi there, I am a telecommunication student working on some matlab code. I have a group signal to noise ratio(SNR) and need to run a loop to go through all the SNR, e.g. substituting the SNR into some code. I gave an example here
for i=1:length(SNR)
a=b(SNR(i))%some code/function need to substitute the SNR
end
Can I use the parfor to speed up? how can I justify if I can use parfor or not.
  1 个评论
Luca Ferro
Luca Ferro 2023-1-16
if this is all you needed and my answer is satisfactory could you please accept it and close the question?

请先登录,再进行评论。

回答(1 个)

Luca Ferro
Luca Ferro 2023-1-12
to use parfor() you need either a Matlab coder software (so standalone code) or the Parallel Computing Toolbox. Other than that i know no technical conditions that could limit its use.
Basically the syntax would be:
parfor (i=1:length(SNR),c),
a=b(SNR(i))%some code/function need to substitute the SNR
end
c is the number of cores you would like to use, if less cores than what you specify are available, it will use the most amount.
note that there is no guarantee that the operations in the parfor loop will be executed in order.
I think that in most cases it is overkill to use it and it would be better to optimize the code instead if possible. So if the only reason is to have the code run in a couple less seconds or minutes, i would not use it.
  3 个评论
Walter Roberson
Walter Roberson 2023-1-13
MATLAB recognizes parfor even if you do not have the toolbox. If you do not have the toolbox installed and licensed then it executes the iterations in serial in reverse order.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Loops and Conditional Statements 的更多信息

标签

产品


版本

R2022b

Community Treasure Hunt

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

Start Hunting!

Translated by