傅里葉變換進行缺陷檢測detect_indent_fft.hdev(源代碼與詳細解析)

文章目錄

    • 簡介
    • 程序解析
    • 處理結果預覽
    • 算法講解

簡介

detect_indent_fft.hdev是halcon的示例程序,是傅里葉變換進行缺陷檢測的一個例子,主要是傅里葉變換在復雜背景下的缺陷檢測

這個程序展示了如何利用快速傅里葉變換(FFT)對塑料制品的表面進行缺陷檢測,大致分為三步:

1、用高斯濾波器構造一個合適的濾波器(將原圖通過高斯濾波器濾波);

2、將原圖和構造的濾波器進行快速傅里葉變換;

3、利用形態學進行缺陷檢測。

程序解析

關于顯示類函數解釋https://blog.csdn.net/cashmood/article/details/93999690
dev_updata_off()

dev_close_window() //關閉活動的圖像窗口
讀入圖片
read_image(Image,’plastics/plastics_01’)
獲取圖片的長寬
//參數說明:讀入的圖片(Image); 圖片的寬(Width);圖片的高(Height)
get_image_size(Image,Width,height)

dev_open_window(0,0,Width,Height,’Black’,WindowHandle)
設置顯示字體
set_display_font (WindowHandle,14,’mono’,’ture’,’false’)

dev_set_draw(‘Margin’)

dev_set_line_width(3)

dev_set_color(’red’)

(根據圖像大小進行fft速度最優化)
對指定大小的圖片的fft速度進行優化
//參數說明:圖片大小(Width,Height);優化模式(’standard’);
optimize_rft_speed(Width,Height,’standard’)

(結合兩個高斯濾波器構造一個合適的濾波器)

定義兩個常量
Sigma1 := 10.0 Sigma2 := 3.0

在頻域生成兩個高斯濾波器
//參數說明:生成的高斯濾波器(GaussFilter); 空域中高斯在主方向上的標準差(Sigma); 空域中高斯在正交于主方向的方向上的標準差(Sigma);濾波器主方向的角度(0.0); 濾波器的規范(’none’);直流項在頻域的位置(’rft’);圖片的大小(Width,Height)
gen_gauss_filter(GaussFilter1,Sigma1,Sigma1,0.0,’none’,’rft’,Width,Height)

gen_gauss_filter(GaussFilter2,Sigma2,Sigma2,0.0,’none’,’rft’,Width,Height) //

兩圖片相減生成一個帶通低頻濾波器
//函數原型以及運算公式: sub_image(ImageMinuend, ImageSubtrahend : ImageSub : Mult, Add : )
//g’ := (g1 - g2) * Mult + Add

sub_image(GaussFilter1,GaussFilter2,Filter,1,0) //兩圖片相減(灰度)

(開始進行圖像檢測)
NumImages := 11
for循環從1到NumImages,步長為1
for Index := 1 to NumImages by 1

read_image(Image,’plastics/plastics_’+Index$’02’)

將圖片轉化為灰度圖,第一個參數為原圖
rgb1_to_gray(Image,Image)

*Perform the convolution in the frequency domain
對一幅圖片進行快速傅里葉變換
//參數說明:輸入的圖片(Image);傅里葉變換后輸出的圖片(ImageFFT);變換方向(’to_freq’或’from_freq’);變換因子的規范(’none’);輸出圖片的數據類型(’complex’);圖片的寬(Width)
rft_generic(Image,ImageFFT,’to_freq’,’none’,’complex’,Width)

圖片用一個濾波器在頻域進行卷積運算
//參數說明:輸入的圖片(ImageFFT);頻域濾波器(Filter);運算后輸出的結果
convol_fft(ImageFFT,Filter,ImageConvol) //對圖片用一個濾波器在頻域進行卷積運算

對濾波后的圖片進行快速傅里葉反變換
rft_generic(ImageConcol,ImageFiltered,’from_freq’,’n’,’real’,Width)

用一個矩形掩膜計算像素點的灰度范圍
//參數說明:輸入的圖片(ImageFiltered); 輸出的灰度范圍圖(ImageResult);矩形掩膜大小(10,10)
灰度范圍計算方法:矩形掩膜內的最大灰度值-最小灰度值

gray_range_rect(ImageFiltered,ImageResult,10,10)

求圖片灰度值的最大和最小值和變換范圍
//參數說明:待分析圖片區域(ImageResult); 圖片(ImageResult);被去除的直方圖兩邊像素點所;占總像素數的百分比(0);得到的最小值最大值及灰度值范圍(Min,Max,Range)
min_max_rect(ImageResult,ImageResult,0,Min,Max,Range)//判斷區域內灰度值的最大和最小值

利用全局閾值對圖像進行分割
//參數說明:輸入的圖片(ImageResult);分割后得到的區域(RegionDynThresh);閾值(max([5.55,Max0.8]),255);公式:MinGray <= g <= MaxGray
threshold(ImageResult,RegionDynThresh,max([5.55,Max0.8]),255)//

分割連通域
//參數說明:輸入的區域(RegionDynThresh);分割連通域后的區域(ConnectedRegions)
connection(RegionDynThresh,ConnectedRegions)

根據面積篩選區域
select_shape (ConnectedRegions,SelectedRegions,’area’,’and’,4,99999)

合并區域
union1(SelectedRegions,RegionUnion)

使用圓形元素對區域進行閉運算
closeing_circle(RegionUnion,RegionClosing,10)

分割連通域
connection(RegionClosing,ConnectedRegions1)

根據面積篩選區域
select_shape(ConnectedRegions1,SelectedRegions1,’area’,’and’,10,99999)

計算區域的面積以及中心位置
area_center(SelectedRegions1,Area,Row,Column)

顯示結果

dev_display(Image)

定義一個變量統計區域的個數
//參數說明:在halcon中“||”代表求數組內元素的個數
Number := |Area|

判斷是否存在缺陷區域
if(Number)

如果存在缺陷區域,畫出缺陷區域

	gen_circle_contour_xld(ContCircle,Row,Column,gen_tuple_const(Number,30),gen_tuple_const(Number,0), gen_tuple_const(Number,rad(360)),’positive’,1)ResultMessage := [‘Not OK’,Number + ‘defect(s) found’]Color := [‘red’,’black’]dev_display(ContCircle) else ResultMessage := ‘OK’Color := ‘forest green’

如果不存在缺陷區域,顯示OK
endif

 	 disp_message(WindowHandle,ResultMessage,’window’,12,12,Color,’ture’) if(Index#NumImages)disp_continue_message(WindowHandle,’black’,’ture’)stop()endif

endfor

處理結果預覽

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

算法講解

在實際的表面缺陷檢測系統中,針對的檢測表面很多是具有一定紋理的比如:布匹、皮革、塑料等,針對這一類表面的檢測就不能單純依靠幀差或者背景差來完成,因為背景的紋理不可能和當前圖像的紋理完全相同。因此,本例程的算法通過將圖像變換到頻域進行處理,提取缺陷分量后反變換到時域,獲得缺陷的具體位置。
在本算法中,在一開始就構造了兩個高斯濾波器,高斯濾波器是一種線性平滑濾波器,適用于消除高斯噪聲。濾波器的實質是對信號進行濾波,濾除不需要的部分,得到想要的部分。一個低通的濾波器可以濾除高頻信號,對于圖像來說,噪聲和邊緣往往集中在高頻分量,因此低通能夠降噪,但是也能造成圖像的模糊。
關鍵就是使用兩個低通濾波器,進行相減后構造了一個帶阻濾波器來提取缺陷分量。這就需要保證在實際的待檢測表面中缺陷所處的頻率范圍要和背景以及噪聲有明顯的差異,并且帶阻的頻率選擇要合適。通過帶阻濾波后獲得的頻率成分對背景中的紋理要有明顯的抑制,并且突出缺陷成分,進行傅里葉反變換后重構的圖像就是缺陷圖像,經過簡單的分割就能很容易得到缺陷了。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/254422.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/254422.shtml
英文地址,請注明出處:http://en.pswp.cn/news/254422.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

lua環境搭建

前言 Linux & Mac上安裝 Lua 安裝非常簡單&#xff0c;只需要下載源碼包并在終端解壓編譯即可&#xff0c;本文介紹Linux 系統上&#xff0c;lua5.3.0版本安裝步驟&#xff1a; Linux 系統上安裝 [rootgitlab ~]# mkdir /app/tools/lua -p [rootgitlab ~]# cd /app/tools/l…

八、job管理

查看用法&#xff1a; [rootsuper65 ~]# salt-run -d|grep jobsjobs.active:                      #查看當前執行的job Return a report on all actively running jobs from a job id centric salt-run jobs.activejobs.list_job: salt-run jobs.list_j…

pthread_join/pthread_exit用法實例

函數pthread_join用來等待一個線程的結束。函數原型為&#xff1a;   extern int pthread_join __P ((pthread_t __th, void **__thread_return));   第一個參數為被等待的線程標識符&#xff0c;第二個參數為一個用戶定義的指針&#xff0c;它可以用來存儲被等待線程的返回…

thinkphp5 內置接口開發與使用

最近的一個項目在用tp5&#xff0c;對于tp3都幾乎沒用過的我來說~~~ tp5最好的一點就是對接口的單獨封裝&#xff0c;只要嚴格按照要求一步一步來就可以成功了 開啟命令行&#xff1a;配置環境變量安裝tp5項目cmd進入項目目錄&#xff0c;運行php think&#xff0c;出現如下內容…

Halcon2019軟件安裝教程

文章目錄1、halcon介紹2、安裝halcon-19.11.0.0-windows.exe1、下載halcon-19.11.0.0-windows.exe安裝包2、halcon-19.11.0.0-windows.exe軟件安裝3、驗證Halcon安裝1、halcon介紹 HALCON是德國MVtec公司開發的一套完善的標準的機器視覺算法包&#xff0c;擁有應用廣泛的機器視…

爬蟲常用庫的安裝

請求庫(requests,selenium)、解析庫(beautifulsop)、存儲庫、工具庫等 urelib re 上面這兩個是python自帶的庫 需要自己安裝額庫&#xff1a; (在windows下&#xff0c;使用pip install 命令) requests selenium用來驅動瀏覽器&#xff0c;做自動化測試&#xff0c;一些被js…

Python: 編程遇到的一些問題以及網上解決辦法?

0.Python: TypeError: str does not support the buffer interface,(點我) fp.write(url.encode("utf-8")) 1.Python:object of type Response has no len()&#xff0c;如何解決&#xff1f;(點我) Traceback (most recent call last):File "F:/Python/TD.py&q…

快排簡要介紹

<!DOCTYPE html><html lang"en"><head> <meta charset"UTF-8"> <title>Title</title></head> <body> <script> var arr [6,10,2,9,3,8,11,4,5]; function quickSort(data, start, end) { // 確定要…

在django中使用celery

前言: 針對高延時任務, 直接在一次網絡請求中處理完畢會導致很不好的體驗, celery則可以不阻塞請求后臺處理這些任務, 并且可以使用django的models進行數據庫操作.環境 python models: celery-4.1.1redis-2.10.6django-1.11.7其他: redis-3.2.9macospython3.6創建django工程 dj…

關于pragma pack的用法(一)

一個很重要的參數#pragma pack(n)數據邊界對齊方式:以如下結構為例: struct {char a;WORD b;DWORD c;char d;}在Windows默認結構大小: sizeof(struct) 444416;與 #pragma pack(4)一樣若設為 #pragma pack(1), 則結構大小: sizeof(struct) 12418;若設為 #pragma pack(2), 則…

TCL語言筆記:TCL中的String命令

一、介紹 字符串是 Tcl 中的基本數據類型&#xff0c;所以有大量的字符串操作命令。一個比較重要的問題就是模式匹配&#xff0c;通過模式匹配將字符串與指定的模式&#xff08;格式&#xff09;相匹配來進行字符串的比較、搜索等操作。 二、string命令列表 命 令 說 …

一文學會,膠位偏移、缺膠、斷膠、溢膠檢測

文章目錄檢測任務檢測思路點膠質量檢測代碼及解析圖示處理思路博主寫作不容易&#xff0c;孩子需要您鼓勵 萬水千山總是情 , 先點個贊行不行 檢測任務 點膠檢查檢測以下缺陷&#xff1a; 1.缺少粘合膠的部分&#xff08;斷膠&#xff09; 2.粘合劑過多或過少的部分&#x…

『轉載』hadoop2.x常用端口、定義方法及默認端口

『轉載』hadoop2.x常用端口、定義方法及默認端口1.問題導讀 DataNode的http服務的端口、ipc服務的端口分別是哪個&#xff1f;NameNode的http服務的端口、ipc服務的端口分別是哪個&#xff1f;journalnode的http服務的端口、ipc服務的端口分別是哪個&#xff1f;ResourceManage…

宏定義和內聯函數的學習

宏定義可以提高效率&#xff0c;但是宏不是函數。 預編譯通過代碼復制的方式代替函數調用&#xff0c;省去了諸如函數壓棧等系統過程&#xff0c;從而提高了效率。但是由于宏定義僅僅是代碼替換&#xff0c;所以引起很多問題。#define MAX(a&#xff0c;b) (a) > (b) ? (…

HAProxy介紹及配置文件詳解

一、HAProxy簡介 HAProxy是一個開源的、高性能的、基于TCP和HTTP應用的負載均衡軟件&#xff0c;借助HAProxy可快速、可靠地提供基于TCP和HTTP應用的負載均衡解決方案 二、HAProxy優點 1) 可靠性和穩定性非常好&#xff0c;可以與硬件的F5相媲美2) 最高可以同時維護40000--5000…

unbutu安裝搜狗輸入法【轉載】

安裝支持庫 sudo apt-get install fcitx libssh2-1 如果安裝過程中出現錯誤失敗&#xff0c;運行apt-get -f install 查看支持庫是否安裝成功 dpkg -l | grep fcitx dpkg -l | grep libssh 下載搜狗輸入法 wget "http://pinyin.sogou.com/linux/download.php?flinux&…

深入理解halcon相機標定

目錄相機標定簡介深度說明1、相機標定參數介紹2、標定板詳細介紹問題1&#xff1a;halcon是否只能使用halcon專用的標定板&#xff1f;問題2&#xff1a;halcon標定板如何生成&#xff1f;問題3&#xff1a;halcon標定板如何擺放&#xff0c;拍照數量有無限制&#xff1f;標定步…

halcon模板匹配干擾邊緣消除辦法(最硬核方式)

目錄halcon手繪形狀匹配模板手繪形狀匹配模板主要算子解析draw_nurbs 繪制平滑曲線參數解釋create_shape_model_xld 使用XLD輪廓創建模板參數解釋實例演示與解析實例代碼展示與解析運行過程與處理展示讀入圖像繪制模板使用繪制的XLD創建模板查找模板博主寫作不容易&#xff0c;…

往文件中寫數據--增量

有的功能需要打印日志文件&#xff0c;但是日志文件太多不方便查看&#xff0c;我就把信息輸出到一個TXT文件中了。 下面就是我將要說的&#xff0c;往文件中寫數據&#xff08;增量&#xff09;&#xff0c;代碼很簡單&#xff0c;也可以放在你的代碼中運行一下&#xff1a; /…

SQL Server 數據庫查找重復記錄的幾種方法

http://www.hanyu123.cn/html/c61/6790.html 一、查某一列&#xff08;或多列&#xff09;的重復值。&#xff08;只可以查出重復記錄的值&#xff0c;不能查出整個記錄的信息&#xff09; 例如:查找stuid&#xff0c;stuname重復的記錄&#xff1a; select stuid&#xff0c;s…