libsvm库基于c++的简单使用

libsvm库是一个开源的svm多语言支持库,官网地址https://www.csie.ntu.edu.tw/~cjlin/libsvm/,github地址https://github.com/cjlin1/libsvm

1.在c++中使用Libsvm库,第一步是将github中的svm.h,svm.cpp拷贝到CMakeLists调用的第三方库位置,然后就可以在自己的代码中使用,关于CMakeLists的编写和svm原理可以自行了解。

2.训练

只是关键一部分,主要记录下相关语法调用

//SVM  基于libsvm
std::string model_path= "../MODEL/svm.xml";
void trainSVM()
{
    //定义训练集和测试集的样本数
    const int  sampleSum=18*3;

    //读取训练数据,先以模板为训练集
    boost::format fmt_train_SVM("../train/temp%d.png"); 
    std::vector<cv::Mat> train_data;
    for (size_t i = 1; i < sampleSum+1; i++)    //读取
    {
        cv::Mat data=cv::imread(  (fmt_train_SVM % i).str() ,0);
        cv::Mat dataShape=data.reshape(1,1);
        train_data.emplace_back(dataShape);
    }

    //设置标签      训练样本所属类别 
    int labels[sampleSum] = { 
        1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,
        1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,
        1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,
        // 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,
    };
    svm_problem problem;
    problem.l=sampleSum;   //训练样本数
    problem.x = new svm_node*[sampleSum];   //特征矩阵
    problem.y = new double[sampleSum];     //标签矩阵
    for (int i=0; i<sampleSum; ++i) 
    {
        problem.x[i] = new svm_node[420*240+1]; //
        for(int j=0; j<420*240; ++j)
        {
            problem.x[i][j].index = j + 1;
            problem.x[i][j].value = train_data[i].at<uchar>(0,j);
        }
        problem.x[i][420*240].index = -1;
        problem.y[i] = labels[i];
    }
    //参数
    svm_parameter param;
    param.svm_type=C_SVC;
    param.kernel_type=LINEAR;
    param.degree=3;
    param.gamma=0.01;
    param.coef0=0;
    param.cache_size=20;
    param.eps=1e-6;
    param.C=1;
    param.nr_weight=0;
    param.weight_label=nullptr;
    param.weight=nullptr;
    param.nu=0.5;
    param.p=0.1;
    param.shrinking=0;
    param.probability=0;        //改成1后预测结果差得很大

    //train
    auto model = svm_train(&problem, &param);
    //save
    if (svm_save_model(model_path.c_str(), model))
    {
        std::cerr << "Save SVM to [" << model_path << "] FAILED" << std::endl;
    } 
    else
    {
        std::cout << "Save SVM to [" << model_path << "] SUCCEED." << std::endl;
    }


}

3.测试

//返回svm,基于libsvm
int testSVM(cv::Mat singleLabelMat)
{
    //1.get model
    svm_model *model=svm_load_model(model_path.c_str());

    //mat to svm_node
    cv::Mat sam=singleLabelMat.clone();
    cv::Mat samShape= sam.reshape(1,1);
    svm_node *sample=new svm_node[420*240+1];
    for (size_t i = 0; i < 420*240; i++)
    {
        sample[i].index=i+1;
        sample[i].value=samShape.at<uchar>(0,i);
    }
    sample[420*240+1].index=-1;
    double probresut[18];
    double resultLabel=svm_predict_probability(model,sample,probresut);
    //double resultLabel=svm_predict(model,sample);

    std::cout<<"labels: "<<resultLabel<<" "<<std::endl;
    
    
    return int(resultLabel);
}
  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: libsvm是一个用于支持向量机(Support Vector Machine)的机器学习算法,它提供了一系列用于解决分类和回归问题的工具和函数。在安装libsvm之前,需要确保计算机已经安装了合适的编译环境,比如GCC编译器等。 首先,我们需要从libsvm的官方网站(https://www.csie.ntu.edu.tw/~cjlin/libsvm/)下载libsvm的压缩包。解压缩后,可以在终端中进入解压缩后的目录。 然后,在终端中输入以下命令编译libsvm: ``` cd python make ``` 这将编译libsvm所需的文件,并在python目录下生成一个名为`svm.so`的文件。 接下来,我们需要将编译生成的`svm.so`文件复制到相应的Python目录中。在终端中输入以下命令: ``` sudo cp svm.so /usr/local/lib/python3.X/dist-packages ``` 其中,`python3.X`是你正在使用的Python版本。 最后,我们可以在Python中导入libsvm,并使用其提供的函数和类: ```python from svmutil import * # 示例代码 prob = svm_problem([1, -1], [[1, 0, 1], [-1, 0, -1]]) param = svm_parameter('-c 4') model = svm_train(prob, param) ``` 通过以上步骤,我们成功安装了libsvm,并可以在Python中使用它进行支持向量机相关的机器学习任务。 ### 回答2: 安装libsvm c需要按照以下步骤进行。 第一步,下载libsvm c的源代码。可以在libsvm的官方网站上找到最新的源代码版本,也可以直接使用命令行下载。下载之后,将源代码保存到本地。 第二步,安装必要的软件依赖项。在Linux系统上,可以使用命令行工具包管理器(比如apt或者yum)来安装gcc编译器和make工具。在Windows系统上,需要安装MinGW编译器和MSYS工具。 第三步,解压源代码文件。将下载好的源代码文件解压到指定的目录下,比如/home/user/libsvm。 第四步,打开命令行终端,进入到解压好的源代码目录中。使用cd命令切换目录,比如cd /home/user/libsvm。 第五步,执行make命令来编译libsvm。在命令行中输入make,然后按下回车键。编译过程可能需要一些时间,耐心等待编译完成。 第六步,编译完成后,会生成一个可执行文件svm-train和一个动态链接文件libsvm.so。可以通过运行svm-train来验证是否安装成功。在命令行中输入./svm-train,如果能够成功运行并显示帮助信息,则说明安装成功。 最后,将生成的libsvm.so文件复制到系统的目录下(比如/usr/local/lib),以便在其他程序中引用libsvm。 通过以上步骤,就可以成功安装libsvm c,并可以使用其提供的机器学习算法功能。 ### 回答3: libsvm是一个用于支持向量机(SVM)的机器学习。在安装libsvm之前,我们需要确保已经安装了适当的编译器,如gcc。接下来,我们可以按照以下步骤进行安装: 1. 首先,下载libsvm的源代码文件。可以从libsvm官方网站(https://www.csie.ntu.edu.tw/~cjlin/libsvm/)上下载最新版本的libsvm。 2. 将下载的文件解压缩到一个目录中。 3. 打开终端,并进入到刚刚解压缩的目录。 4. 在终端中输入以下命令进行编译: ``` make ``` 这个命令会自动编译libsvm的源代码,并生成可执行文件svm-train和svm-predict。 5. 如果编译成功,我们可以将生成的可执行文件复制到我们希望使用的目录下,方便后续使用。 通过以上步骤,我们就成功地安装了libsvm。此时,我们可以通过运行svm-train和svm-predict来训练和预测SVM模型。同时,我们还可以在自己的代码中引入libsvm的头文件,使用其提供的函数和类来训练和使用SVM模型。 需要注意的是,libsvm除了C语言版本外,还有其他语言的接口,如Python和Java。如果需要在其他编程语言中使用libsvm,我们可以按照相应语言的安装和使用方式进行操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值