八云墨玄 2021-12-21 22:25 采纳率: 71.4%
浏览 159
已结题

修改svm识别手写数字

  • 写回答

4条回答 默认 最新

  • BryceRui 2021-12-22 11:40
    关注

    你试试这个呢

    
    import os
    import cv2
    import matplotlib.pyplot as plt
    import numpy as np
    from sklearn import datasets
    
    
    def getdata(_dir):
        images= []
        labels = []
        for cls in os.listdir(_dir):
            cls_dir = os.path.join(_dir,cls)  
            for file in os.listdir(cls_dir ):
                img = cv2.imread(os.path.join(cls_dir,file ),-1)
                images.append(img)
                labels.append(int(cls))
        return images,labels
    
    
    _dir_train=r""
    _dir_test=r""
    Xtrain,Ytrain = getdata(_dir_train)
    Xtest,Ytest= getdata(_dir_test)
    
    images_and_labels=list(zip(Xtrain,Ytrain))
    plt.figure(figsize=(8, 6))
    for index, (image, label) in enumerate(images_and_labels[:8]):
        plt.subplot(2, 4, index + 1)
        plt.axis('off')
        plt.imshow(image, cmap=plt.cm.gray_r, interpolation='nearest')
        plt.title('Digit: %i' % label, fontsize=20);
    
    from sklearn import svm
    clf = svm.SVC(gamma=0.001, C=100., probability=True)
    clf.fit(Xtrain, Ytrain);
    
    from sklearn.metrics import accuracy_score
    Ypred = clf.predict(Xtest);
    accuracy_score(Ytest, Ypred)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 12月30日
  • 已采纳回答 12月22日
  • 赞助了问题酬金 12月22日
  • 创建了问题 12月21日

悬赏问题

  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd