机器视觉课程设计报告书
机器视觉系列课程设计
机器视觉系列课程设计一、教学目标本课程旨在通过机器视觉系列课程的学习,让学生掌握机器视觉的基本概念、原理和应用。
具体目标如下:1.了解机器视觉的基本概念和原理。
2.掌握机器视觉的主要技术和应用领域。
3.熟悉机器视觉的基本算法和编程方法。
4.能够运用机器视觉技术解决实际问题。
5.具备进行机器视觉算法设计和编程的能力。
6.能够进行机器视觉系统的设计和调试。
情感态度价值观目标:1.培养学生对机器视觉技术的兴趣和热情。
2.培养学生对科技创新和智能化发展的认识和关注。
3.培养学生具备团队合作和创新思维的能力。
二、教学内容本课程的教学内容主要包括机器视觉的基本概念、原理、技术和应用。
具体安排如下:第1周:机器视觉概述1.1 机器视觉的基本概念1.2 机器视觉的发展历程1.3 机器视觉的应用领域第2周:机器视觉的基本原理2.1 图像处理基础2.2 特征提取和匹配2.3 机器视觉的算法概述第3周:机器视觉的主要技术3.1 计算机视觉3.2 图像识别与分类3.3 目标检测和跟踪第4周:机器视觉的应用案例4.1 工业自动化4.2 智能交通4.3 医疗影像分析三、教学方法为了激发学生的学习兴趣和主动性,本课程将采用多种教学方法,包括讲授法、讨论法、案例分析法和实验法等。
1.讲授法:通过教师的讲解,让学生掌握机器视觉的基本概念、原理和算法。
2.讨论法:通过分组讨论,培养学生的团队合作能力和创新思维。
3.案例分析法:通过分析实际应用案例,让学生了解机器视觉技术的应用领域和解决方案。
4.实验法:通过实验室实践,让学生动手操作和调试机器视觉系统,培养学生的实际操作能力。
四、教学资源为了支持教学内容和教学方法的实施,丰富学生的学习体验,我们将准备以下教学资源:1.教材:选用《机器视觉》一书作为主要教材,系统介绍机器视觉的基本概念、原理和应用。
2.参考书:提供相关的参考书籍,供学生深入学习和拓展知识。
3.多媒体资料:制作精美的PPT和教学视频,帮助学生更好地理解和掌握机器视觉技术。
机器视觉课课程设计
机器视觉课课程设计一、教学目标本课程旨在让学生了解和掌握机器视觉的基本概念、原理和应用,培养学生对机器视觉技术的兴趣和好奇心,提高学生的科学素养和创新能力。
具体目标如下:1.知识目标:学生能够理解机器视觉的基本原理,掌握常见的机器视觉技术和应用,如图像处理、目标检测、人脸识别等。
2.技能目标:学生能够运用机器视觉技术解决实际问题,如编写简单的机器视觉程序,进行图像处理和目标检测等。
3.情感态度价值观目标:学生能够认识到机器视觉技术在现代社会中的重要性,理解科技对人类生活的影响,培养正确的科技观念和价值观。
二、教学内容本课程的教学内容主要包括机器视觉的基本概念、原理和应用。
具体安排如下:1.第一章:机器视觉概述,介绍机器视觉的定义、发展历程和应用领域。
2.第二章:图像处理,讲解图像处理的基本概念、原理和常用方法,如图像滤波、边缘检测、图像分割等。
3.第三章:目标检测,介绍目标检测的基本方法和技术,如滑动窗口法、特征匹配、深度学习等。
4.第四章:人脸识别,讲解人脸识别的基本原理和常用算法,如特征提取、模板匹配、神经网络等。
5.第五章:机器视觉应用,介绍机器视觉在现实生活中的应用案例,如自动驾驶、无人机、工业自动化等。
三、教学方法本课程采用多种教学方法,以激发学生的学习兴趣和主动性。
具体方法如下:1.讲授法:教师讲解机器视觉的基本概念、原理和算法,引导学生理解并掌握相关知识。
2.讨论法:学生分组讨论实际案例,分析机器视觉技术在解决问题中的应用,培养学生的思维能力和团队协作精神。
3.案例分析法:分析具体的机器视觉应用案例,让学生了解机器视觉技术在现实生活中的重要性。
4.实验法:学生动手编写机器视觉程序,进行图像处理和目标检测等实验,提高学生的实际操作能力。
四、教学资源本课程所需的教学资源包括教材、参考书、多媒体资料和实验设备。
具体如下:1.教材:选用《机器视觉》一书作为主要教材,为学生提供系统的机器视觉知识。
机器视觉实验报告
研究生课程论文机器视觉应用实验报告《机器视觉应用实验报告》姓名学号院系专业仪器仪表工程指导教师华南理工大学实验报告课程名称:机器视觉应用机械与汽车工程学院系仪器仪表工程专业姓名廖帆实验名称机器视觉应用实验日期指导老师一、实验目的自行搭建机器视觉测量系统,采集标定板、工件图像,利用图像处理软件进行标定、工件尺寸测量、工件缺陷检测。
主要目的有:1、根据被测工件,搭建机器视觉测量系统,选择成像系统软件,进行图像采集等实验。
掌握常规机器视觉测量原理、实验平台搭建、图像采集步骤;2、掌握成像系统软件常用操作,能够对图像进行简单处理,并编写简单相关程序尺寸测量、缺陷检测判定;3、对测量结果进行误差分析,进一步加深理解机器视觉测量过程中的关键因素。
二、实验原理机器视觉主要是利用机器实现代替人眼来做测量和判断等目的,因此机器视觉可以看作是使用计算机及相关设备对生物视觉的一种模拟。
该实验就是通过对选取的工件进行图像采集和图像分析处理以获得所需物体的尺寸、缺陷等信息,一个典型的机器视觉系统包括:相机(包括COMS相机和CCD相机)、光源、镜头、图像获取单元(图像采集卡等)、显示器、图像处理软件、通讯设备、输入输出单元等。
本次实验借助HALCON机器视觉软件,它是德国MVtec公司开发的一套完善的标准的机器视觉算法包,拥有应用广泛的机器视觉集成开发环境,在欧洲以及日本的工业界已经是公认具有最佳效能的MachineVision软件。
它源自学术界,是一套图像处理库,由一千多个各自独立的函数,以及底层的数据管理核心构成。
其中包含了各类滤波、色彩分析以及几何、数学变换、形态学计算分析、校正、分类、辨识、形状搜索等等基本的几何以及图像计算功能。
HALCON支持Windows,Linux和MacOS X操作环境,函数库可以用C,C++,C#,Visual Basic 和Delphi等多种普通编程语言开发,为工业检测上提供了高速、高精度、强有力的方法。
机器视觉课内实验
机器视觉课内实验报告(4次)学院:自动化班级:智能姓名:学号:目录实验一:一种摄像机标定算法的编程实现 (1)实验二:图像预处理算法的编程实现 (8)实验三:基于一阶微分算子的边缘检测 (14)实验四:基于二阶微分算子的边缘检测 (17)《机器视觉》课内实验报告(1)摄像机标定算法的编程实现智能科学与技术专业:班级:学号:姓名:实验时间:实验一MATLAB 编程实现基于直接线性变换的摄像机标定方法一、实验目的掌握摄像机标定方法的原理,采用直接线性变换方法,通过MATLAB 编程实现摄像机内参数和外参数的估计。
二、实验原理摄像机标定是指建立摄像机图像像素位置与场景点位置之间的关系,其途径是根据摄像机模型,由已知特征点的图像坐标求解摄像机的模型参数。
直接线性变换是将像点和物点的成像几何关系在齐次坐标下写成透视投影矩阵的形式:其中(u ,v ,1)为图像坐标系下的点的齐次坐标,(X,Y,Z)为世界坐标系下的空间点的欧氏坐标,P 为3*4的透视投影矩阵,s 为未知尺度因子。
消去s ,可以得到方程组:当已知N 个空间点和对应的图像上的点时,可以得到一个含有2*N 个方程的方程组: 三、实验步骤1 读取一幅图像并显示;2 检查内存(数组)中的图像;3 实现图像直方图均衡化;4 读取图像中像素点的坐标值;5 保存图像;6 检查新生成文件的信息;7 使用阈值操作将图像转换为二值图像; 8 根据RGB 图像创建一幅灰度图像; 9 调节图像的对比度;10 在同一个窗口内显示两幅图像;11 掌握Matlab 命令及函数,获取标定块图像的特征点坐标;12 根据DLT 摄像机标定方法原理编写Matlab 程序,估计摄像机内参数和外参数;⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎣⎡=⎥⎥⎥⎦⎤⎢⎢⎢⎣⎡⨯1143w w w Z Y X P v u s 0034333231142322213433323114131211=----+++=----+++u p uZ p uY p uX p p Z p Y p X p u p uZ p uY p uX p p Z p Y p X p w w w w w w w w w w w w 0=AL四、程序代码及实验结果显示代码:I=imread('C:\Users\w\12.jpg');imshow(I);whosfigure,I1=rgb2gray(I);figure,imshow(I1)imhist(I1);I2=histeq(I1);figure,imshow(I2)figure,imhist(I2)a=imread('C:\Users\w\12.jpg');imwrite(I1,'DSgray.jpg');imwrite(I2,'DSgrayeq.jpg');inf=imfinfo('C:\Users\w\12.jpg');level=graythresh(I2);bw=im2bw(I2,level);figure,imshow(bw)whosI3=imadjust(I2,stretchlim(I2),[0 1]); figure,imshow(I3);a=imread('C:\Users\w\12.jpg');b=imread('DSgray.jpg');subplot(1,2,1),imshow(a);subplot(1,2,2),imshow(b);clear;xpot=[];ypot=[];imshow('C:\Users\w\12.jpg');hold on;n=input('Please input the number of pot:'); for i=1:n[x,y]=ginput(1);plot(x,y,'or');text(x+1,y+1,num2str(i));xpot=[xpot,x];ypot=[ypot,y];end[xpot;ypot][xw;yw;zw]a=[xw',yw',zw',ones([100 1]),zeros([100 4]),(-1)*xpot'.*xw',(-1)*xpot'.*yw',(-1)*xpot'.*zw',-1*xpot';zeros([1004]),xw',yw',zw',ones([100 1]),(-1)*ypot'.*xw',(-1)*ypot'.*yw',(-1)*ypot'.*zw',-1*ypot'];c=a(:,1:11);b=a(:,12);l=(-1)*(c'*c)^(-1)*c'*b;显示两幅图对比度调节均衡化直方图灰度图直方图二进制图图片信息:名称:12.jpg项目类型:JPG图像文件夹路径:C:\Users\w创建日期:2017年11月6日, 星期一 13:16修改日期:2017年11月6日, 星期一 13:16 大小:111KB分辨率:1024 x 638宽度:1024像素高度:638像素水平分辨率:72dpi垂直分辨率:72dpi位深度:24检查内存中的图像:Name Size Bytes Class AttributesI 638x1024x3 1959936 uint8 ans 2x15 240 doublei 1x1 8 doublen 1x1 8 doublex 1x1 8 doublexpot 1x15 120 doubley 1x1 8 doubleypot 1x15 120 doubleName Size Bytes Class AttributesI 638x1024x3 1959936 uint8 I1 638x1024 653312 uint8I2 638x1024 653312 uint8a 638x1024x3 1959936 uint8ans 2x15 240 doublebw 638x1024 653312 logicali 1x1 8 doubleinf 1x1 42720 structlevel 1x1 8 doublen 1x1 8 doublex 1x1 8 doublexpot 1x15 120 doubley 1x1 8 doubleypot 1x15 120 doublePlease input the number of pot:10ans =550.3592 391.7113 261.9085 521.5141 838.8099 921.7394 211.4296 117.6831 770.3028 957.7958463.7254 308.6831 146.4296 160.8521 283.4437 492.5704 460.1197 247.3873 113.9789 157.2465五、实验心得《机器视觉》课内实验报告(2)图像预处理算法的编程实现智能科学与技术专业:班级:学号:姓名:实验时间:实验二:图像预处理算法的编程实现一、实验目的掌握图像预处理的基本方法及其主要思想,编程实现直方图均衡化、直方图规定化和图像的锐化处理。
机器视觉实验报告
机器视觉实验报告
一、实验目的
本实验旨在探究机器视觉在图像识别和分析方面的应用,通过实际操作和数据分析,验证机器视觉技术的准确性和可行性。
二、实验装置与方法
1. 实验装置:使用具备机器视觉功能的摄像头和计算机软件。
2. 实验方法:
a. 首先,搜集一定数量的图像数据作为实验样本。
b. 接着,利用机器视觉软件对图像数据进行处理和分析。
c. 最后,对机器视觉技术的准确性和稳定性进行评估。
三、实验结果分析
通过实验数据的分析和比对,我们得出以下结论:
1. 机器视觉在图像识别方面具有较高的准确率,能够准确辨识不同物体和场景。
2. 机器视觉在图像分析方面具有较强的处理能力,能够提取图像特征和进行数据分析。
3. 机器视觉技术的稳定性较高,能够在复杂环境下正常工作并保持较高的准确性。
四、实验结论与展望
通过本次实验,我们验证了机器视觉技术在图像识别和分析方面的有效性和可靠性。
未来,随着技术的不断进步和应用领域的拓展,机器视觉将会在更多领域展示出其强大的功能和潜力,为人类生活和工作带来更多便利和效益。
以上为机器视觉实验报告的内容,希望能够对您有所帮助。
机器视觉的应用课程设计
机器视觉的应用课程设计一、课程目标知识目标:1. 学生能理解机器视觉的基本概念,掌握其在实际应用中的原理和流程。
2. 学生能描述至少三种机器视觉技术的应用案例,并阐述其工作原理和关键功能。
3. 学生能运用已学的图像处理知识,分析并解决简单的机器视觉问题。
技能目标:1. 学生具备运用机器视觉软件进行基本图像捕捉、处理和分析的能力。
2. 学生能通过小组合作,设计并实施一个简单的机器视觉应用项目。
3. 学生能够运用批判性思维,评价机器视觉应用的优缺点,并提出改进方案。
情感态度价值观目标:1. 学生能够积极探究机器视觉技术在实际生活中的应用,培养对人工智能技术的兴趣和认识。
2. 学生在小组合作中,学会尊重他人意见,培养团队协作精神。
3. 学生能够关注机器视觉技术对社会生活的影响,认识到科技发展应遵循道德伦理原则,树立正确的科技价值观。
课程性质:本课程为高年级选修课程,旨在帮助学生将所学的图像处理知识应用于实际项目中,提高学生的实践能力和创新能力。
学生特点:学生具备一定的图像处理知识基础,对新鲜事物充满好奇,喜欢动手实践。
教学要求:注重理论与实践相结合,鼓励学生主动探索、合作学习,注重培养学生的实践能力和科技创新精神。
通过分解课程目标为具体的学习成果,使学生在完成课程后能够达到预定的知识、技能和情感态度价值观目标。
二、教学内容1. 机器视觉基础理论:- 介绍机器视觉的概念、发展历程及在我国的应用现状。
- 影像感知与图像处理基础知识回顾,如像素、分辨率、图像格式等。
2. 机器视觉技术与应用:- 分类介绍常见的机器视觉技术,如图像识别、目标跟踪、三维重建等。
- 分析典型应用案例,如工业检测、自动驾驶、医疗诊断等。
3. 机器视觉系统组成与工作原理:- 阐述机器视觉系统的硬件组成,如光源、镜头、相机、图像传感器等。
- 介绍机器视觉软件的功能、分类及选用原则。
4. 实践操作与项目设计:- 指导学生使用机器视觉软件进行图像捕捉、处理和分析。
机器人视觉建模课程设计
机器人视觉建模课程设计一、教学目标本课程旨在通过学习机器人视觉建模,使学生掌握机器视觉的基本原理和方法,培养学生运用视觉信息处理技术解决实际问题的能力。
具体目标如下:1.理解机器视觉的基本概念、原理和应用。
2.掌握常用视觉信息处理技术,如图像处理、特征提取、目标识别等。
3.了解视觉建模的基本方法,包括几何建模、物理建模和统计建模等。
4.能够运用视觉信息处理技术进行简单的图像处理和分析。
5.能够运用视觉建模方法解决实际问题,如目标跟踪、场景重建等。
6.具备一定的编程能力,能够使用常见的视觉软件和工具。
情感态度价值观目标:1.培养学生对新技术的敏感性和好奇心,激发学生对领域的兴趣。
2.培养学生具备创新精神和团队合作意识,提高学生解决实际问题的能力。
3.培养学生具备良好的科学道德,注重实践与理论相结合,遵循学术规范。
二、教学内容本课程的教学内容主要包括以下几个部分:1.机器视觉概述:介绍机器视觉的基本概念、原理和应用领域。
2.图像处理技术:包括图像增强、滤波、边缘检测、特征提取等。
3.目标识别与跟踪:介绍目标识别的基本方法和跟踪技术。
4.视觉建模方法:包括几何建模、物理建模和统计建模等。
5.实践项目:结合实际案例,进行视觉建模项目的实践和训练。
三、教学方法为了提高教学效果,本课程将采用多种教学方法相结合的方式,包括:1.讲授法:通过讲解基本概念、原理和算法,使学生掌握视觉建模的基本知识。
2.案例分析法:分析实际案例,使学生更好地理解视觉建模的方法和应用。
3.实验法:让学生动手实践,培养学生的实际操作能力和解决问题的能力。
4.小组讨论法:分组进行讨论和实践,培养学生的团队合作意识和沟通能力。
四、教学资源为了支持本课程的教学,我们将准备以下教学资源:1.教材:《机器人视觉建模》,提供基本概念、原理和算法的介绍。
2.多媒体资料:包括PPT、教学视频等,用于辅助讲解和演示。
3.实验设备:包括计算机、摄像头等,用于实践操作和实验。
机器视觉课程设计报告书
机器视觉课程设计对圆盘形零件I心与直径和矩形零件长与宽尺寸测量学生学院_______ 专业班级_____________________ 学号________________________ 学生_____________________指导教师_____________________2015年1月20日问题描述 (5)1. 1基本目标 (5)1.2基本要求 (5)程序及其算法 (5)2.1检测与计算圆半径的程序 (5)2.2检测与计算矩形长和宽的程序 (8)2. 2. 1打开摄像头程序 (8)2.2.2保存拍摄的照片程序 (9)2. 2. 3读取拍摄到的图片(读取文名字Current Image, jpg的图片) (9)2.2.4检测边上的点和计算长和高的函数 (9)2.2.5老师写的显示图片的函数 (13)运行结果 (14)小结 (15)1问题描述1.1基本目标显示一图片(包含一个矩形或一个圆),测量矩形的长宽或圆的直径。
完成得及格分,扩展有加分!要求图片1.2基本要求“机器视觉”考试结果要求独立在计算机上完成,建议使用Visual C++和OpenCV 实现一个具有视觉捕捉、图像显示、尺寸测量等功能的对话框程序,其中必须完成对圆盘形零件圆心与直径和矩形零件长与宽尺寸测量容。
在教师提供的基本框架程序基础上,修改、补充界面和功能。
2程序及其算法2.1检测与计算圆半径的程序思路:从图片中间横扫取点得M_Point[0], M_Point[l] (x坐标相加除2的圆心的x 坐标)中间纵向取点得M_Point[2], M_Point[3] (y坐标相加除2的圆心的y坐标)圆上四个点到圆心的距离(半径)取平均值,输出为半径。
显示图片程序如下:double c DialogTeclarn::f MakeCircle(double e dThreshold){if(NULL==m_pIplImageSource){return 0;}〃定义变量存图像的宽,高,行像素int q__iWidth z:m_pIplImageSource->width;int q_iHeight=m_pIplImageSource->height;int q__iWidthStep=m_pIpl ImageSource->widthStep;uchar *q_pchDataImage=(uchar *)m_pIp11mageSource->imageData:CvPoint M_Point[4] = {};//存放检索出的四个点循环检索//01纵扫for(int Cycle_Y=l;Cyc1e Y<q_iHeight;Cyc1e_Y++)if (e_dThreshold>q_pchDataImage[q_iWidth/2+q_iWidthStep*(Cycle_Y-l)J) { NLPoint[0].x=q_iWidth/2;M Point[01. y=Cycle Y;for(int cyclelYuq_iHeight;cycle —Y 〉l;CycleY I —)亠if(e —dThreshold 〉尸pchDat 巴mage 〔尸iwidth、2+Fiwidthstep*(cycle —Y —1)」)MPoint =〕• x=q —iwidth 、2"M PointLl〕・ yucycleY 八)}for(int Cycle xul 八 Cyclex 〈q —iwidthnyclex++)亠if(eldThreshold〉q_pchDataImage 〔cyclelx+尸iwidrhstep*(qliHeight、2丄)〕)3M Point 「2〕• xucyclelx; M Point 「2,- •yuq —iHeight'2”)} for(i nt Cycle XHq —iwid thnycl ex 〉1" Cycle X I —)亠rdThreshold〉尸pchDat 巴mage 「cycle —x2iwidthstep*(q 」Height、2丄)(M Point 「3〕•xucyclelx一MPoint 一3- •y=q —iHeight、2")}(i n t H-?i〈4“ i ++)、、画娱初El{cvCircle(m_plplImageSource,M_Point[i],8,cvScalarAl1 (127),2);}int Ridius=O t clear=O;int c i rc1e_y=abs(M Po i n111J. y+M Point I 0]. y)/2;int circ1e_x=abs(M Point[3]. x+M Point[2]. x)/2;float c=0,j=0;for (int i=0;i<4;i++){j=(M_Point[i]・ x-cirele x)*(M_Point[i]・ x-cirele x) + (M_Point[i]・ y-circle_y )*(M_Point[i]. y-circle_y);c=c+sqrt(j);}Ridius=c/4;//在窗口中显示长和高char chi[101,ch2[101;itoa(Ridius,chi,10);itoa (clear,ch2t10);SetDlgltemText(IDC LONG,chi);SetDlgltemText(IDC_SHORT,ch2);CWnd *e_pCWndPicture=this->GetDlgItem(ID PICTURE DISPLAY);fContro1ShowImage(m_pIplImageDisplay,e_pCWndPicture,m_pIplImageSource); cvSavelmage( T("・//Result_Image・ jpg"),m_plplImageSource);return 0;}2.2检测与计算矩形长和宽的程序思路:这个程序主要包括:打开摄像头-一保存图片(拍照)-一加载刚刚保存的图片-一找出点并计算长和高四个按钮,每一个按钮包含下面的一段代码,拍摄的图片保存为Currentimage, jpg,这里事先保存了一同名的图片,所以可以直接点击Load Image 读取。
《机器视觉》报告模板_课程综合实践报告
TDCQ大学20 -20 学年第学期《机器视觉》课程综合实践报告完善封面信息,报告双面打印,左侧2钉装订,报告打印前去掉此蓝/红色字体专业:学号:姓名:成绩:20 年月日目录(报告完成后可自动更新目录,并去掉此页的蓝色/红色文字)1 绪论(一级标题三号黑体) (1)1.1 课程综合实践的意义 (2)1.2 文献综述 (2)2 图像预处理与视觉特征提取 (3)2.1 ×××方法 (3)2.1.1 ×××方法 (3)2.1.2 ×××方法测试验证 (3)2.2 小结 (4)3 摄像机标定 (4)3.1 摄像机标定的原理(二级标题小三黑体) (5)3.1.1 摄像机模型(三级标题,四号宋体加粗) (5)3.2 实验结果及分析 (5)3.2.1 仿真条件(三级标题,四号宋体加粗) (5)3.2.2 实验结果及结果分析(三级标题,四号宋体加粗) (5)3.3 小结 (5)4 立体视觉匹配 (6)5 运动分析 (6)6 综合实践及测试 (6)总结 (6)参考文献 (7)特别注意:本报告的模板后续章节是按照绪论、各章实践作业和以无人车为载体的综合实践为顺序设置的章节内容。
在具体实施时可以不局限于这个形式,可以以“无人车机器视觉系统综合实践”为主线,从概述、系统方案设计、理论方法及测试验证、实践平台集成与测试和结论。
但无论哪种形式,后续“特别注意”中的细节要求都是相同的。
这也是重点考察逻辑性、规范性、可读性的标准。
1 绪论(一级标题三号黑体)特别注意:在形成报告时,删除所有提示的文字,即文中蓝色和红色字体、图或字符,各级标题的字号和字体如下:一级标题三号黑体二级标题小三号黑体三级标题四号宋体加粗文内标题小四号宋体加粗特别注意:正文为小四号宋体(中文)+Time New Roman(英文)字体,1.5倍行距;段首行空2字符;标点符号必须用中文标点符号,而且标点符号要合理使用;文中首次出现的英文缩写需给出英文全称;引用的参考文献要顺序引用,不许跳引和漏引;排版时每一页的页面底端不能留空白,当底端有图放不下时可以调整图的大小使图和图题放下或将图放置在下一页的页首处。
校园机器视觉实训报告
一、引言随着人工智能技术的飞速发展,机器视觉技术在各个领域得到了广泛应用。
为了提高学生的实践能力,我校特开设了校园机器视觉实训课程。
通过本课程的学习,学生能够掌握机器视觉的基本原理、系统搭建、图像处理方法以及在实际应用中的操作技巧。
以下是本次实训的报告。
二、实训内容1. 机器视觉系统搭建本次实训首先进行了机器视觉系统的搭建,包括硬件和软件两部分。
硬件部分主要包括:工业相机、光源、镜头、图像采集卡、计算机等。
软件部分主要包括:图像采集软件、图像处理软件、机器视觉开发平台等。
2. 图像采集与处理在搭建好机器视觉系统后,我们进行了图像采集与处理实验。
具体步骤如下:(1)打开图像采集软件,设置相机参数,如分辨率、帧率等。
(2)调整光源,确保光线均匀照射到被测物体上。
(3)调整镜头焦距,使被测物体清晰。
(4)通过图像采集卡将相机采集到的图像传输到计算机。
(5)使用图像处理软件对采集到的图像进行处理,如灰度化、滤波、边缘检测等。
3. 目标识别与定位在图像处理的基础上,我们进行了目标识别与定位实验。
具体步骤如下:(1)对图像进行预处理,如去噪、二值化等。
(2)利用特征提取算法(如SIFT、SURF等)提取图像特征。
(3)使用机器学习算法(如KNN、SVM等)对目标进行分类。
(4)根据分类结果,对目标进行定位。
4. 实际应用案例本次实训还选取了实际应用案例,如人脸识别、车牌识别、机器人路径规划等。
通过这些案例,学生能够了解机器视觉技术在现实生活中的应用,并掌握相应的解决方法。
三、实训成果通过本次实训,我们取得了以下成果:1. 掌握了机器视觉系统的搭建方法。
2. 熟悉了图像采集与处理流程。
3. 学会了目标识别与定位方法。
4. 熟悉了机器视觉在实际应用中的解决方案。
四、实训总结1. 机器视觉技术在各个领域具有广泛的应用前景,通过本次实训,学生能够了解并掌握机器视觉的基本原理和应用方法。
2. 实训过程中,学生积极参与,遇到问题能够相互讨论、共同解决,提高了团队合作能力。
课程设计机器视觉报告
目录摘要 (I)Abstract .......................................................................................................................... I I 1.概述 . (3)1.1 机器视觉 (3)1.2 数字图像处理 (3)1.3 MATLAB (4)1.4 课程设计任务 (4)2.边缘检测 (5)2.1边缘检测简介 (5)2.2检测方法 (5)2.3 边缘检测算子 (6)2.4 边缘检测仿真结果 (12)3.轮廓提取 (13)3.1基于边缘检测的轮廓提取 (13)3.2 基于HSV空间H的参数图像的轮廓提取 (14)4.实验小结 (15)参考文献 (15)附录:源程序代码........................................................................ 错误!未定义书签。
边缘检测程序......................................................................... 错误!未定义书签。
轮廓提取程序......................................................................... 错误!未定义书签。
基于HSV空间H参数的图像轮廓提取 ............................... 错误!未定义书签。
摘要机器视觉系统就是利用机器代替人眼来作各种测量和判断。
它是计算机学科的一个重要分支,它综合了光学、机械、电子、计算机软硬件等方面的技术,涉及到计算机、图像处理、模式识别、人工智能、信号处理、光机电一体化等多个领域。
图像处理和模式识别等技术的快速发展,也大大地推动了机器视觉的发展。
机器视觉检测课程设计
机器视觉检测课程设计一、课程目标知识目标:1. 让学生掌握机器视觉检测的基本原理,理解图像处理和特征提取的关键技术。
2. 使学生了解机器视觉检测在不同行业中的应用,如工业自动化、医疗诊断等。
3. 帮助学生掌握至少一种机器视觉编程语言或软件工具,如OpenCV、HALCON等。
技能目标:1. 培养学生运用机器视觉技术解决实际问题的能力,包括图像预处理、特征提取、目标检测等。
2. 提高学生的团队协作和沟通能力,使其能够与他人共同完成复杂的项目任务。
3. 培养学生具备一定的创新能力,能够针对特定问题提出合理的解决方案。
情感态度价值观目标:1. 培养学生对机器视觉检测技术的兴趣和热情,激发其探索未知领域的欲望。
2. 培养学生的责任心,使其认识到机器视觉检测技术在社会发展中的重要作用。
3. 培养学生具备良好的职业道德,遵循法律法规,尊重知识产权,保守商业秘密。
本课程针对高年级学生,结合学科特点和教学要求,将课程目标分解为具体的学习成果。
通过本课程的学习,学生将能够掌握机器视觉检测的基本知识和技能,培养解决实际问题的能力,同时形成积极向上的情感态度和价值观。
为实现这些目标,后续教学设计和评估将围绕这些具体学习成果展开。
二、教学内容本课程教学内容紧密结合课程目标,确保科学性和系统性。
主要包括以下几部分:1. 机器视觉基础理论:涵盖图像处理、图像特征提取、模式识别等基本概念和原理,参考教材相关章节,帮助学生建立扎实的理论基础。
2. 机器视觉硬件设备:介绍摄像头、光源、图像传感器等硬件设备的选择和使用,让学生了解硬件设备在机器视觉检测中的作用。
3. 机器视觉算法与应用:讲解常用的目标检测、图像分割、特征匹配等算法,并结合实际案例进行分析,使学生掌握算法原理及其在实际应用中的优缺点。
4. 机器视觉编程与实战:以教材为基础,教授至少一种机器视觉编程语言或软件工具,如OpenCV、HALCON等,让学生动手实践,提高编程能力。
机器视觉实验报告书
一、实验名称基于机器视觉的物体识别与跟踪系统二、实验目的1. 了解机器视觉的基本原理和常用算法。
2. 掌握图像采集、预处理、特征提取、识别和跟踪的基本方法。
3. 培养动手能力和编程能力,提高实际应用机器视觉技术解决实际问题的能力。
三、实验内容及工作原理1. 实验内容本实验主要包括以下内容:(1)图像采集:使用摄像头采集待识别物体的图像。
(2)图像预处理:对采集到的图像进行灰度化、滤波、二值化等处理,提高图像质量。
(3)特征提取:提取图像中物体的特征,如颜色、形状、纹理等。
(4)物体识别:利用机器学习算法对提取的特征进行分类,实现物体识别。
(5)物体跟踪:根据识别结果,对物体进行实时跟踪。
2. 工作原理(1)图像采集:通过摄像头将物体图像转换为数字图像,然后存储到计算机中。
(2)图像预处理:对图像进行灰度化、滤波、二值化等处理,去除噪声,突出物体特征。
(3)特征提取:根据需要识别的物体类型,选择合适的特征提取方法。
如颜色特征、形状特征、纹理特征等。
(4)物体识别:利用机器学习算法对提取的特征进行分类,实现物体识别。
(5)物体跟踪:根据识别结果,实时更新物体位置,实现物体跟踪。
四、实验步骤1. 准备实验设备:摄像头、计算机、图像采集软件等。
2. 编写图像采集程序:使用OpenCV等图像处理库,实现图像采集功能。
3. 编写图像预处理程序:对采集到的图像进行灰度化、滤波、二值化等处理。
4. 编写特征提取程序:根据需要识别的物体类型,选择合适的特征提取方法。
5. 编写物体识别程序:利用机器学习算法对提取的特征进行分类。
6. 编写物体跟踪程序:根据识别结果,实时更新物体位置。
7. 实验验证:使用实际物体进行实验,验证系统性能。
五、实验结果与分析1. 实验结果本实验成功实现了基于机器视觉的物体识别与跟踪系统。
通过图像采集、预处理、特征提取、识别和跟踪等步骤,系统能够准确识别和跟踪物体。
2. 实验分析(1)图像预处理:图像预处理是提高物体识别准确率的关键步骤。
机器视觉基础课程设计
机器视觉基础课程设计一、课程目标知识目标:1. 理解机器视觉的基本概念,掌握视觉感知系统的组成及其功能;2. 学习图像处理的基本方法,包括图像采集、预处理、特征提取和识别;3. 了解机器视觉在实际应用中的技术发展及其在各领域的应用前景。
技能目标:1. 能够运用图像处理软件进行基本的图像处理操作,如滤波、边缘检测、图像分割等;2. 掌握至少一种编程语言(如Python)进行简单的机器视觉程序编写;3. 能够通过小组合作,设计并实现一个简单的机器视觉应用项目。
情感态度价值观目标:1. 培养学生对机器视觉技术的兴趣,激发其探索未知、创新实践的热情;2. 培养学生的团队协作意识,使其在合作中学会沟通、分享和承担责任;3. 增强学生对我国在机器视觉领域的发展认识,提高民族自豪感。
分析课程性质、学生特点和教学要求,将目标分解为以下具体学习成果:1. 学生能够独立完成图像处理的基本操作,达到熟练程度;2. 学生能够通过编程实现一个简单的图像识别程序,具备初步的编程能力;3. 学生在小组合作中能够积极参与,共同完成一个具有实际意义的机器视觉项目;4. 学生能够积极关注我国在机器视觉领域的发展动态,提高自己的专业素养。
二、教学内容1. 机器视觉概述- 引导学生了解机器视觉的概念、发展历程和应用领域;- 分析机器视觉系统的组成,包括光源、图像传感器、处理算法和执行机构。
2. 图像处理基础- 介绍图像的基本概念,如像素、分辨率、灰度等;- 讲解图像预处理方法,如滤波、增强、边缘检测等;- 指导学生掌握图像分割和特征提取技术。
3. 机器视觉算法- 介绍常用的机器视觉算法,如SIFT、SURF、HOG等;- 分析不同算法的优缺点和适用场景;- 引导学生通过实际案例,理解算法在图像识别中的应用。
4. 编程实践- 教授Python语言的基本语法和图像处理库(如OpenCV)的使用方法;- 制定编程实践任务,如实现目标检测、颜色识别等;- 组织学生进行编程实践,培养其动手能力和解决问题的能力。
机器视觉课程设计
机器视觉课程设计一、教学目标本课程旨在让学生了解和掌握机器视觉的基本概念、原理和应用,培养学生对机器视觉技术的兴趣和认识,提高学生在实际问题中运用机器视觉知识的能力。
知识目标:使学生了解机器视觉的基本原理、技术方法和应用领域;掌握机器视觉系统的基本构成和操作方法。
技能目标:培养学生运用机器视觉知识分析、解决实际问题的能力;训练学生进行机器视觉系统设计和实验的能力。
情感态度价值观目标:激发学生对机器视觉技术的兴趣,培养学生的创新精神和团队合作意识,使学生认识到机器视觉技术在现代社会中的重要作用。
二、教学内容本课程的教学内容主要包括机器视觉的基本概念、图像处理技术、特征提取和匹配、机器视觉系统的设计与应用等。
1.机器视觉基本概念:介绍机器视觉的定义、发展历程和应用领域。
2.图像处理技术:包括图像的数字化、图像增强、边缘检测、图像分割等。
3.特征提取和匹配:介绍特征提取的方法、特征匹配的算法及其应用。
4.机器视觉系统的设计与应用:讲解机器视觉系统的基本构成、工作原理和应用案例。
三、教学方法为了提高教学效果,本课程将采用多种教学方法相结合的方式进行教学。
1.讲授法:通过讲解机器视觉的基本概念、原理和应用,使学生掌握相关知识。
2.讨论法:学生针对实际问题进行讨论,培养学生的思考能力和团队协作精神。
3.案例分析法:分析机器视觉领域的实际案例,使学生更好地理解理论知识。
4.实验法:安排实验室实践环节,让学生动手设计、搭建和调试机器视觉系统。
四、教学资源为了支持本课程的教学,我们将准备以下教学资源:1.教材:《机器视觉导论》等国内外优秀教材。
2.参考书:提供相关领域的经典著作和最新研究成果,供学生拓展阅读。
3.多媒体资料:制作课件、教学视频等,以丰富教学手段,提高教学质量。
4.实验设备:搭建机器视觉实验平台,为学生提供实际操作的机会。
五、教学评估为了全面、客观地评估学生的学习成果,本课程将采用多种评估方式相结合的方法。
机器视觉培训课程设计
机器视觉培训课程设计一、课程目标知识目标:1. 让学生理解机器视觉的基本概念,掌握视觉传感器的工作原理;2. 学会使用机器视觉相关软件进行图像处理和数据分析;3. 掌握机器视觉技术在工业、医疗、农业等领域的应用。
技能目标:1. 培养学生运用机器视觉技术解决实际问题的能力;2. 提高学生团队协作、沟通表达的能力;3. 培养学生自主学习和创新能力。
情感态度价值观目标:1. 激发学生对机器视觉技术的研究兴趣,培养其探索精神;2. 增强学生对我国科技创新成果的自豪感,培养其社会责任感;3. 引导学生树立正确的价值观,认识到科技发展应服务于人类福祉。
课程性质:本课程为选修课,旨在拓展学生的知识视野,提高其创新实践能力。
学生特点:学生具备一定的编程基础和图像处理知识,对新兴技术充满好奇心。
教学要求:结合实际案例,注重理论与实践相结合,培养学生的动手操作能力和实际问题解决能力。
通过分组讨论、成果展示等形式,提高学生的沟通表达和团队协作能力。
在教学过程中,关注学生的个体差异,激发其学习兴趣,引导其树立正确的价值观。
将课程目标分解为具体的学习成果,以便于教学设计和评估。
二、教学内容1. 机器视觉基础理论:- 视觉传感器原理与种类- 图像处理基础:图像采集、预处理、特征提取- 机器视觉系统组成与工作流程2. 机器视觉软件应用:- 常用机器视觉软件介绍:OpenCV、HALCON等- 图像处理与分析操作:边缘检测、图像分割、目标识别等- 数据处理与结果输出3. 机器视觉技术与应用:- 工业领域:自动化检测、装配、包装等- 医疗领域:细胞识别、病理诊断等- 农业领域:果实分级、病虫害检测等4. 实践项目与案例分析:- 设计实际项目,让学生动手实践,巩固所学知识- 分析典型案例,了解机器视觉技术在各领域的应用现状和发展趋势教学内容安排与进度:- 第1周:机器视觉基础理论- 第2周:机器视觉软件应用- 第3周:机器视觉技术与应用- 第4周:实践项目与案例分析教材章节关联:- 《机器人视觉基础》第1章、第2章、第3章- 《机器视觉技术与应用》第4章、第5章、第6章教学内容确保科学性和系统性,结合课程目标,注重理论与实践相结合,培养学生的实际操作能力。
机器人视觉建模课程设计
机器人视觉建模课程设计一、课程目标知识目标:1. 学生能理解机器人视觉建模的基本原理,掌握视觉感知、图像处理和模式识别的基础知识。
2. 学生能描述至少三种常用的机器人视觉算法,并了解其适用场景和优缺点。
3. 学生能解释视觉建模在机器人导航、识别和交互中的应用。
技能目标:1. 学生能运用所学的视觉建模知识,独立操作相关软件和硬件,完成简单的机器人视觉系统搭建。
2. 学生能通过实践,掌握图像采集、预处理、特征提取和对象识别的基本技能。
3. 学生能设计并实施简单的视觉算法,解决特定问题,如路径规划、目标跟踪等。
情感态度价值观目标:1. 学生培养对机器人视觉技术的兴趣,激发探究精神,形成主动学习的态度。
2. 学生通过团队合作,培养沟通协作能力,增强团队意识。
3. 学生意识到机器人视觉技术在实际应用中的价值,认识到科技对社会发展的积极影响,树立正确的科技观。
本课程针对高中年级学生设计,结合学生好奇心强、动手能力逐步提高的特点,注重理论与实践相结合。
课程旨在帮助学生构建扎实的视觉建模知识体系,培养实际操作能力,同时激发学生的创新意识和团队精神,为未来进一步学习相关领域知识打下坚实基础。
二、教学内容本课程教学内容主要包括以下几部分:1. 视觉建模基础理论:- 图像基础知识:图像的表示、色彩空间、图像变换等。
- 视觉感知原理:视觉感知过程、视觉注意力、视错觉等。
2. 图像处理技术:- 图像预处理:滤波、增强、边缘检测等。
- 特征提取:角点、边缘、纹理、形状等特征提取方法。
3. 模式识别与机器学习:- 模式识别基础:贝叶斯分类器、支持向量机、决策树等。
- 机器学习应用:深度学习、卷积神经网络等。
4. 机器人视觉应用:- 视觉导航:路径规划、避障、定位等。
- 对象识别:目标检测、跟踪、分类等。
5. 实践项目:- 使用开源软件和硬件平台,如OpenCV、ROS等,进行视觉系统搭建和算法实现。
- 实际案例分析和操作,如人脸识别、自动驾驶等。
机器视觉培育课程设计
机器视觉培育课程设计一、课程目标知识目标:1. 学生能理解机器视觉的基本概念,掌握视觉感知系统的组成及工作原理。
2. 学生能描述常见的图像处理技术,如边缘检测、特征提取等,并了解其在实际应用中的优势与局限。
3. 学生能掌握一种机器视觉编程语言或软件工具,如OpenCV,并运用其进行简单的图像处理和识别。
技能目标:1. 学生能够运用所学的机器视觉知识,独立完成图像的采集、处理和解析任务。
2. 学生能够通过实践操作,培养解决实际视觉问题的能力,如物体识别、场景重建等。
3. 学生能够结合其他学科知识,开展跨学科项目,提高创新能力和团队协作能力。
情感态度价值观目标:1. 学生能够认识到机器视觉在科技发展中的重要性,激发对人工智能技术的兴趣和热情。
2. 学生能够通过课程学习,培养勇于探索、积极进取的精神风貌,增强自信心。
3. 学生能够关注机器视觉在现实生活中的应用,关注科技发展对社会进步的推动作用,树立正确的价值观。
课程性质:本课程为选修课,以实践性、应用性为主,注重培养学生的实际操作能力和跨学科创新能力。
学生特点:学生为高中生,具备一定的物理、数学和计算机基础,对新鲜事物充满好奇,具备较强的动手能力和探究精神。
教学要求:教师应结合学生特点,注重理论与实践相结合,鼓励学生积极参与实践操作,培养其解决问题的能力和团队合作精神。
同时,关注学生的情感态度价值观培养,引导他们关注科技发展,树立正确的价值观。
通过分解课程目标为具体的学习成果,为教学设计和评估提供依据。
二、教学内容1. 机器视觉基本概念:介绍机器视觉的定义、应用领域及发展历程,结合课本第二章内容,让学生对机器视觉有全面的认识。
- 图像感知与表示- 视觉系统组成与工作原理2. 图像处理技术:讲解图像处理的基本方法,结合课本第三章内容,使学生掌握图像处理的基本技巧。
- 图像预处理(滤波、增强等)- 边缘检测(Sobel、Canny算法等)- 特征提取(Hough变换、特征点检测等)3. 机器视觉编程语言与工具:学习OpenCV库的基本使用方法,结合课本第四章内容,让学生掌握一种机器视觉编程工具。
机器视觉训练课程设计
机器视觉训练课程设计一、课程目标知识目标:1. 让学生理解机器视觉的基本概念,掌握视觉感知在机器人技术应用中的作用和重要性。
2. 学会运用图像处理的基本方法,如滤波、边缘检测和特征提取等,对图像进行分析和理解。
3. 掌握机器学习的基本原理,并运用到视觉识别算法中,实现对物体分类和检测。
技能目标:1. 能够运用编程软件和视觉处理库,完成简单的图像处理和机器视觉任务。
2. 培养学生的团队协作能力,通过项目实践,学会与团队成员沟通、分工和协作。
3. 培养学生的问题解决能力,使学生能够针对实际问题,提出合理的视觉解决方案。
情感态度价值观目标:1. 培养学生对人工智能和机器人技术的兴趣,激发学生的学习热情和创新意识。
2. 增强学生的信息意识,让他们认识到机器视觉在现实生活中的广泛应用和价值。
3. 引导学生树立正确的价值观,了解机器视觉技术对社会发展和人类生活的积极影响。
本课程针对高中年级学生,结合课程性质、学生特点和教学要求,将课程目标分解为具体的学习成果。
在教学过程中,注重理论与实践相结合,以项目为导向,让学生在动手实践中掌握机器视觉的相关知识,提高解决实际问题的能力。
通过本课程的学习,为学生未来在人工智能领域的发展奠定基础。
二、教学内容本课程依据课程目标,科学系统地组织以下教学内容:1. 机器视觉基础理论:包括视觉感知、图像处理和机器学习等基本概念,涉及课本第二章相关内容。
2. 图像处理技术:滤波、边缘检测、特征提取等基本方法,对应课本第三章内容。
3. 机器视觉算法:介绍常用的视觉识别算法,如支持向量机、神经网络等,结合课本第四章相关内容。
4. 实践项目:设计具有实际意义的机器视觉项目,如人脸识别、物体检测等,涵盖课本第五章实例。
教学内容安排和进度如下:第一周:机器视觉基础理论,图像处理技术;第二周:机器视觉算法,实践项目一;第三周:实践项目二,讨论与改进;第四周:总结与展示,成果评价。
本教学内容注重理论与实践相结合,确保学生在掌握基本知识的同时,能够通过实践项目锻炼实际操作能力。
关于机器视觉实验报告
一、实验背景随着计算机技术的发展,机器视觉技术已经成为人工智能领域的一个重要分支。
机器视觉通过模拟人类视觉感知,利用计算机对图像或视频进行分析、处理和理解,从而实现对物体、场景的识别和检测。
本实验旨在通过实际操作,了解机器视觉的基本原理、技术方法和应用领域,并掌握相关软件的使用。
二、实验目的1. 理解机器视觉的基本概念和原理;2. 掌握图像采集、处理、特征提取和识别的基本方法;3. 学习并运用相关软件进行图像分析和处理;4. 了解机器视觉在各个领域的应用。
三、实验内容1. 实验一:图像采集与预处理(1)实验目的:掌握图像采集方法和预处理技术。
(2)实验步骤:1)使用摄像头采集图像;2)对采集到的图像进行灰度化、滤波、边缘检测等预处理操作;3)观察预处理效果,分析预处理对图像质量的影响。
2. 实验二:图像特征提取(1)实验目的:学习并掌握图像特征提取方法。
(2)实验步骤:1)选择合适的特征提取方法,如HOG(Histogram of Oriented Gradients)、SIFT(Scale-Invariant Feature Transform)等;2)对预处理后的图像进行特征提取;3)观察提取到的特征,分析特征对识别效果的影响。
3. 实验三:图像识别与分类(1)实验目的:学习并掌握图像识别与分类方法。
(2)实验步骤:1)选择合适的分类器,如支持向量机(SVM)、K近邻(KNN)等;2)对提取到的特征进行分类;3)观察分类结果,分析分类器的性能。
4. 实验四:机器视觉在人脸识别中的应用(1)实验目的:了解机器视觉在人脸识别领域的应用。
(2)实验步骤:1)采集人脸图像;2)对人脸图像进行预处理、特征提取和识别;3)观察识别结果,分析人脸识别系统的性能。
四、实验结果与分析1. 实验一:图像预处理通过对图像进行灰度化、滤波和边缘检测等预处理操作,可以有效提高图像质量,减少噪声对后续处理的影响。
实验结果表明,预处理后的图像质量得到了明显改善。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
机器视觉课程设计对圆盘形零件圆心与直径和矩形零件长与宽尺寸测量学生学院机电学院专业班级学号学生指导教师2015年 1 月 20 日目录1 问题描述 (5)1.1 基本目标 (5)1.2 基本要求 (5)2 程序及其算法 (5)2.1 检测与计算圆半径的程序 (5)2.2 检测与计算矩形长和宽的程序 (8)2.2.1 打开摄像头程序 (8)2.2.2 保存拍摄的照片程序 (9)2.2.3 读取拍摄到的图片(读取文名字CurrentImage.jpg的图片) (9)2.2.4 检测边上的点和计算长和高的函数 (9)2.2.5 老师写的显示图片的函数 (13)3 运行结果 (14)4 小结 (15)1 问题描述1.1 基本目标显示一图片(包含一个矩形或一个圆),测量矩形的长宽或圆的直径。
完成得及格分,扩展有加分!1.2 基本要求“机器视觉”考试结果要求独立在计算机上完成,建议使用Visual C++和OpenCV 实现一个具有视觉捕捉、图像显示、尺寸测量等功能的对话框程序,其中必须完成对圆盘形零件圆心与直径和矩形零件长与宽尺寸测量容。
在教师提供的基本框架程序基础上,修改、补充界面和功能。
2 程序及其算法2.1 检测与计算圆半径的程序思路:从图片中间横扫取点得M_Point[0],M_Point[1](x坐标相加除2的圆心的x 坐标)中间纵向取点得M_Point[2],M_Point[3](y坐标相加除2的圆心的y坐标)圆上四个点到圆心的距离(半径)取平均值,输出为半径。
要求图片显示图片程序如下:double c_DialogTeclarn::f_MakeCircle(double e_dThreshold){if(NULL==m_pIplImageSource){return 0;}//定义变量存图像的宽,高,行像素int q_iWidth=m_pIplImageSource->width;int q_iHeight=m_pIplImageSource->height;int q_iWidthStep=m_pIplImageSource->widthStep;uchar *q_pchDataImage=(uchar *)m_pIplImageSource->imageData;CvPoint M_Point[4]={};//存放检索出的四个点循环检索//01纵扫for(int Cycle_Y=1;Cycle_Y<q_iHeight;Cycle_Y++){if(e_dThreshold>q_pchDataImage[q_iWidth/2+q_iWidthStep*(Cycle_Y-1)]) {M_Point[0].x=q_iWidth/2;M_Point[0].y=Cycle_Y;}}for(int Cycle_Y=q_iHeight;Cycle_Y>1;Cycle_Y--){if(e_dThreshold>q_pchDataImage[q_iWidth/2+q_iWidthStep*(Cycle_Y-1)]) {M_Point[1].x=q_iWidth/2;M_Point[1].y=Cycle_Y;}}for(int Cycle_X=1;Cycle_X<q_iWidth;Cycle_X++){if(e_dThreshold>q_pchDataImage[Cycle_X+q_iWidthStep*(q_iHeight/2-1)]) {M_Point[2].x=Cycle_X;M_Point[2].y=q_iHeight/2;}}for(int Cycle_X=q_iWidth;Cycle_X>1;Cycle_X--){if(e_dThreshold>q_pchDataImage[Cycle_X+q_iWidthStep*(q_iHeight/2-1)]) {M_Point[3].x=Cycle_X;M_Point[3].y=q_iHeight/2;}}for (int i=0;i<4;i++)//画边界圆{cvCircle(m_pIplImageSource,M_Point[i],8,cvScalarAll(127),2);}int Ridius=0,clear=0;int circle_y=abs(M_Point[1].y+M_Point[0].y)/2;int circle_x=abs(M_Point[3].x+M_Point[2].x)/2;float c=0,j=0;for (int i=0;i<4;i++){j=(M_Point[i].x-circle_x)*(M_Point[i].x-circle_x)+(M_Point[i].y-circle_y )*(M_Point[i].y-circle_y);c=c+sqrt(j);}Ridius=c/4;//在窗口中显示长和高char ch1[10],ch2[10];itoa(Ridius,ch1,10);itoa(clear,ch2,10);SetDlgItemText(IDC_LONG,ch1);SetDlgItemText(IDC_SHORT,ch2);CWnd *e_pCWndPicture=this->GetDlgItem(ID_PICTURE_DISPLAY);f_ControlShowImage(m_pIplImageDisplay,e_pCWndPicture,m_pIplImageSource);cvSaveImage(_T(".//Result_Image.jpg"),m_pIplImageSource);return 0;}2.2 检测与计算矩形长和宽的程序思路:这个程序主要包括:打开摄像头---保存图片(拍照)---加载刚刚保存的图片---找出点并计算长和高四个按钮,每一个按钮包含下面的一段代码,拍摄的图片保存为CurrentImage.jpg,这里事先保存了一同名的图片,所以可以直接点击Load Image 读取。
2.2.1 打开摄像头程序void c_DialogTeclarn::OnBnClickedButton OpenCamera(){CvCapture *q_pCvCapture=cvCreateCameraCapture(0);if(NULL==q_pCvCapture){return;}IplImage *q_pIplImageCapture=cvQueryFrame(q_pCvCapture);if(NULL==q_pIplImageCapture){return;}if(NULL!=m_pIplImageSource){cvReleaseImage(&m_pIplImageSource);m_pIplImageSource=NULL;}m_pIplImageSource=cvCloneImage(q_pIplImageCapture);cvReleaseCapture(&q_pCvCapture);CWnd *e_pCWndPicture=this->GetDlgItem(ID_PICTURE_DISPLAY);f_ControlShowImage(m_pIplImageDisplay,e_pCWndPicture,m_pIplImageSource);}注:绿色的为检测是否成功打开摄像头,蓝色的是读取摄像头拍摄的图片到存,后面的语句是让图片在mfc窗口显示出来。
2.2.2 保存拍摄的照片程序void c_DialogTeclarn::OnBnClickedButton SaveImage(){// TODO: 在此添加控件通知处理程序代码cvSaveImage(_T(".//CurrentImage.jpg"),m_pIplImageSource);}2.2.3 读取拍摄到的图片(读取文名字CurrentImage.jpg的图片)void c_DialogTeclarn::OnBnClickedButton LoadImage(){// TODO: 在此添加控件通知处理程序代码if(NULL!=m_pIplImageSource){cvReleaseImage(&m_pIplImageSource);m_pIplImageSource=NULL;}m_pIplImageSource=cvLoadImage(_T(".//CurrentImage.jpg"),0);CWnd *e_pCWndPicture=this->GetDlgItem(ID_PICTURE_DISPLAY);f_ControlShowImage(m_pIplImageDisplay,e_pCWndPicture,m_pIplImageSource);}2.2.4 检测边上的点和计算长和高的函数思路是:第一步找到边上的点,设定一个变量e_dThreshold值为127,通过循环让它与每一个像素的像素值进行比较。
如果检测到一个点的像素值比127小,则这个点可能就是需要的点(黑色=0,白色=255)如果每个像素都要比较运算太多,所以上边两个点的检测是沿着图片长的的2/5分处和3/5分处向下检测,下边的点是沿着1/2处向上检测。
第二步是用找到6个点的坐标算出三角形的面积,然后除以底边边长得到高。
求三角形的面积用的是行列式的值等于三角形面积的2倍程序如下:double c_DialogTeclarn::f_MakeRectangleWidth(double e_dThreshold){// TODO: 在此添加控件通知处理程序代码//定义一些点和变量int q_iWidth=m_pIplImageSource->width;int q_iHeight=m_pIplImageSource->height;int q_iWidthStep=m_pIplImageSource->widthStep;uchar *q_pchDataImage=(uchar *)m_pIplImageSource->imageData;int q_iXLeftTop=2*q_iWidth/5;int q_iXRightTop=3*q_iWidth/5;int q_iXBottom=q_iWidth/2;int q_iYLeftTop=2*q_iHeight/5;int q_iYLeftBottom=3*q_iHeight/5;int q_iYRightMid=q_iHeight/2;CvPoint q_CvPointLeftTop,q_CvPointRightTop,q_CvPointBottom;CvPoint q_CvPointLeft_Top,q_CvPointRight_Mid,q_CvLeft_Bottom;//求上下两边上的点,3个循环for(int q_iCycleHeight=0;q_iCycleHeight<q_iHeight;q_iCycleHeight++){if(e_dThreshold>q_pchDataImage[q_iCycleHeight*q_iWidthStep+q_iXLeftTop]){q_CvPointLeftTop.x=q_iXLeftTop;q_CvPointLeftTop.y=q_iCycleHeight;break;}}for(int q_iCycleHeight=0;q_iCycleHeight<q_iHeight;q_iCycleHeight++){if(e_dThreshold>q_pchDataImage[q_iCycleHeight*q_iWidthStep+q_iXRightTop]){q_CvPointRightTop.x=q_iXRightTop;q_CvPointRightTop.y=q_iCycleHeight;break;}}for(int q_iCycleHeight=q_iHeight-1;q_iCycleHeight>=0;q_iCycleHeight--){if(e_dThreshold>q_pchDataImage[q_iCycleHeight*q_iWidthStep+q_iXBottom]){q_CvPointBottom.x=q_iXBottom;q_CvPointBottom.y=q_iCycleHeight;break;}}//求左右两边上的点,3个循环for(int q_iCycleWidth=0;q_iCycleWidth<q_iHeight;q_iCycleWidth++){if(e_dThreshold>q_pchDataImage[q_iCycleWidth+q_iWidthStep*(q_iYLeftTop-1)]){q_CvPointLeft_Top.x=q_iCycleWidth;q_CvPointLeft_Top.y=q_iYLeftTop;break;}}for(int q_iCycleWidth=0;q_iCycleWidth<q_iHeight;q_iCycleWidth++){if(e_dThreshold>q_pchDataImage[q_iCycleWidth+q_iWidthStep*(q_iYLeftBottom-1)]) {q_CvLeft_Bottom.x=q_iCycleWidth;q_CvLeft_Bottom.y=q_iYLeftBottom;break;}}for(int q_iCycleWidth=q_iHeight-1;q_iCycleWidth>=0;q_iCycleWidth--){if(e_dThreshold>q_pchDataImage[q_iCycleWidth+q_iWidthStep*(q_iYRightMid-1)]) {q_CvPointRight_Mid.x=q_iCycleWidth;q_CvPointRight_Mid.y=q_iYRightMid;break;}}//在检测到的点上画圆,只是为了更好看到找点的情况cv Circle(m_pIplImageSource,q_CvPointLeftTop,5,cvScalarAll(127),2);cvCircle(m_pIplImageSource,q_CvPointRightTop,5,cvScalarAll(127),2);cvCircle(m_pIplImageSource,q_CvPointBottom,5,cvScalarAll(127),2);cvCircle(m_pIplImageSource,q_CvPointLeft_Top,5,cvScalarAll(127),2);cvCircle(m_pIplImageSource,q_CvLeft_Bottom,5,cvScalarAll(127),2);cvCircle(m_pIplImageSource,q_CvPointRight_Mid,5,cvScalarAll(127),2);//显示画圆后的图片CWnd *e_pCWndPicture=this->GetDlgItem(ID_PICTURE_DISPLAY);f_Control ShowImage(m_pIplImageDisplay,e_pCWndPicture,m_pIplImageSource);//计算长和高的像素值,三角形3点的坐标构成行列式,行列式的值=2*面积,行列式的值/底边=高CvMat Ma;int HIGH,WIDE;float Area;int a=q_CvPointLeftTop.x-q_CvPointRightTop.x;int b=q_CvPointLeftTop.y-q_CvPointRightTop.y;double c=a*a+b*b;//定义行列式doublearr[9]={q_CvPointLeftTop.x,q_CvPointLeftTop.y,1,q_CvPointRightTop.x,q_CvPointRightTop.y,1,q_CvPointBottom.x,q_CvPointBottom.y,1};cvInitMatHeader(&Ma,3,3,CV_64FC1,arr);Area=abs(cvDet(&Ma));HIGH=Area/sqrt(c);int A=q_CvPointLeft_Top.x-q_CvLeft_Bottom.x;int B=q_CvPointLeft_Top.y-q_CvLeft_Bottom.y;double C=A*A+B*B;//定义行列式DoubleARR[9]={q_CvPointLeft_Top.x,q_CvPointLeft_Top.y,1,q_CvLeft_Bottom.x,q_CvLeft_Bottom.y,1,q_ CvPointRight_Mid.x,q_CvPointRight_Mid.y,1};cvInitMatHeader(&Ma,3,3,CV_64FC1,ARR);Area=abs(cvDet(&Ma));WIDE=Area/sqrt(C);//在窗口中显示长和高char ch1[10],ch2[10];itoa(HIGH,ch1,10);itoa(WIDE,ch2,10);SetDlgItemText(IDC_LONG,ch1);SetDlgItemText(IDC_SHORT,ch2);cvSaveImage(_T(".//Result_Image.jpg"),m_pIplImageSource);return 0;}//调用上面的函数进行检测点和计算长和高的值,点击第四个按钮会调用这段程序,当里面的函数调用时,它会调用上面那段函数void c_DialogTeclarn::OnBnClickedButton Rectangle(){// TODO: 在此添加控件通知处理程序代码f_MakeRectangleWidth();}2.2.5 老师写的显示图片的函数void c_DialogTeclarn::f_ControlShowImage(IplImage *&e_pIplImageShow,CWnd *e_pCWndControl, IplImage *e_pIplImageSource){if((NULL==e_pCWndControl)||(NULL==e_pIplImageSource)){return;}CRect q_CRectControl;e_pCWndControl->GetClientRect(&q_CRectControl);if(NULL!=e_pIplImageShow){cvReleaseImage(&e_pIplImageShow);e_pIplImageShow=NULL;}e_pIplImageShow=cvCreateImage(cvSize(q_CRectControl.Width(),q_CRectControl.Height()), IPL_DEPTH_8U,e_pIplImageSource->nChannels);cvResize(e_pIplImageSource,e_pIplImageShow);HDC q_HDCControl=e_pCWndControl->GetDC()->GetSafeHdc();unsigned int q_piBuffer[sizeof(BITMAPINFOHEADER)+sizeof(RGBQUAD)*256];BITMAPINFO *e_pBITMAPINFODisplay=(BITMAPINFO *)q_piBuffer;BITMAPINFOHEADER *e_pBITMAPINFOHEADERDisplay=&(e_pBITMAPINFODisplay->bmiHeader);memset(e_pBITMAPINFOHEADERDisplay,0,sizeof(*e_pBITMAPINFOHEADERDisplay));e_pBITMAPINFOHEADERDisplay->biSize=sizeof(BITMAPINFOHEADER);e_pBITMAPINFOHEADERDisplay->biWidth=e_pIplImageShow->width;e_pBITMAPINFOHEADERDisplay->biHeight=-e_pIplImageShow->height;e_pBITMAPINFOHEADERDisplay->biPlanes=1;e_pBITMAPINFOHEADERDisplay->biBitCount=8*e_pIplImageShow->nChannels; e_pBITMAPINFOHEADERDisplay->biCompression=BI_RGB;RGBQUAD* palette=e_pBITMAPINFODisplay->bmiColors;if(8==e_pBITMAPINFOHEADERDisplay->biBitCount){for(int q_iCycle=0;q_iCycle<256;q_iCycle++){palette[q_iCycle].rgbBlue=(BYTE)q_iCycle;palette[q_iCycle].rgbGreen=(BYTE)q_iCycle;palette[q_iCycle].rgbRed=(BYTE)q_iCycle;palette[q_iCycle].rgbReserved=(BYTE)0;}}StretchDIBits(q_HDCControl,q_CRectControl.left,q_CRectControl.top,e_pIplImageShow->width,e_pIplImageShow->height,q_CRectControl.left,q_CRectControl.top,e_pIplImageShow->width,e_pIplImageShow->height,e_pIplImageShow->imageData,e_pBITMAPINFODisplay,DIB_RGB_COLORS,SRCCOPY);}3 运行结果运行结果图形如下:4 小结通过本次设计,让我很好的锻炼了理论联系实际,与具体项目、课题相结合开发、设计产品的能力。