How can I get R to use more CPU usage?

╄→гoц情女王★ 提交于 2019-12-01 18:36:01

If you are trying to run 4 different LPs in parallel, here's how to do it in snowfall.

sfInit(parallel=TRUE, cpus=4)
sfSource(code.R) #if you have your function in a separate file
sfExport(list=c("variable1","variable2",
            "functionname1")) #export your variables and function to cluster
results<-sfClusterApplyLB(parameters, functionname) #this starts the function on the clusters

E.g. The function in the sfClusterApply could contain your LP.

Otherwise see comments in regard to your question

Bas

Posting this as an answer because there's not enough space in a comment.
This is not an answer directly towards your question but more to the performance.


R uses slow statistical libraries by default which also can only use single core by default. Improved libraries are OPENBLAS/ATLAS. These however, can be a pain to install.
Personally I eventually got it working using this guide.

I ended up using Revolution R open(RRO) + MKL which has both improved BLAS libraries and multi-cpu support. It is an alternative R distribution which is supposed to have up to 20x the speed of regular R (I cannot confirm this, but it is alot faster).

Furthermore, you could check the CRAN HPC packages to see if there is any improved packages which support the lp function.

There is also packages to explore multi cpu usage.
This answer by Gavin, as well as @user3293236's answer above show several possibilities for packages allowing multi CPU usage.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!