LIBSVM线程是否安全

时间:2014-01-21 14:57:46

标签: java multithreading multicore 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)。

1 个答案:

答案 0 :(得分:3)

据我所知,你想在8个不同的问题实例和不同的参数上调用svm_train()来获得不同的模型实例!

当我查看Java-Sourcecode时,我发现只读取了问题和参数实例,并且没有任何内容写入它们。该方法创建了自己需要修改和存储数据的所有对象,最后返回创建的模型。

这意味着从多个线程调用svm_train()应该没问题。