




已阅读5页,还剩13页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
东华大学研究生课程论文封面教师填写:得分任课教师签名年 月 日学生填写:姓名学号专业导师课程名称任课教师课程学分上课时间20 至20 学年 第 学期 星期 递交时间年 月 日本人郑重声明:我恪守学术道德,崇尚严谨学风。所呈交的课程论文,是本人独立进行研究工作所取得的成果。除文中已明确注明和引用的内容外,本论文不包含任何其他个人或集体已经发表或撰写过的作品及成果的内容。论文为本人亲自撰写,我对所写的内容负责,并完全意识到本声明的法律结果由本人承担。 论文作者签名: 2摘 要在自动识别技术中,二维条码技术以其低成本、快速识读、大信息量、高安全性等优点,在社会生活中应用越来越广泛。物联网技术的蓬勃发展,也对二维条技术提供了广阔的应用空间。相应的二维条码编码、解码技术研究已经很多,应用上也基本成熟。目前,随着移动通信技术的飞速发展,手机的拥有量和使用量越来越大,功能也越来越强。二维条码技术和移动通信技术的结合,促成了手机二维码的诞生。因此,研究在手机等带有摄像头的智能嵌入式设备中的解码技术变得非常必要。与PC 系统下的解码方式相比,手机型号多种多样,性能差别很大,摄像头拍摄时受环境干扰也多。在复杂条件下如何有效进行二维条码解码的研究就显得非常必要。本文以QR 二维条码为例,通过图像处理技术对带有摄像头的智能设备采集的二维条码图像进行分析处理,解码出二维条码的编码信息,为手机二维码的广泛应用打下一定的技术基础。关键词:QR,二维码,编解码,物联网目录目录21 绪 论11.1 目的和要求11.2 设计内容11.3 总体设计方案12 二维码简介22.1 定义22.2 原理22.3 应用33 二维码解码技术43.1 算法总体流程43.2 图像的灰度化43.3 图像的降噪处理53.4 图像的二值化处理63.5 图形的定位73.6 常规扫描方法73.7 测试和调试11结论13致谢14参考文献151 绪 论1.1 目的和要求本课题主要研究二维条码的识别程序及译码方法,使用C语言来开发二维码的识别程序。查找并阅读相关资料,了解基本的内容,利用需求分析文档,对整个系统有个初步的架构。搜寻实验用的文件文档集和研究过程中用到的各种工具软件。根据已有的资料并借助面向对象的程序设计思想对系统各模块进行分析、建模、设计。使用C语言来开发二维码识别程序。1.2 设计内容本文主要来完成二维码识别和译码程序,运用图像校正、二值化、边缘检测等各种图像处理方法实现条码的预处理,并进行二维码码的解码,结合图像处理技术,完成了基于图像处理的二维码快速识别的解码系统。1.3 总体设计方案本设计的主要任务是在研究二维条码的码制标准的基础上实现对二维码的告诉采集与识别,详细分析二维码的基本特点、符号结构;在条码图像识别方面,研究了对采集的条码图像进行预处理的方法,即:对图像进行整形。运用图像校正、二值化、去噪、边缘检测、图像旋转、数据纠错等多种图像处理方法实现条码图像的预处理、条码定位、条码分割和数据提取。对预处理后的条码图像进行译码。2 二维码简介2.1 定义二维条码/二维码(英文名:QR Code) 是用某种特定的几何图形按一定规律在平面(二维方向)分布的黑白相间的图形记录数据符号信息的。二维码是DOI(Digital Object Unique Identifier,数字对象唯一识别符)的一种,全球最大的二维码资源中心是“渡云” ,为全球用户统一提供了“唯一数据样本”的物品、人员、组织二维码识别信息2.2 原理二维码的原理可以从矩阵式二维码的原理和行列式二维码的原理来讲述。矩阵式二维码(又称棋盘式二维码)是在一个矩形空间通过黑、白像素在矩阵中的不同分布进行编码。下图是国内常用的矩阵式二维码实例,手机正常扫描后会跳出高可靠性的信息:在矩阵元素位置上,出现方点、圆点或其他形状点表示二进制“1”,不出现点表示二进制的“0”,点的排列组合确定了矩阵式二维码所代表的意义。矩阵式二维码是建立在计算机图像处理技术、组合编码原理等基础上的一种新型图形符号自动识读处理码制。具有代表性的矩阵式二维码有:Code One、Maxi Code、QR Code、 Data Matrix等。图21*21的矩阵中,黑白的区域在QR码规范中被指定为固定的位置,称为寻像图形(finder pattern)和定位图形(timingpattern)。寻像图形和定位图形用来帮助解码程序确定图形中具体符号的坐标。黄色的区域用来保存被编码的数据内容以及纠错信息码。蓝色的区域,用来标识纠错的级别(也就是Level L到Level H)和所谓的Mask pattern,这个区域被称为“格式化信息”(format information)。行排式二维码(又称:堆积式二维码或层排式二维码),其编码原理是建立在一维码基础之上,按需要堆积成二行或多行。它在编码设计、校验原理、识读方式等方面继承了一维码的一些特点,识读设备与条码印刷与一维码技术兼容。但由于行数的增加,需要对行进行判定、其译码算法与软件也不完全相同于一维码。有代表性的行排式二维码有CODE49、CODE 16K、PDF417等。其中的CODE49,是1987年由 David Allair 博士研制,Intermec 公司推出的第一个二维码。2.3 应用网络资源下载(网址链接,APP下载)二维码名片(拍码即可快速导入联系人)证照应用(身份证、识别证、会员证等证照之资料登记及自动输入)支付方式(拍码支付,方便快捷)车辆管理应用(驾驶证,车辆的年审文件等基本信息转化保存在二维码)景点门票应用(景点门票,采用二维码进行售票、检票,提高通行效率)表单应用(公文表单、商业表单、进出口报单、舱单等资料之传送交换)婚礼应用(传统的婚礼要大派请柬,2013年婚礼只用发一张二维码即可)会议服务(二维码彩信短信邀请函,二维码签到,彩信会刊、会后感谢)追踪应用(生产线零件、客户服务、邮购运送、维修记录等自动追踪)创意应用(二维码指示牌,二维码宣传广告,二维码食品身份证)保密应用(商业情报、政治情报、军事情报等机密资料之加密及传递)3 二维码解码技术3.1 算法总体流程首先,对采集的彩色图像进行灰度化,以提高后继的运行速度。其次,去除噪声。采用十字形中值滤波去除噪音对二码图像的干扰主要是盐粒噪声。再次,利用灰度直方图工具,使用迭代法选取适当的阈值,对二维码进行二值化处理,使其变为白底黑色条码。最后,确定二维码的位置探测图形,对条码进行定位,旋转至水平后,获得条码数据,以便下一步进行解码。灰度化去噪二值化寻找探测图形确定旋转角度定位旋转获得数据图3.1 算法总体流程3.2 图像的灰度化灰度化的常用方法有两种:1.Gray(i,j) = 0.299 * R(i,j) + 0.587 * G(i,j) + 0.114 * B(i,j)2.Gray(i,j) = 30 * R(i,j) + 59 * G(i,j) + 11 * B(i,j)/100本设计进行灰度化的实现函数如下:internal virtual void imageToGrayScale(int image)for (int y = 0; y image0.Length; y+)for (int x = 0; x 16 & 0xFF;int g = imagexy 8 & 0xFF;int b = imagexy & 0xFF;int m = (r * 30 + g * 59 + b * 11) / 100;imagexy = m;3.3 图像的降噪处理降噪的方法很多,选用的是中值滤波法,因为中值滤波是一种非线性平滑滤波器。中值滤波在降低噪声的同时,又可以保持图像的细节,使用中值滤波时能较好保护图像的边缘。中值滤波的滤波窗口的形状和尺寸对滤波效果有一定的影响。常用的中值滤波窗口形状一般为正方形、十字形等。就一般经验而言,对于有缓慢变化的较长轮廓线物体的图像,适合使用正方形窗口;对于包含尖角物体的图像,适合使用十字形窗口。窗口大小一般小于图像中最小有效物尺寸为宜。中值滤波的函数实现如下:internal virtual bool applyMedianFilter(bool image, int threshold)bool filteredMatrix = new boolimage.Length;for (int i = 0; i image.Length; i+)filteredMatrixi = new boolimage0.Length;/filtering noise in image with median filter int numPointDark;for (int y = 1; y image0.Length - 1; y+)for (int x = 1; x image.Length - 1; x+)/if (imagexy = true) numPointDark = 0;for (int fy = - 1; fy 2; fy+)for (int fx = - 1; fx threshold)filteredMatrixxy = POINT_DARK;return filteredMatrix;3.4 图像的二值化处理二值化就是将图像转换成只有黑或白两种颜色,二值的方法也有很多,一种较为常用的是阈值法,取一个合适的阈值,使图像中每一个像素点应该属于目标还是背景区域,从而产生相应的二值图像。设原始图像为f(x,y),按照一定的准则在该图像中找到特征阈值T,将图像分割为两部分,分割后的图像为: (2-1)其中,b0为黑,b1为白。在QR码的图像二值化中,一般取b0=1,b1=0,也就是: (2-2)根据确定阈值的取样范围来分,二值化的方法可以分为全局阈值法与局部阈值法。全局阈值法对整幅图像的所有像素点进行取样,通过相关算法计算出一个阈值,进行二值化。而局部阈值法(又称为自适应阈值法)是将整幅图像划分成若干区域(通常是均匀划分),对每块区域中的像素点进行阈值计算,每块区域得出一个阈值,然后分块进行二值化9,10,11。使用局部阈值法时,每一块区域的二值化过程是独立进行的。本文使用的是中间值法,先对区域中所有像素点进行遍历,找出最大的灰度值Graymax和最小的灰度值Graymin,然后求出最大灰度值与最小灰度值的中间值Graymid,将该灰度值作为区域的阈值,即 T = Graymid = (Graymax + Graymin) / 2。3.5 图形的定位 图3.2 定位图形3.6 常规扫描方法GB/T 18284-2000中推荐的扫描方法如下:1. 在X方向进行依次扫描。a) 固定Y坐标的取值,在X方向上画一条水平直线(称为扫描线)进行扫描。当扫描线被黑白相间地截为1:1:3:1:1时,可以认为该直线穿过了位置探测图形。在实际判定时,比例系数允许0.5的误差,即比例系数为1的,允许范围为0.51.5,比例系数为3的,允许范围为2.53.5。b) 当寻找到有直线穿过位置探测图形时,记录下位置探测图形的外边缘相遇的第一点和最后一点A和B。由A、B两点为端点的线段称为扫描线段。将扫描线段保存下来。图3.3 扫描线段2. 在Y方向,使用相同的方法,进行垂直扫描,同样保存扫描得到的扫描线段。扫描步骤获得的扫描线段是没有经过分类的,也就是对于特定的一条扫描线段,无法获知其具体对应于三个位置探测图形中的哪一个。在计算位置探测图形中心坐标之前,要将所有的扫描线段按照位置进行归类。一般采用距离邻域法进行扫描线段的分类。距离邻域法的思想是:给定一个距离阈值dT。,当两条扫描线段的中点的距离小于dT。时,认为两条扫描线段在同一个邻域内,将它们分为一类,反之则归为不同的类别。距离邻域法的具体步骤如下:(1) 给定一个距离阈值dT。,dT。要求满足以下条件:位于同一个位置探测图形之中的任意两点之间的距离小于dT。,位于不同位置探测图形中的任意两点之间的距离大于dT(2) 新建一个类别,将第1条扫描线段归入其中。(3) 对于第i条扫描线段li(2in),做以下操作:a) 求出li的中点Ci。b) 分别计算Ci与在已存在的每一个类别中的第一条扫描线段的中点的距离d,若ddT,则直接将li加入相应类别中。c) 若无法找到li可以加入的类别,则新建一个类别,将li加入其中。(4)将所有类别按照包含扫描线段的数目进行从大到小排序,保存前3个类别(即包含扫描线段数目最多的3个类别),其余的视为误判得到的扫描线段(在位置探测图形以外的位置得到的符合扫描特征的扫描线段),直接舍去。距离邻域法结束后得到的分好3个类别的扫描线段就分别对应了3个位置探测图形。距离邻域法的关键就是距离阈值的选取。一般对于不同大小的QR码图像,要使用不同的距离阈值。其中GB/T 18284-2000中推荐的位置探测图形中心坐标的计算方法如下:(1) 在X方向的扫描线段中找出最外侧的两条,分别取中点,记为A、B。由A、B两点连一条直线。图3.4 对X方向扫描线段的处理(2) 在Y方向的扫描线段中找出最外侧的两条,分别取中点,记为C、D。由C、D两点连一条直线。图3.5 对Y方向扫描线段的处理(3) 计算直线AB与直线CD的交点O,即为位置探测图形中心点。图3.6 位置探测图形中心点将QR码符号的左上、右上位置探测图形的中心分别记为A、B。连接A、B。直线AB与水平线的夹角即为QR码符号的旋转角度。图3.7 旋转角度对于该旋转角度,求出其正弦值sin与余弦值cos即可。具体计算公式如下: (2-3) (2-4)其中, (2-5)在GB/T 18284-2000中定义的位置探测图形边长的计算是基于无旋转图像的,在无旋转图像中,水平扫描线段的长度即为位置探测图形的边长。水平扫描线段AB的长度即为位置探测图形的边长X。图3.8 位置探测图形的边长对于经过旋转的QR码图像,先通过插值算法生成旋正的QR码图像,然后按照如上所述的方法进行位置探测图形边长的计算3.7 测试和调试为了便于调试,本文设计了一个QR编码的方法,用于生成QR图像,再把生成的图像用识别器进行识别。界面如下:图3.9 调试界面其中实现QR编译的类为QRCodeEncoder ,主要的属性有:QRCodeEncodeMode、QRCodeScale、QRCodeVersion、QRCodeErrorCorrect,编译方法声明为 Bitmap Encode( String , Encoding ),设置好QRCodeEncoder的属性后,再调用QRCodeEncoder. Encode( 需编码的字符串 ,字符串的字符集 )就可以得到字符串对应的QR码,结果是一个Bitmap类,可以保存为图片。 图3.10 二维码图片QR码的识别处理,封装在QRCodeDecoder类中,该类有一个解码方法声明为 String decode(QRCodeImage) ,其中QRCodeImage为需要识别的图片,返值为识别后的字符串,要使用QRCodeImage,可以在生成QRCodeImage对象的时候,传一个Bitmap对象。译码界面如下:图3.11 译码界面结论本文已详细分析了图像的识别技术,在此基础上,根据新的应用需求也可以进行其它条码的识别。研究二维码图像的识别技术。运用图像校正、二值化、去噪、边缘检测、Hough变换、图像旋转等多种图像处理方法实现条码图像的预处理、条码定位、条码分割和数据提取。但由于各方面的原因,仍然存在着许多问题有待于进一步研究,比如识别算法的单一性问题以及纠错问题等,在稳定性和高效性也有进一步改进的可能。希望在后续工作中进一步改进和完善系统的功能。二维码由于具有高密度、大容量、纠错能力强、可表示文字图像等信息、可加密等优点,己广泛应用于传统的工业自动化生产线、医疗服务、收费系统、商品管理系统及信息查询系统等各个领域。而且随着当今信息技术的发展和网络的普及,二维条码将
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024-2025学年高中物理 第二章 楞次定律和自感现象 第1节 感应电流的方向说课稿2 鲁科版选修3-2
- 10 《制作纸相框》(教学设计)人教版劳动三年级下册
- 第2课 笔形与架构-表达文字内涵说课稿高中美术人教版2019选择性必修4 设计-人教版2019
- 服装色彩配色原理教学设计中职专业课-服装设计基础-服装设计与工艺-轻工纺织大类
- 自建房租赁协议书范本5篇
- 安全相关培训课件
- 安全监督人培训宣传课件
- 美丽中国2024年第五全国国家版图知识竞赛题库及答案
- 2024秋九年级语文上册 第2单元 7敬业与乐业说课稿 新人教版
- 协会法人变更申请书
- 高校实验室安全基础课(实验室准入教育)学习通网课章节测试答案
- 【申报书】高职院校高水平专业群建设项目申报书
- 劳动教育通论1-11章完整版课件
- 《炼油与化工装置机泵 在线监测系统技术规范》
- 羽毛球竞赛编排知识与方法
- 2023数据标准管理实践
- 非洲水坝施工方案
- Unit 3 Understanding ideas The Road to Success课件 2023-2024学年高中英语外研版选择性必修第一册
- 项目需求分析文档(模板)
- 长阳清江画廊
- 四川2023年专业技术人员公需科目“数字经济与驱动发展”参考答案(通用版)
评论
0/150
提交评论