使用SVM对于许多类型的多维数据分类

最近,我做了一件小事,使用SVM正确8三维级数据分类,在线搜索,我们发现二分的问题大家都在讨论二维数据,一些决定自己的研究。我首先参考opencvtutorial。这也是二维数据的二分类问题。然后通过学习研究,发现别有洞天,遂实现之前的目标。在这里将代码贴出来。这里实现了对三维数据进行三类划分。以供大家相互学习。

#include "stdafx.h"
#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/ml/ml.hpp>

using namespace cv;
using namespace std;

int main()
{

    //--------------------- 1. Set up training data randomly ---------------------------------------
    Mat trainData(100, 3, CV_32FC1);
    Mat labels   (100, 1, CV_32FC1);

    RNG rng(100); // Random value generation class

    // Generate random points for the class 1
    Mat trainClass = trainData.rowRange(0, 40);
    // The x coordinate of the points is in [0, 0.4)
    Mat c = trainClass.colRange(0, 1);
    rng.fill(c, RNG::UNIFORM, Scalar(1), Scalar(0.4 * 100));
    // The y coordinate of the points is in [0, 0.4)
    c = trainClass.colRange(1, 2);
    rng.fill(c, RNG::UNIFORM, Scalar(1), Scalar(0.4 * 100));
	// The z coordinate of the points is in [0, 0.4)
    c = trainClass.colRange(2, 3);
    rng.fill(c, RNG::UNIFORM, Scalar(1), Scalar(0.4 * 100));

    // Generate random points for the class 2
    trainClass = trainData.rowRange(60, 100);
    // The x coordinate of the points is in [0.6, 1]
    c = trainClass.colRange(0, 1);
    rng.fill(c, RNG::UNIFORM, Scalar(0.6*100), Scalar(100));
    // The y coordinate of the points is in [0.6, 1)
    c = trainClass.colRange(1, 2);
    rng.fill(c, RNG::UNIFORM, Scalar(0.6*100), Scalar(100));
	 // The z coordinate of the points is in [0.6, 1]
    c = trainClass.colRange(2, 3);
    rng.fill(c, RNG::UNIFORM, Scalar(0.6*100), Scalar(100));

    // Generate random points for the classes 3
    trainClass = trainData.rowRange(  40, 60);
    // The x coordinate of the points is in [0.4, 0.6)
    c = trainClass.colRange(0,1);
    rng.fill(c, RNG::UNIFORM, Scalar(0.4*100), Scalar(0.6*100));
    // The y coordinate of the points is in [0.4, 0.6)
    c = trainClass.colRange(1,2);
    rng.fill(c, RNG::UNIFORM, Scalar(0.4*100), Scalar(0.6*100));
	// The z coordinate of the points is in [0.4, 0.6)
    c = trainClass.colRange(2,3);
    rng.fill(c, RNG::UNIFORM, Scalar(0.4*100), Scalar(0.6*100));

    //------------------------- Set up the labels for the classes ---------------------------------
    labels.rowRange( 0,  40).setTo(1);  // Class 1
    labels.rowRange(60, 100).setTo(2);  // Class 2
	labels.rowRange(40, 60).setTo(3);  // Class 3

    //------------------------ 2. Set up the support vector machines parameters --------------------
    CvSVMParams params;
    params.svm_type    = SVM::C_SVC;
    params.C           = 0.1;
    params.kernel_type = SVM::LINEAR;
    params.term_crit   = TermCriteria(CV_TERMCRIT_ITER, (int)1e7, 1e-6);

    //------------------------ 3. Train the svm ----------------------------------------------------
    cout << "Starting training process" << endl;
    CvSVM svm;
    svm.train(trainData, labels, Mat(), Mat(), params);
    cout << "Finished training process" << endl;

	 Mat sampleMat = (Mat_<float>(1,3) << 50, 50,10);
     float response = svm.predict(sampleMat);
	 cout<<response<<endl;

	 sampleMat = (Mat_<float>(1,3) << 50, 50,100);
     response = svm.predict(sampleMat);
	 cout<<response<<endl;

	 sampleMat = (Mat_<float>(1,3) << 50, 50,60);
     response = svm.predict(sampleMat);
	 cout<<response<<endl;

    waitKey(0);
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

时间: 2024-09-27 10:26:27

使用SVM对于许多类型的多维数据分类的相关文章

个人网站类型的运维

企业级的网站运维耗资都是巨大的,对于个体用户来说是无法承担的,所以改下思路,我使用了百度统计和360网站监控.首先说下网站监控:   网站监控:首先可以扫描网站漏洞,(网址:http://webscan.360.cn/)对网站进行一个评估,值得注意的是扫描之前需要把自己的数据库备份一下,因为扫描过程中会进行数据库注入测试(表示我自己中招了两次),扫描过程大概20分钟,扫描完后会把扫描结果通过邮件方式发送给你 之后进行http监控,全天后检测http是否可用,当发生故障后会发送短信和邮件给你,让你

关于Delphi中二维数组的声明和大小调整(对非基本类型数据,小心内存泄漏)

这是一个实例: procedure TMainForm.Button1Click(Sender: TObject);var  arr:array of array of string;begin  setlength(arr,2,3);  arr[1,2]:='this is a test';  setlength(arr,0,0);  setlength(arr,4,5);  showmessage(arr[1,2]); end; 声明一个二维数组的方法是用 array of array of

C#调用C++ 平台调用P/Invoke 结构体--含有内置数据类型的一维、二维数组、字符串指针【六】

[1]结构体中含有内置数据类型的一维数组 C++代码: typedef struct _testStru3 { int iValArrp[30]; WCHAR szChArr[30]; }testStru3; EXPORTDLL_API void Struct_ChangeArr( testStru3 *pStru ) { if (NULL == pStru) { return; } pStru->iValArrp[0] = 8; lstrcpynW(pStru->szChArr, L&quo

SVM支持向量机算法

参考资料:http://www.cppblog.com/sunrise/archive/2012/08/06/186474.html                   http://blog.csdn.net/sunanger_wang/article/details/7887218 我的数据挖掘算法代码:https://github.com/linyiqun/DataMiningAlgorithm 介绍 svm(support vector machine)是一种用来进行模式识别,模式分类的

opencv使用svm

作者 群号 C语言交流中心 240137450  微信 15013593099 OpenCV开发SVM算法是基于LibSVM软件包开发的,LibSVM是台湾大学林智仁(LinChih-Jen)等开发设计的一个简单.易于使用和快速有效的SVM模式识别与回归的软件包.用OpenCV使用SVM算法的大概流程是 1)设置训练样本集 需要两组数据,一组是数据的类别,一组是数据的向量信息. 2)设置SVM参数 利用CvSVMParams类实现类内的成员变量svm_type表示SVM类型: CvSVM::C_

学习Opencv2.4.9(四)---SVM支持向量机

作者:咕唧咕唧liukun321 来自:http://blog.csdn.net/liukun321 先来看一下什么是SVM(支持向量机) SVM是一种训练机器学习的算法,可以用于解决分类和回归问题,同时还使用了一种称之为kernel trick(支持向量机的核函数)的技术进行数据的转换,然后再根据这些转换信息,在可能的输出之中找到一个最优的边界(超平面).简单来说,就是做一些非常复杂的数据转换工作,然后根据预定义的标签或者输出进而计算出如何分离用户的数据. 支持向量机方法是建立在统计学习理论的

OpenCV 中使用SVM

分类器 分类器是一种计算机程序. 他的设计目标是在通过学习后,可自动将数据分到已知类别. 平面线性分类器 一个简单的分类问题,如图有一些圆圈和一些正方形,如何找一条最优的直线将他们分开? 我们可以找到很多种方法画出这条直线,但怎样的直线才是最优的呢? 距离样本太近的直线不是最优的,因为这样的直线对噪声敏感度高,泛化性较差. 因此我们的目标是找到一条直线,离最近的点距离最远. 怎么寻找距离最远的直线?枚举所有直线,然后计算其样本最小距离?这样显然不是一个好办法,这将产生大量的计算开销. 我们利用另

OpenCV 2.4+ C++ SVM介绍

转自:http://www.cnblogs.com/justany/archive/2012/11/23/2784125.html opencv中svm的使用方法 分类器 分类器是一种计算机程序. 他的设计目标是在通过学习后,可自动将数据分到已知类别. 平面线性分类器 一个简单的分类问题,如图有一些圆圈和一些正方形,如何找一条最优的直线将他们分开? 我们可以找到很多种方法画出这条直线,但怎样的直线才是最优的呢? 距离样本太近的直线不是最优的,因为这样的直线对噪声敏感度高,泛化性较差. 因此我们的

听业内人士谈谈IT运维到底有没有意思?(续)-PIGOSS BSM

李虓,someone who still have dream 我 以前做过开发,现在在做运维.但我认为大部分人对这个职位还是普遍存大着很多误解,因为出现的时间和发展的时间不够长.本身互联网运维的目标就是保证产品 (网站/应用)能够正确无误的运行以支持整体商业目标 规模上去之后你会发现这个运维可以包括太多的东西,也可以细分成无数的子部门.    互联网公司的一个特点应该是快速开发周期,在SOA的框架下可以分成很多小service,如此多的service在开发.发布的过程中遇到的一系列问题,都需要