detect_mura_defects_blur.hdev例程解析
- this example shows how to detect mura defects
- in blurred images
dev_close_window ()
dev_update_off ()
Path := ‘C:/Users/shang/Desktop/新建文件夹2/Image_’
read_image (Image, Path + ‘01’)
get_image_size (Image, Width, Height)
dev_open_window_fit_size (0, 0, Width, Height, 640, 480, WindowHandle)
set_display_font (WindowHandle, 14, ‘mono’, ‘true’, ‘false’)
dev_set_draw (‘margin’)
dev_set_line_width (3)
dev_set_color (‘red’)
ScaleFactor := 0.4
calculate_lines_gauss_parameters (17, [25,3], Sigma, Low, High)
for f := 1 to 3 by 1
read_image (Image, Path + f$’.2i’)
*decompose3 (Image, R, G, B)
* correct side illumination
*傅里叶变换
rft_generic (Image, ImageFFT, ‘to_freq’, ‘none’, ‘complex’, Width)
*生成高斯滤波器
gen_gauss_filter (ImageGauss, 100, 100, 0, ‘n’, ‘rft’, Width, Height)
*高斯滤波器卷积
convol_fft (ImageFFT, ImageGauss, ImageConvol)
*傅里叶变换
rft_generic (ImageConvol, ImageFFT1, ‘from_freq’, ‘none’, ‘byte’, Width)
*两幅图像做减法运算
sub_image (Image, ImageFFT1, ImageSub, 2, 100)
*将图像ImageSub进行放大观察,ImageZoomed为放大后的图像,ScaleFactor, ScaleFactor为长宽放大加数,
*constant为插值方法。
zoom_image_factor (ImageSub, ImageZoomed, ScaleFactor, ScaleFactor, ‘constant’)
* 获取一幅图的区域,目的为避免边框对lines_gauss的影响。
get_domain (ImageZoomed, Domain)
*腐蚀,
erosion_rectangle1 (Domain, RegionErosion, 7, 7)
*在图像ImageZoomed截取RegionErosion大小图片,存放到变量ImageReduced
reduce_domain (ImageZoomed, RegionErosion, ImageReduced)
*检测图像的线条与宽度。ImageReduced, Lines为输入图像与输出的亚像素线条,
*Sigma为高斯平滑系数, Low为后滞阈值分隔低值, High为前置阈值分割高值,
*'dark’表示 提取图像 中的暗线条, 'true’表示 是否提取线条 宽度, 'gaussian’提取线条的模式,
*gaussian在线条不锐利时使用, 'true’表示添加 能够 提取的接合点。
lines_gauss (ImageReduced, Lines, Sigma, Low, High, ‘dark’, ‘true’, ‘gaussian’, ‘true’)
*生成齐次转换矩阵
hom_mat2d_identity (HomMat2DIdentity)
*添加缩放的齐次转换矩阵,HomMat2DIdentity为输入矩阵,
*1 / ScaleFactor, 1 / ScaleFactor为缩放因数, HomMat2DScale为输出的矩阵。
hom_mat2d_scale_local (HomMat2DIdentity, 1 / ScaleFactor, 1 / ScaleFactor, HomMat2DScale)
*对亚像素直线Lines进行仿射变换。
affine_trans_contour_xld (Lines, Defects, HomMat2DScale)
*
dev_display (Image)
dev_display (Defects)
if (f < 3)
disp_continue_message (WindowHandle, ‘black’, ‘true’)
stop ()
endif
endfor
detect_mura_defects_blur.hdev例程解析相关推荐
- 虚幻4 游戏引擎 C++编程 官网例程解析
虚幻4游戏引擎C++编程官网例程解析 官网例程 源代码 FloatingActor.h FloatingActor.cpp 内容说明 pragma once 头文件 UClass宏 AActor类 P ...
- halcon例程解析:检查饼干的质量——check_hazelnut_wafers
halcon例程解析:检查饼干的质量--check_hazelnut_wafers 1. 效果展示 2. 思路分析 2.1自动阈值分割 2.2 形态学处理 2.3 计算孔洞面积 2.4 计算矩形的形状 ...
- Halcon例程解析——3d_coordinates.hdev
* * Initialize the program dev_close_window () dev_open_window (0, 0, 768, 576, 'black', WindowHandl ...
- 【OAI】部署5GSA独立组网网络切片例程及例程解析
文章目录 摘要 引言 关键技术介绍 5G核心网 核心网网元功能 网络切片 OAI Docker 官方例程详解 整体介绍 具体详解 网络切片架构 部署概览与说明 1-4 1.预先准备 5.部署OAI 5 ...
- espnow 例程解析
1.什么是espnow 短数据传输.无连接的快速通讯技术 2.应用范围智能照明控制 (一). ESPNOW例程. 下面的例程展示了怎样使用ESPNOW 步骤: 1.初始化wifi A.TCP/ip适配 ...
- CC2640R2F学习笔记(二.gpiointerrupt例程解析)
文章目录 前言 一.导入gpiointerrupt工程 二.主要文件功能 三.代码解析 1.main_tirtos.c 2.gpiointerrupt.c 四.实验现象 总结 参考 前言 gpioin ...
- TI TIDM-1001方案与例程解析
本文档目的为将TI的DEMO板方案及其对应例程进行简单解析,分析其程序框架. 一.PWM设置 1.电路为两路LLC交错并联. 2.第一路LLC原边用ePWM1驱动,副边用ePWM2驱动. 3.第二路L ...
- 感应(异步)电机无速度传感器技术—TI例程解析
电机控制系列文章 感应(异步)电机磁场定向控制MATLAB/Simulink建模 感应(异步)电机磁场定向控制电流环PI控制参数设计 感应(异步)电机磁场定向控制速度环PI控制参数设计 感应(异步)电 ...
- TMS28027输出PWM波例程解析
PWM波模块由Time-Base(时基).Counter-Compare(计数器比较).Action-Qualifier(波形发生器).Dead-Band(死区设置).Trip-Zone(错误处理). ...
最新文章
- mysql 安装 注意点
- win10 远程登录 无密码用户
- discuz中,修改admin密码
- 【多线程高并发】jcstress并发测试工具使用教程详解
- expect监控 雏形 scp用法
- Python中xrange和range异同
- git仓库的基本用法
- ADO.Net中DataSete的应用
- python3 第二十五章 - comprehensions(推导式)
- [翻译]jQuery 1.5.1 发布,全面支持IE9
- 计算机基础知识面试题集
- Python+Pid实现车辆速度跟踪
- C++异常处理throw
- HHUOJ 1019 Friendship of Mouse(水题)
- Android Proximity Sensor近距离传感器P-Sensor
- window检测到计算机,Windows检测到一个硬盘问题怎么办
- rpm查询,删除,安装命令详解
- php excel 导出 插件,php不使用插件导出excel
- 关于st25系列NFC标签简单介绍及st25TV系列用于门禁读取时的注意事项总结
- 浅析支付宝钱包支付流程
热门文章
- 采用matlab实现二维码识别_“吉事办”升级2.0版采用人脸识别技术实现注册、登录一步到位...
- 计算机二级excel降水量分值,计算机二级Excel条件格式的8大用法,太全了!
- 关系型数据库与非关系型数据库优缺点
- 聚焦企业安全核心问题 WOT技术峰会再扬风帆
- sysindexes mysql_sysindexes
- 关于枚举类的写法及应用
- make: *** 没有规则可制作目标“check_python_dependencies”......问题解决方法
- 自动化运维批量管理saltstack
- Python Celery和RabbitMQ实战教程
- yii2框架使用的第一天