libsvm使用

在matlab中将libsvm安装完成后,就可以来尝试用一下啦。详细用法可以看文件夹中的README文件,这里主要介绍两个函数svmtrain()和svmpredict()。

svmtrain用法:

model = svmtrain(train_label, train_matrix, ['libsvm_options']); 根据输入的训练样本建立一个模型,该模型用来进行predict

train_label: 一个m*1的矢量,存着label值,矢量中数值类型必须为double型。

     所谓label即为分类的类别,train_matrix中的各行数据分别对应着train_label中相应行的一个label值,表示本行中的特征值属于label值标注的这一类。

train_matrix: 一个m*n的矩阵,数值类型也必须为double型。每一行都存着一组n维特征值向量,每一行表示一个样本,每一列表示一种特征。

libsvm_options: 调整参数生成不同的model可以影响svmpredict的准确率

      -c cost 对于错分的惩罚参数

            -g gama 核函数的参数之一 


svmpredict用法:

[predicted_label, accuracy, decision_values/prob_estimates] = svmpredict(test_label, test_matrix, model, ['libsvm_options'']);

predicted_label: 预测的标签,可以用来与test_label比对,从而计算准确率accuracy。decision_values/prob_estimates用于回归问题,分类问题中用不到。

test_label: 测试集用的标签,若没有则输入任意随机值。

test_matrix: 测试数据

model: svmtrain生成的模型


遇到的问题:

按网上教程使用命令[predicted_label, accuracy] = svmpredict(test_label, test_matrix, model),结果提示用法不正确,后来改成[predicted_label, accuracy, decision_values] = svmpredict(test_label, test_matrix, model)即可得到正确结果,估计是libsvm版本更新后最后一个返回值不能省略了。

libsvm是一个常用的支持向量机(SVM)库,用于分类和回归任务。下面是一个简单的libsvm使用教程: 1. 安装libsvm:你可以从libsvm官方网站上下载最新版本的libsvm库,并按照指示进行安装。 2. 数据准备:libsvm使用特定的数据格式。对于分类任务,数据应该是一个文本文件,每一行代表一个样本,以空格分隔特征特征值。例如: ``` label1 feature1:value1 feature2:value2 ... label2 feature1:value1 feature2:value2 ... ``` 对于回归任务,数据的格式与分类任务类似,但标签是连续的实数。 3. 数据加载:使用libsvm提供的API加载数据。在C++中,你可以使用`svm_problem`结构来存储训练数据使用`svm_load_problem`函数从文件中加载数据,并将其转换为`svm_problem`结构。 4. 参数设置:选择合适的参数配置。libsvm提供了一系参数,如SVM类型、核函数、惩罚系数等。你可以通过交叉验证或其他方法来选择最佳参数配置。 5. 模型训练:使用训练数据和参数配置来训练SVM模型。使用`svm_train`函数,将训练数据和参数作为输入,得到一个训练好的模型。 6. 模型预测:使用训练好的模型进行预测。对于分类任务,使用`svm_predict`函数,将测试数据作为输入,得到预测结果。对于回归任务,使用`svm_predict_values`函数,得到预测的连续值。 以上是libsvm的基本使用教程。你可以参考libsvm的文档和示例代码,进一步学习和使用libsvm库。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值