jovahe 2016-01-21 01:07 采纳率: 0%
浏览 6034
已结题

opencv svm predict输出结果不对?

请教各位大侠:
我在使用opencv3.0的SVM进行图像分类时,训练样本为图像的灰度值(float型,最小0,最大255,均值2.0),
当灰度大于3.0时,lables设为1.0,小于3.0时,设置为-1.0;随便选了一种核函数进行训练,
然后再拿原图作为测试样本,结果在“response = svm->predict(sampleMat);”结果怎么不是1或-1,而是很大的一个负数(-1082130432.000);对原图每个像素进行训练都是这个负数,请各位大侠赐教!!!十分感激!!!
主体代码如下:
Mat trainImg = Mat(width*height, 1, CV_32FC1, img_org);//把图像安装width*height行1列的方式存进trainImg

float *labels = new float[width*height];
memset(labels, 0, sizeof(float)*width*height);
for (int j = 0; j < height; j++){
    for (int i = 0; i < width; i++){
        if (img_org[j*width + i]>3.0)
            labels[j*width + i] = 1.0;
        else
            labels[j*width + i] = -1.0;
    }
}
Mat labelsMat = Mat(width*height, 1, CV_32SC1, labels);

Ptr<ml::SVM> svm = ml::SVM::create();
svm->setType(ml::SVM::C_SVC);
svm->setKernel(ml::SVM::LINEAR);
svm->setTermCriteria(TermCriteria(TermCriteria::MAX_ITER, (int)1e7, 1e-6));;//终止准则函数:当迭代次数达到最大值时终止  

// 训练
svm->train(trainImg, ml::ROW_SAMPLE, labelsMat);// 
    Mat image = Mat::zeros(width, height, CV_8UC3);// 之前一直弄成CV_32SC1格式了,呵呵

Vec3b green(0, 255, 0), blue(255, 0, 0);

for (int j = 0; j < image.rows; j++){
    for (int i = 0; i < image.cols; i++){
        float temp = img_org[j*width + i];
        Mat sampleMat = Mat(1, 1, CV_32FC1, temp);
        float response = 0;
        response = svm->predict(sampleMat);// ??? 结果怎么不是1或-1,而是很大的一个负数,用openCV行不通?
        if (abs(response-1.0)<0.0001)
             image.at<Vec3b>(j, i) = green;         
        else if (abs(response + 1.0)<0.0001)
            image.at<Vec3b>(j, i) = blue;
    }
}

    imwrite("result.png", image);

 delete[]img_org;
  • 写回答

7条回答 默认 最新

  • devmiao 2016-01-21 17:51
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题