编程语言
首页 > 编程语言> > java – LIBSVM线程是否安全

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