位置: 编程技术 - 正文

3行程序搞定SVM分类-用JAVA程序调用LibSVM API 最简单的示例

编辑:rootadmin

推荐整理分享3行程序搞定SVM分类-用JAVA程序调用LibSVM API 最简单的示例,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

最近用LibSVM做分类实验,发现网上的资料大都是关于SVM基本原理和怎么用终端命令行使用svm-train,svm-predict等几个程序,这些其实在README文件中已经讲得很清楚了,Readme里面几乎包含了所有可以帮助你灵活使用LibSVM的信息,可以很多人都不怎么看。这里给出用JAVA调用LibSVM API最简单的示例,用JAVA进行SVM分类只需要几行程序就搞定了,前提是你已经准备好了符合LibSVM处理数据&#;式的训练样本和测试样本。下面一一道来(注:有网友向我要eclipse工程,下载地址见点击打开链接)

1、 准备训练样本和测试样本

直接上LibSVM官网就可以下载,我下载的UCI的UCI-breast-cancer数据集,训练样本和测试样本的基本&#;式是这样的

<label> <index1>:<value1> <index2>:<value2> ...

分别代表 类别 feature1索引:feature1&#; feature2索引:feature2&#;

如果想自己定义核函数,那么属于precompute kernel values and input them as training and testing files.

此时训练样本和测试样本变成如下&#;式:

New training instance for xi: <label> 0:i 1:K(xi,x1) ... L:K(xi,xL) New testing instance for any x: <label> 0:? 1:K(x,x1) ... L:K(x,xL)

That is, in the training file the first column must be the "ID" of xi. In testing, ? can be any value.

3行程序搞定SVM分类-用JAVA程序调用LibSVM API 最简单的示例

很好理解,有篇EMNLP做观点和关系抽取就是自己定义核函数借助SVM分类器实现的。

2、建立JAVA工程,导入LibSVM 的JAR包,要注意还需要导入java文件下的svm_train.java和svm_predict.java这两个文件,这两个类其实主要在LibSVM基础上做了进一步封装,把命令行参数转化成了String []类型的函数参数,方便API调用。至于另外两个svm_tony.java和svm_scale可以不导入,它们分别是图形界面和数据压缩用的,不是必要文件。

3、把训练样本和测试样本放在工程文件夹下,当然,你也可以自定义data目录。

4 、修改svm_train.java和svm_predict.java这两个文件,前者主要是把model_file_name返回,因为在svm_predict的main函数中需要使用,后者主要是把分类的Accuracy返回。

5、编写JAVA调用LibSVM API分类代码如下,非常简单,代码中给出了注释

[java] view plaincopyimport java.io.IOException; import libsvm.*; /**JAVA test code for LibSVM * @author yangliu * @blog * @mail yangliuyx@gmail.com */ public class LibSVMTest { public static void main(String[] args) throws IOException { // TODO Auto-generated method stub //Test for svm_train and svm_predict //svm_train: // param: String[], parse result of command line parameter of svm-train // return: String, the directory of modelFile //svm_predect: // param: String[], parse result of command line parameter of svm-predict, including the modelfile // return: Double, the accuracy of SVM classification String[] trainArgs = {"UCI-breast-cancer-tra"};//directory of training file String modelFile = svm_train.main(trainArgs); String[] testArgs = {"UCI-breast-cancer-test", modelFile, "UCI-breast-cancer-result"};//directory of test file, model file, result file Double accuracy = svm_predict.main(testArgs); System.out.println("SVM Classification is done! The accuracy is " &#; accuracy); //Test for cross validation //String[] crossValidationTrainArgs = {"-v", "", "UCI-breast-cancer-tra"};// fold cross validation //modelFile = svm_train.main(crossValidationTrainArgs); //System.out.print("Cross validation is done! The modelFile is " &#; modelFile); } } 6 运行工程,观察分类准确率,我的代码主要进行了两次实验,第一次是基于训练样本训练分类model(分类超平面),然后对测试样本进行分类;第二次直接对训练样本采用折交叉验证法测试SVM分类性能,其他参数采用默认&#;,运行结果如下

是不是很容易,其实仔细看看LibSVM的Readme,很多问题都不是问题。如果需要完整工程文件可以在下面评论栏留下邮箱。

附:svm 主调用程序经常使用的几个方法,注意这是LibSVM中SVM类下的函数,与svm_train.java等文件中的相关函数要区分:svm.svm_train(svm_problem,svm_parameter) 该方法返回一个训练好的svm_modelsvm.svm_load_model(文件名); 该方法返回一个训练好的svm_modelsvm.svm_save_model(文件名,svm_model); 该方法将svm_model保存到文件中svm.svm_predict_values(svm_model,svm_node,double); 该方法返回doule类&#;,svm_node对svm_model测试,返回&#;确定了svm_node在模型中的定位

原文:

android中style的学习心得 通过学习发现android中界面、元素及动画一般都用到style,关于系统自带的styles.xml文件(我的在D:android-sdk-windowsplatformsandroid-dataresvaluesstyles.xml),源

android 中添加字体:java.lang.RuntimeException: native typeface cannot be made 关于android自定义字体我想自行定义内容的字体,用了以下语句:TextViewtv=(TextView)findViewById(R.id.maintitle);//换字体Typefaceface=Typeface.createFromAsset(getAssets(),font

LRU缓存机制 今天在看Android内存优化的文档的时候,有一段提到了LRU内存缓存机制,当时一下没想起来,遂searchinnet.然后知道真相的我眼泪掉下来,%_%大学时候学的

标签: 3行程序搞定SVM分类-用JAVA程序调用LibSVM API 最简单的示例

本文链接地址:https://www.jiuchutong.com/biancheng/376596.html 转载请保留说明!

上一篇:我决定放弃Android开发(我决定放弃了你却对我笑了)

下一篇:android中style的学习心得(android style文件)

  • 一般纳税人公账转法人私账
  • 个人所得税手续费返还属于政府补助吗
  • 解聘补偿金赔偿标准2023
  • 应交税费是什么类
  • 公司账户短期理财收益要交税吗
  • 什么企业符合加计扣除的条件
  • 小规模纳税人可以开13%的发票吗
  • 企业一般户怎么注销
  • 参加会议培训的好处
  • 过路费按照什么缴纳增值税
  • 工会支出发票抬头是企业名称可以吗
  • 物业公司临时工的工资可以进成本吗
  • 广告传媒公司安全生产标准化
  • 企业成立股东没有实际出资分录怎么写?
  • 固定资产退回账务处理规定
  • 预收账款计入应纳税所得额
  • 给不是本单位的人开证明
  • 理论增值额的含义
  • 二手房有不动产统一发票吗
  • 员工工作服计入劳保费吗
  • 有进项无销项会计分录
  • 外币报表折算差额会计分录
  • 软件服务费是什么
  • 出售专利权属于什么科目
  • 工会会费可以一年交两个单位吗
  • 捐款属于什么会计科目类别
  • 外卖收入增值税怎么算
  • 工资中的话费补助是什么
  • window10安装教程u盘
  • 当月收到服务成本票下个月才开出发票
  • 采购合同付款违约条款怎么签
  • 怎么绕开中介找到房主
  • 预提费用是啥
  • 什么叫存续分立
  • 退货时会计分录的银行存款能是负数吗
  • 其他收益年末需要结转吗
  • framework启动
  • 相思树学名叫什么
  • 上月未结账本月不能操作任何业务
  • vue route 参数
  • 房租的计算方式
  • 房租税务局代增值税发票 税点
  • 库存周转率会大于1吗
  • Sqlite数据库里插入数据的条数上限是500
  • 购买办公楼之后怎么入住
  • 医疗器械和医疗耗材是一回事吗
  • 投资性房地产成本模式转公允模式差额
  • 家具厂成本
  • 小规模纳税人为什么不能抵扣进项税
  • 购买预付卡如何开发票
  • 什么是存货周转期间
  • 自产产品对外捐赠确认收入吗
  • 公司名义看望病人慰问金用什么包
  • 银行日记账更正
  • 企业贷款利息多少
  • 计提工资申报个税
  • 管理费用科目余额表有余额怎么办
  • 新成立的公司需要年报吗
  • 全国县市区最多的省
  • win8出现问题需要重启
  • m0b0player播放器
  • system idle process 连接了外网
  • winxp系统占用c盘多少
  • windowsxp示例图片
  • 垂直翻转画布
  • jQuery+AJAX实现遮罩层登录验证界面(附源码)
  • django ajax请求
  • javascript中new Array()和var arr=[]用法区别
  • vue父子组件之间的通讯
  • 批处理清除保留扇区
  • node.js gui
  • 注释讲解
  • jQuery基本选择器
  • 全面解析日本失去的十年
  • android studio 安装好后怎么在桌面找到
  • 山东发票查询系统平台
  • 街道税务所职责和任务
  • 公司0申报怎么申报视频
  • 年度纳税申报基础信息表怎么填
  • 地税逾期了怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设