Labview图像处理-2处理方法

彩色数据的存储

Labview将彩色数据以U32类型数组存储,有两种方式:RGB(红绿蓝)和HSL(色彩亮度饱和度)。

将彩色图转换为HSL格式,然后提取亮度平面。亮度平面与灰度图像是完全对应的。并且,它是能够提供灰度图像准确表达的唯一颜色平面。

HSL—Hue SaturationLuminance

RGB—Red Green Blue

存储方式如下:

备用

Red

Green

Blue

备用

Hue

Saturation

Luminance

8bit

8bit

8bit

8bit

灰度图

大多数图像处理算法都是以灰度图为基础。因此,如何得到灰度图很重要,也是首要步骤。

将一幅图转换为灰度图,就是每个像素点由原来的32位的表示方法压缩到8位表示(可能有16位、24位、32位)的算法有多种,由原来的RGB三色的分量,映射到0~255的灰度值,其方法有多种:

Gray=R*0.3+G*0.59+B*0.11

Gray=(R+G+B)/3

……

归根到底是将彩色对应到灰度值上。

在Labview的Vision开发包内,使用这个工具包的函数中需注意一点,即每个图片打开显示之前,都要给其分配一个内存区域,使用的函数为IMAQ Creat,在分配的时候,一个参数Image type需要指定。常规的使用方法是获取文件的类型后,将类型值赋给这个参数,如下图所示,即可读取到一个图片到前面板:


图1 常规读取


图2 常规读取结果

当我们需要灰度图时,很简单,只需将Image type的参数设定为GrayScale(U8)即可。

补充一些概念:

每个像素的颜色用16位二进制数表示,叫做16位图;

每个像素存放在1个Byte中,0~255分别表示不同的灰度,0表示最暗,255最亮,叫做8位图。

灰度图的处理方法(图像点运算)

1.      灰度直方图

统计各像素的灰度值,然后在图中显示出各个灰度值的点数,横坐标为灰度值0~255,纵坐标为个灰度值对应的像素点数,一般用占的百分比表示。

这个算法在Labview的Vision的工具包中是IMAQ Histograph,其中参数 Image mask不输入的时候,表示的整个图。需要某个区域时,可选择IMAQ ROIToMask这个VI。灰度直方图可方便观察每个级别的灰度值有多少个像素点。

2.      线性变换

将灰度值统一的进行放大和缩小。即对每个点进行线性运算。在labview程序中,使用IMAQ ImageToArray获取灰度图的每个像素的灰度值,是一个2D数组,然后对数组进行运算,得到一组新的灰度值。设定Xi是原灰度图第i个点的灰度值,Yi是线性变换过得灰度值,有以下公式

Yi=Xi*k+b

然后将2D灰度值数组还原成图像,使用IMAQ ArrayToImage。输入参数中,根据原图的实际情况,选择是Image Pxies(U8)还是其他参数。

程序框图略。函数参见上文中提到的。

3.      灰度拉伸

灰度拉伸类似于线性变换,区别是映射关系是一个分段函数,类似于下图所示:


图3 灰度拉伸

对分段函数分别求出k和b,进行计算即可。算法程序框图可参见如下:



图4 算法

“拉伸设置”是一个XY图,计算三个段的k、b后,集散新的灰度值,还原图像。处理结果如如下:


图5 灰度拉伸结果

可以概括为,让浅色更浅,深色更深。

4.      灰度均衡

灰度均衡,顾名思义,就是让灰度尽量的分布均匀些,从直方图上直观的看,就是让灰度分布曲线平缓一些。算法如下:

Y=255*(n0+n1+n2+……+ni)/n,i∈[0,X];其中,X为待转换的像素值,n为总像素数,ni为灰度为i的像素个数。程序框图如下:


图6 均衡算法

5.      二值化

二值化是以某一个灰度值为阈值,小于阈值为0,大于阈值为255,由此设定,可将图像进行分割。


图7 二值化结果

二值化后,即可明显的分割图像。


未完待续。。。。。


第一章 概述... 9 第一节 NI LabVIEW & NI Vision简介... 9 第二节 NI各款视觉软件的应用范围... 14 2.1 LabVIEW的应用... 14 2.2 VDM视觉开发模块的应用... 15 2.3 VA视觉助手的应用... 16 2.4 VBAI视觉生成器的应用... 17 2.5 VAS视觉采集软件的应用... 18 第三节 NI软件的兼容性... 19 3.1 LabVIEW与操作系统兼容性... 19 3.2 LabVIEW的生命周期策略... 20 3.2.1 NI LabVIEW 年度发行... 20 3.2.2 NI LabVIEW生命周期策略的各个阶段... 21 3.2.3 NI LabVIEW生命周期策略... 21 3.3 视觉软件的兼容性... 23 第二章 结构框架... 27 第一节 编程风格... 27 第二节 编程框架... 30 第三节 通用图像处理平台项目结构... 39 第四节 通用图像处理平台流程图... 44 第三章 功能函数与主程序... 47 第一节 功能函数与模块... 47 1.1 Camera相机模块... 49 1.1.1 打开相机... 51 1.1.2 设置属性... 53 对照MAX中的属性设置属性... 56 使用.icd文件查看属性... 58 使用枚举属性函数查看属性... 60 读写相机属性文件... 60 1.1.3 读视频模式... 61 1.1.4 写视频模式... 62 1.1.5 配置相机... 63 1.1.6 采集图像... 64 1.1.7 停止相机... 65 1.1.8 关闭相机... 66 1.1.9 大恒相机DLL调用... 67 函数LvGetDeviceTotal 68 函数LvOpenDevice. 69 函数LvAllocateResources. 71 函数LvSetResolution. 73 函数LvSetSnapMode. 75 函数LvSetGain. 78 函数LvGetImageWidth. 81 函数LvGetImageHeight. 83 函数LvSetAOI 83 函数LvSetShutter. 88 函数LvSetADCLevel 91 函数LvSetTimeout. 94 函数LvGrabSingle. 96 函数LvExportImageData. 101 函数LvStartGrab. 102 函数LvStopGrab. 104 函数LvCloseDevice. 106 函数使用简要说明... 108 1.2 Datalog数据记录... 109 1.2.1 Open打开数据库... 110 1.2.2 Write写数据... 111 1.2.3 Search查询数据... 113 1.2.4 Update更新数据... 114 1.2.5 Delete删除数据... 115 1.2.6 Close关闭数据库... 115 1.3 Sub VI子函数... 116 1.3.1 ImageforUse. 117 Create创建图像缓存... 117 Use使用图像... 118 Copy复制图像... 119 Dispose释放图像缓存... 120 1.3.2 帮助... 120 1.3.3 等待(有错误)... 121 1.3.4 读写参数... 122 1.3.5 读写最后机种... 126 1.3.6 仿真采集图像... 129 1.3.7 放大图像算子... 131 1.3.8 缩小图像算子... 132 1.3.9 检查文件夹存在及新建... 133 1.3.10 良率计算... 134 1.3.11 路径(开发与应用环境)... 135 1.3.12 罗列文件-多文件类型... 137 1.3.13 判断数组大小并截取子集... 138 1.3.14 任一范围随机数... 139 1.3.15 首行行号... 140 1.3.16 提示信息... 143 1.3.17 新建文件... 145 第二节 主程序与功能实现... 149 2.1 主程序前面板说明... 151 2.2 主程序初始化... 153 2.2.1 程序执行时的原始初始化... 154 初始化状态提示... 155 初始化主队列... 156 初始化从队列... 156 建立相对路径... 157 前面板全屏运行... 157 访问网页... 159 2.2.2 队列初始化... 160 元素出队列... 161 状态机-初始化... 162 循环控制及状态机控制... 163 状态机-初始化控件... 165 状态机-加载机种参数... 169 状态机-初始化参数... 171 2.3 前面板事件响应... 176 2.3.1 用户登陆/退出事件... 176 2.3.2 设置参数... 185 2.3.3 保存参数... 189 2.3.4 参数另存为... 192 2.3.5 打开参数... 195 2.3.6 运动... 197 2.3.7 连续采集... 198 2.3.8 单帧采集... 201 2.3.9 图像处理... 203 2.3.10 自动运行... 205 2.3.11 缩小图像... 215 2.3.12 放大图像... 215 2.3.13 原始尺寸... 216 2.3.14 适合窗口... 217 2.3.15 保存图像... 218 2.3.16 帮助... 221 2.3.17 最小化... 221 2.3.18 退出程序... 223 2.3.19 访问主页... 225 2.3.20 机种... 226 2.3.21 规格参数... 228 2.3.22 相机参数... 230 2.3.23 运动参数... 232 2.3.24 图像参数... 233 2.3.25 其它参数... 240 2.4 程序退出... 243 2.5 单相机程序框图与双相机程序框图... 246 第四章 图像处理实例... 248 第一节 尺寸测量... 248 1.1 视觉助手生成脚本... 248 1.2 视觉助手生成LabVIEW代码... 250 1.3 生成LabVIEW代码的优化... 251 1.3.1 删除打开图像文件代码... 251 1.3.2 删除Image显示控件调色板类型... 252 1.3.3 删除错误代码判断... 254 1.3.4 删除IVA代码... 255 1.3.5 合并部分函数输入控件... 259 1.3.6 优化输入输出控件... 261 1.4 通用图像处理平台中加载图像处理-clamp函数... 264 1.5 自动运行... 264 第二节 二维码识别... 266 2.1 视觉助手生成脚本... 266 2.2 视觉助手生成LabVIEW代码... 269 2.3 生成LabVIEW代码的优化... 271 2.3.1 删除冗余代码... 271 2.3.2 使用覆盖多段线函数覆盖条码边框... 271 2.3.3 优化输入输出控件... 278 2.4 通用图像处理平台中加载图像处理-QR识别函数... 280 2.5 数据判断... 281 2.5 图像参数... 281 2.6 初始化... 284 2.7 结果保存... 285 2.8 自动运行... 285 第三节 模式匹配... 286 3.1 视觉助手生成脚本... 287 3.2 视觉助手生成LabVIEW代码... 289 3.3 生成LabVIEW代码的优化... 293 3.3.1 删除错误判断代码和IVA存储结果代码... 293 3.3.2 改善模板图像的调用... 294 3.3.3 修改匹配数量... 294 3.3.4 优化输入输出控件... 295 3.4 通用图像处理平台中加载图像处理-模式匹配函数... 298 3.5 添加匹配边框... 303 3.6 ROI赋值... 307 3.7 模板文件的制作... 311 3.7.1 使用NI的Teplate Editor. 311 3.7.2 使用命令提示符调用Template Editor. 312 3.7.3 使用模式匹配库函数学习模板... 323 3.8 自动运行效果... 330 第四节 形状检测-圆... 332 4.1 视觉助手生成脚本... 332 4.2 视觉助手生成LabVIEW代码... 334 4.3 生成LabVIEW代码的优化... 335 4.3.1 删除错误判断代码和IVA存储结果代码... 335 4.3.2 删除打开图片代码... 337 4.3.3 设置图像参数自定义控件... 337 4.3.4 添加圆覆盖... 339 4.4 通过图像处理平台加载图像处理-形状检测查找圆函数... 342 4.5 初始化控件... 343 4.6 图像参数值改变... 343 4.7 ROI赋值... 344 4.8 数据判断... 348 4.9 结果保存... 349 4.10 简单标定... 349 4.11 标定数据标定... 349 4.12 运行效果... 361 第五节 LED编带机方向判断... 362 5.1 视觉助手生成脚本... 363 5.2 视觉助手生成LabVIEW代码... 367 5.3 生成LabVIEW代码的优化... 370 5.3.1 删除错误判断代码... 370 5.3.2 修改ROI 371 5.3.3 改善IVA Measure2函数... 373 5.3.4 坐标系优化与求交点优化... 376 5.3.5 设置图像参数自定义控件... 382 5.3.6 生成最终图像处理子函数... 386 5.4 通过图像处理平台加载图像处理-方向判断函数... 387 5.5 数据判断... 388 5.6 结果保存... 388 5.7 初始化控件... 389 5.8 参数设置... 390 5.8.1 定义左边ROI 391 5.8.2 查找左边... 392 5.8.3 定义顶边ROI 393 5.8.4 查找顶边... 394 5.8.5 定义参考坐标系... 395 5.8.6 定义检测区域... 396 5.8.7 参数设置流程... 396 5.9 自动运行... 401 5.10 执行效率研究... 402 5.11 图像采集、图像处理串行处理... 410 5.11.1 自动运行图像处理... 410 5.11.2 保存数据... 412 5.11.3 存储图像... 413 5.12 改善后自动运行... 413 第六节 OCR字符识别... 416 6.1 视觉助手生成脚本... 417 6.2 视觉助手生成LabVIEW代码... 420 6.3 生成LabVIEW代码的优化... 422 6.3.1 删除错误判断等冗余代码... 422 6.3.2 删除字符集参数设置... 423 6.3.3 覆盖兴趣区域和字符边框区域... 425 6.3.4 改善字符集文件操作... 427 6.4 通过图像处理平台加载字符识别函数... 432 6.5 自定义字符识别ROI 434 6.6 学习字符集文件... 434 6.7 初始化等修改... 436 6.8 自动运行效果... 439 转载 资源来源于网上
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值