python实现基于SVM手写数字识别功能


Posted in Python onMay 27, 2020

本文实例为大家分享了SVM手写数字识别功能的具体代码,供大家参考,具体内容如下

1、SVM手写数字识别

识别步骤:

(1)样本图像的准备。
(2)图像尺寸标准化:将图像大小都标准化为8*8大小。
(3)读取未知样本图像,提取图像特征,生成图像特征组。
(4)将未知测试样本图像特征组送入SVM进行测试,将测试的结果输出。

识别代码:

#!/usr/bin/env python
import numpy as np
import mlpy
import cv2
print 'loading ...'

def getnumc(fn):
 '''返回数字特征'''
 fnimg = cv2.imread(fn) #读取图像
 img=cv2.resize(fnimg,(8,8)) #将图像大小调整为8*8
 alltz=[]
 for now_h in xrange(0,8):
 xtz=[] 
 for now_w in xrange(0,8):
  b = img[now_h,now_w,0]
  g = img[now_h,now_w,1]
  r = img[now_h,now_w,2]
  btz=255-b
  gtz=255-g
  rtz=255-r
  if btz>0 or gtz>0 or rtz>0:
  nowtz=1
  else:
  nowtz=0
  xtz.append(nowtz) 
 alltz+=xtz
 return alltz
 
#读取样本数字
x=[]
y=[]
for numi in xrange(1,10):
 for numij in xrange(1,5):
 fn='nums/'+str(numi)+'-'+str(numij)+'.png'
 x.append(getnumc(fn))
 y.append(numi)
 
x=np.array(x)
y=np.array(y)
svm = mlpy.LibSvm(svm_type='c_svc', kernel_type='poly',gamma=10)
svm.learn(x, y)
print u"训练样本测试:"
print svm.pred(x)
print u"未知图像测试:"
for iii in xrange (1,10):
 testfn= 'nums/test/'+str(iii)+'-test.png'
 testx=[]
 testx.append(getnumc(testfn))
 print 
 print testfn+":",
 print svm.pred(testx)

样本:

python实现基于SVM手写数字识别功能

python实现基于SVM手写数字识别功能

结果:

python实现基于SVM手写数字识别功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现得到一个给定类的虚函数
Sep 28 Python
以一个投票程序的实例来讲解Python的Django框架使用
Feb 18 Python
Python中属性和描述符的正确使用
Aug 23 Python
python编程测试电脑开启最大线程数实例代码
Feb 09 Python
python pandas 如何替换某列的一个值
Jun 09 Python
Django中ORM外键和表的关系详解
May 20 Python
PyCharm-错误-找不到指定文件python.exe的解决方法
Jul 01 Python
利用pyshp包给shapefile文件添加字段的实例
Dec 06 Python
python GUI库图形界面开发之PyQt5多行文本框控件QTextEdit详细使用方法实例
Feb 28 Python
python标准库OS模块详解
Mar 10 Python
一篇文章搞懂python的转义字符及用法
Sep 03 Python
Python编写可视化界面的全过程(Python+PyCharm+PyQt)
May 17 Python
Python中字典的浅拷贝与深拷贝用法实例分析
Jan 02 #Python
python+matplotlib绘制简单的海豚(顶点和节点的操作)
Jan 02 #Python
Python实现进程同步和通信的方法
Jan 02 #Python
mac系统安装Python3初体验
Jan 02 #Python
Python中static相关知识小结
Jan 02 #Python
python tensorflow基于cnn实现手写数字识别
Jan 01 #Python
python+selenium实现163邮箱自动登陆的方法
Dec 31 #Python
You might like
php+mysql开源XNA 聚合程序发布 下载
2007/07/13 PHP
用PHP连接MySQL代码的参数说明
2008/06/07 PHP
php魔术变量用法实例详解
2014/11/13 PHP
PHP实现通用alert函数的方法
2015/03/11 PHP
用PHP将Unicode 转化为UTF-8的实现方法(推荐)
2017/02/08 PHP
基于jquery的一个浮动框(扩展性比较好 )
2010/08/27 Javascript
基于jQuery实现仿淘宝套餐选择插件
2015/03/04 Javascript
jquery使用remove()方法删除指定class子元素
2015/03/26 Javascript
jQuery使用zTree插件实现树形菜单和异步加载
2016/02/25 Javascript
JavaScript中文件上传API详解
2016/04/01 Javascript
js获取新浪天气接口的实现代码
2016/06/06 Javascript
基于bootstrap实现广告轮播带图片和文字效果
2016/07/22 Javascript
Vuejs第八篇之Vuejs组件的定义实例解析
2016/09/05 Javascript
JS动态生成年份和月份实例代码
2017/02/04 Javascript
详解js静态资源文件请求的处理
2017/08/01 Javascript
JavaScript 中的 this 简单规则
2017/09/19 Javascript
使用vue实现简单键盘的示例(支持移动端和pc端)
2017/12/25 Javascript
浅谈vue中改elementUI默认样式引发的static与assets的区别
2018/02/03 Javascript
p5.js入门教程之键盘交互
2018/03/19 Javascript
JavaScript根据json生成html表格的示例代码
2018/10/24 Javascript
VUE实现Studio管理后台之鼠标拖放改变窗口大小
2020/03/04 Javascript
JavaScript接口实现方法实例分析
2020/05/16 Javascript
Python3实现的判断环形链表算法示例
2019/03/07 Python
详解Django 时间与时区设置问题
2019/07/23 Python
PyTorch 对应点相乘、矩阵相乘实例
2019/12/27 Python
canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动
2018/01/10 HTML / CSS
Canvas系列之滤镜效果
2019/02/12 HTML / CSS
世界知名接发和假发品牌:Poze Hair
2017/03/08 全球购物
美国婴儿用品店:Babies”R”Us
2017/10/12 全球购物
软件设计的目标是什么
2016/12/04 面试题
医学生自我评价
2014/01/27 职场文书
学生自我评价范文
2014/02/02 职场文书
工程承包协议书
2014/04/22 职场文书
大型活动组织方案
2014/05/10 职场文书
2014预备党员党课学习心得范文
2014/07/08 职场文书
导游词之无锡丝业博物馆
2019/11/12 职场文书