opencv-SVM

void MainWindow::on_SVM_Train_pushButton_clicked()
{
    const char *match_pic[match_all] = {
        "rightPic/0.bmp", "rightPic/1.bmp", "rightPic/2.bmp", "rightPic/3.bmp", "rightPic/4.bmp",
        "rightPic/5.bmp", "errorPic/6.bmp", "errorPic/7.bmp", "errorPic/8.bmp", "errorPic/9.bmp","errorPic/10.bmp","errorPic/11.bmp"
    };
    int i, j, k;

    float labels[match_all] = { 1, 1, 1, 1, 1, 1, -1, -1, -1, -1,-1,-1 };//标记样本类别
    Mat labelsMat(match_all, 1, CV_32FC1, labels);//必须为float

    //读取样本数据
    vector<vector<float>>  trainingData(match_all);
    for (i = 0; i<match_detect; i++){
        cv::Mat mat1 = cv::imread(match_pic[i], 0);
        uchar* ptr = mat1.ptr(0);
        int length = mat1.rows * mat1.cols;

        for (j = 0; j<length; j++){
            trainingData[i].push_back((float)ptr[j])  ;
        }
    }
    //准备训练数据
    //#define pic_size 68040 即图片像素总数
    Mat trainingDataMat(match_all, pic_size, CV_32FC1);
    for (i = 0; i<match_detect; i++)
    {
        for (j = 0; j<pic_size; j++)
        {
            trainingDataMat.at<float>(i, j) = trainingData[i][j];
        }
    }
    // Set up SVM's parameters
    //有很多训练参数的设置方式
    CvSVMParams params;
    params.svm_type = CvSVM::C_SVC;
    params.C = 0.1;
    params.kernel_type = CvSVM::LINEAR;
    params.term_crit = cvTermCriteria(CV_TERMCRIT_ITER, 100, 1e-6);

    // Train the SVM
    CvSVM SVM;
    SVM.train(trainingDataMat, labelsMat, Mat(), Mat(), params);
    SVM.save("1.xml");
}
void  MainWindow::on_SVM_detect_pushButton_clicked()
{
    CvSVM SVM;
    int i, j, k;
    string svm_test_img;
    SVM.load("1.xml");
    svm_test_img = ui->svm_test_file_path->text().toStdString();
    cv::Mat mat2 = cv::imread(svm_test_img, 0);
    uchar* ptr2 = mat2.ptr(0);
    vector<float>  testData;
    //float testData[pic_size];
    for (k = 0; k<pic_size; k++){
        testData.push_back((float)ptr2[k]);;
    }
    //cv::Mat mat3(1, pic_size, CV_32FC1, testData);
    Mat mat3(1, pic_size, CV_32FC1);//测试的数据
    for (i = 0; i<pic_size; i++)
    {

        mat3.at<float>(i) = testData[i];
    }
    float response = SVM.predict(mat3);//进行分类预测
    if (1 == response)
    {
        QString inf = QStringLiteral("合格");
        QMessageBox::information(this, QStringLiteral("测试结果"), inf);
    }
    else
    {
        QString inf = QStringLiteral("不合格 ");
        QMessageBox::information(this, QStringLiteral("测试结果"), inf);
    }

    printf("response:%f\n", response);
    ShowImage(mat2, ui->label_5);
}
要使用Python-OpenCV训练SVM,您需要遵循以下步骤: 1. 收集并准备数据集:您需要准备正样本和负样本的图像。将它们分别放在两个文件夹中,并确保它们的命名方式相同。 2. 提取图像特征:使用OpenCV的HOG描述符提取每个图像的特征。将这些特征存储在一个numpy数组中。 3. 创建SVM训练器:使用OpenCV的ml库创建一个SVM训练器对象。 4. 训练SVM:调用SVM训练器的train方法,并将特征数组和标签数组作为参数传递。标签数组应该是一个大小相同的numpy数组,其中包含正样本和负样本的标签。 5. 测试SVM:使用一些测试数据来测试SVM的性能,可以使用OpenCV的predict方法。预测结果将是一个数字,其中1表示正类,0表示负类。 以下是一个简单的示例代码,用于训练SVM: ```python import cv2 import numpy as np # Step 1: Collect and prepare dataset pos_images = ["pos1.jpg", "pos2.jpg", ...] neg_images = ["neg1.jpg", "neg2.jpg", ...] # Step 2: Extract image features hog = cv2.HOGDescriptor() features = [] labels = [] for img in pos_images: img = cv2.imread(img) features.append(hog.compute(img)) labels.append(1) for img in neg_images: img = cv2.imread(img) features.append(hog.compute(img)) labels.append(0) features = np.squeeze(features) labels = np.array(labels) # Step 3: Create SVM trainer svm = cv2.ml.SVM_create() # Step 4: Train SVM svm.train(features, cv2.ml.ROW_SAMPLE, labels) # Step 5: Test SVM test_img = cv2.imread("test.jpg") test_features = hog.compute(test_img) result = svm.predict(test_features) print(result) ``` 请注意,此代码仅为示例,您可能需要根据自己的数据集和需求进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值