java – LIBSVM线程是否安全
作者:互联网
在使用LIBSVM时,我想利用当今的CPU多核功能.我想知道/理解的是我是否可以安全地从多个线程同时调用LIBSVM服务(例如,在8个不同模型上调用svm_train(),参数调整过程具有不同的参数).
我能找到的唯一参考是LIBSVM网站上的这个:
Q: How can I use OpenMP to parallelize LIBSVM on a multicore/shared-memory computer?
问题是它谈论了训练函数本身的算法(代码)的并行化,但没有提及多次同时调用训练函数 – 我更喜欢这样做,因为它让我更好地控制交叉验证&参数调整/网格搜索过程.
注意:我正在使用LIBSVM包本身(目前是java实现,也可能是python).
解决方法:
我知道你想在8个不同的问题实例和不同的参数上调用svm_train()来获得不同的模型实例!
当我查看Java-Sourcecode时,我发现只读取了问题和参数实例,并且没有任何内容写入它们.该方法创建自己需要修改和存储数据的所有对象,最后返回创建的模型.
这意味着从多个线程调用svm_train()应该没问题.
标签:java,multithreading,multicore,libsvm 来源: https://codeday.me/bug/20190629/1323454.html