核酸管外观缺陷检测(一)

1.1应用示例思路

(1) 对核酸管图像进行灰度化、阈值分割和连通域分析;

(2) 筛选出待检测的区域,并对该区域进行变换校正;

(3) 进一步获取待检测的ROI区域,并根据几何特征和阈值条件,来对核酸管外观进行检测;

(4) 将检测结果写入txt文档。

1.2 应用示例代码

复制代码
*统计核酸管外观正常的数组
P_Tuple:=[]
*统计核酸管外观缺陷的数组
N_Tuple:=[]
*判断文件是否存在
file_path:= './核酸管外观缺陷检测统计1.txt'
file_exists (file_path, file_exist)
if (file_exist==1)
    delete_file (file_path)
endif
open_file (file_path, 'output', FileHandle)
*获取文件路径列表
list_files ('./Test_img/', ['files','follow_links'], ImageFiles)
*文件筛选
tuple_regexp_select (ImageFiles, ['\\.(tif|tiff|gif|bmp|jpg|jpeg|jp2|png|pcx|pgm|ppm|pbm|xwd|ima|hobj)$','ignore_case'], ImageFiles)

for Index := 0 to |ImageFiles| - 1 by 1
    img_path:=ImageFiles[Index]
    *img_path:='./Test_img/Image_20230420091226458.bmp'
    *文件名拆分
    parse_filename (img_path, BaseName, Extension, Directory)
    *读取核酸管图片
    read_image (Image, img_path)
    *灰度化
    rgb1_to_gray (Image, GrayImage)
    *阈值分割
    threshold (GrayImage, Region, 30, 145)
    *填充孔洞
    fill_up (Region, RegionFillUp)
    *连通区域分析
    connection (RegionFillUp, ConnectedRegions)
    *获取面积
    area_center (ConnectedRegions, Area, Row, Column)
    *通过面积筛选区域
    select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 500000, 800000)
    *获取区域外接矩形
    smallest_rectangle2 (SelectedRegions, Row1, Column1, Phi, Length1, Length2)
    *创建变换模型
    vector_angle_to_rigid (Row1, Column1, abs(Phi), Row1, Column1, acos(0.0), HomMat2D)
    *进行区域变换
    affine_trans_region (SelectedRegions, RegionAffineTrans, HomMat2D, 'nearest_neighbor')
    *获取区域外接矩形(平行于坐标轴)
    smallest_rectangle1 (RegionAffineTrans, Row11, Column11, Row12, Column12)
    *裁剪区域
    clip_region (RegionAffineTrans, RegionClipped1, Row11, Column12-200, Row12, Column12)
    *获取区域外接矩形(平行于坐标轴)
    smallest_rectangle1 (RegionClipped1, Row21, Column21, Row22, Column22)
    *裁剪区域
    clip_region (RegionClipped1, RegionClipped2, int((Row21+Row22)/2.0)-20, Column12-200, int((Row21+Row22)/2.0)+20, Column12)
    *获取区域外接矩形(平行于坐标轴)
    smallest_rectangle1 (RegionClipped2, Row31, Column31, Row32, Column32) 
    distance:=Column32-Column31
    if(distance>=180)
        dev_clear_window ()
        get_image_size (Image, Width, Height)
        dev_open_window (0, 0, Width/2, Height/2, 'black', WindowHandle)
        dev_display (Image)
        *设置颜色
        dev_set_color ('green')
        *显示字符
        set_tposition (WindowHandle, 10, 5)  //设置文本光标1的位置
        write_string (WindowHandle, '核酸管外观正常!')
        set_tposition (WindowHandle, 50, 5)  //设置文本2光标的位置
        write_string (WindowHandle, ['核酸管外观正常的图片名:',BaseName])
        dev_close_window ()
        P_Tuple:=[P_Tuple,1]
        fwrite_string(FileHandle,[Index,'核酸管外观正常的图片名:',BaseName])
        fnew_line(FileHandle)    
    else
        dev_clear_window ()
        get_image_size (Image, Width, Height)
        dev_open_window (0, 0, Width/2, Height/2, 'black', WindowHandle)
        dev_display (Image)
        *设置颜色
        dev_set_color ('green')
        *显示字符
        set_tposition (WindowHandle, 10, 5)  //设置文本光标1的位置
        write_string (WindowHandle, '核酸管外观有缺陷!')
        set_tposition (WindowHandle, 50, 5)  //设置文本2光标的位置
        write_string (WindowHandle, ['核酸管外观缺陷的图片名:',BaseName])
        dev_close_window ()
        N_Tuple:=[N_Tuple,0]
        fwrite_string(FileHandle,[Index,'核酸管外观缺陷的图片名:',BaseName])
        fnew_line(FileHandle)    
    endif
endfor

tuple_length (P_Tuple, P_Length)
tuple_length (N_Tuple, N_Length)
Yield_Rate:= real(P_Length)/real(N_Length+P_Length)
fwrite_string(FileHandle,['核酸管良品率:',Yield_Rate])
fnew_line(FileHandle)
close_file (FileHandle)

1.3 结果展示

(1) 单张图片检测结果:

(2) 部分图片检测结果:

相关推荐
机器视觉的发动机6 天前
图像处理-机器视觉算法中的数学基础
开发语言·人工智能·算法·决策树·机器学习·视觉检测·机器视觉
机器视觉的发动机21 天前
高效机器视觉软件 CKVision SDK 6.0 产品介绍及应用
自动化·ai编程·机器视觉
光泽雨23 天前
检测阈值 匹配阈值分析 金字塔
图像处理·人工智能·计算机视觉·机器视觉·smart3
机器视觉的发动机24 天前
AI算力中心的能耗挑战与未来破局之路
开发语言·人工智能·自动化·视觉检测·机器视觉
光泽雨25 天前
smart3学习
机器视觉·汇川·smart3
机器视觉的发动机1 个月前
从实验室到工业现场:机器人视觉感知系统的边缘AI架构实战, 深度解析硬件选型、TensorRT量化加速与多传感器融合的极致优化方案
人工智能·机器人·视觉检测·人机交互·机器视觉
机器视觉的发动机1 个月前
特斯拉FSD v14技术解析:端到端神经网络与视觉系统的突破
人工智能·深度学习·神经网络·机器学习·自动化·视觉检测·机器视觉
机器视觉的发动机1 个月前
波士顿动力机器人技术全解析从四足Spot到人形Atlas的机器人革命
大数据·人工智能·深度学习·机器人·视觉检测·机器视觉
机器视觉的发动机1 个月前
大语言模型:从理论起源到技术革命
前端·javascript·自动化·视觉检测·ecmascript·easyui·机器视觉
搞科研的小刘选手1 个月前
【双一流高校主办】第五届光学与机器视觉国际学术会议(ICOMV 2026)
人工智能·计算机视觉·机器视觉·光学·学术会议·控制工程·先进算法