<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于FPGA的灰度形態(tài)學濾波器實現(xiàn)

          基于FPGA的灰度形態(tài)學濾波器實現(xiàn)

          作者: 時間:2010-12-18 來源:網(wǎng)絡 收藏

            在形態(tài)算法設計中,結(jié)構(gòu)元素的選擇十分重要,其形狀和尺寸的選擇是能否有效地提取信息的關(guān)鍵。一般情況下,結(jié)構(gòu)元素的選擇按照下面原則進行:

            (1)結(jié)構(gòu)元素必須在幾何上比原圖像簡單,且有界。

            (2)結(jié)構(gòu)元素的凸性非常重要,一般選擇凸性子集。

            2 的硬件實現(xiàn)

            2.1 結(jié)構(gòu)元素選擇及簡化[3]

            本文所述形態(tài)學濾波的目的是檢測256×256大小12位灰度圖像f中的弱小目標,選擇3×3大小的扁平結(jié)構(gòu)元素和原始圖像做開操作,其結(jié)構(gòu)為:

            2.2 電路原理設計[4][5]

            輸入圖像f與結(jié)構(gòu)元素g1腐蝕就是求f中每行相鄰3個象素的灰度最小值。對于1幅靜止圖像,可以采用1個1×3的窗體從圖像第1行第1列開始,自左向右滑動,依次取出窗口內(nèi)的3個象素灰度值,比較得到灰度最小值并按順序存儲。第1行做完后,再在第2行滑動,直至圖像的最后1行的最后3個象素。存儲后的圖像即為f與g1腐蝕的結(jié)果圖像。對于實時串行輸入圖像,只需讓圖像灰度數(shù)據(jù)流從1×3的窗體通過,取出窗體內(nèi)的3個象素灰度值,比較后得到的最小值數(shù)據(jù)流就是腐蝕后的圖像灰度數(shù)據(jù)。

            求3個數(shù)的最小值可以先求2個數(shù)的較小值,將結(jié)果再與第3個數(shù)比較即可得到最小值。設計的關(guān)鍵是如何利用第1組數(shù)據(jù)的中間結(jié)果快速完成第2組數(shù)據(jù)的比較。針對圖像是串行輸入流以及內(nèi)部資源足夠豐富的特點,設計了二級流水比較器,其邏輯框圖如圖1所示。圖像第1行第1列的灰度值輸入后鎖存到12位的觸發(fā)器,待第2個數(shù)據(jù)輸入后與之比較,較小值鎖存到中間的12位觸發(fā)器,而第2個數(shù)據(jù)存儲到左邊的12位觸發(fā)器。當?shù)?個數(shù)據(jù)輸入后與前2個數(shù)據(jù)的較小值比較,得到第1組數(shù)據(jù)的最小值,同時第1組數(shù)據(jù)中的第2個值作為第2組數(shù)據(jù)的第1個值,將與第3個數(shù)據(jù)(第2組數(shù)據(jù)的第2個值)比較。這樣,圖像數(shù)據(jù)輸入到1×3腐蝕單元,2個象素周期之后即可得到最小值輸出數(shù)據(jù)流。

            將圖1中的12位鎖存器替換深度為256字節(jié)的FIFO,即可得到1×3腐蝕邏輯框圖。與1×3腐蝕過程類似,f與g1腐蝕的最小值數(shù)據(jù)流輸入到1×3腐蝕單元,2行延遲時間之后即可得到f與g腐蝕的圖像灰度數(shù)據(jù)流。



          關(guān)鍵詞: FPGA 濾波器 灰度形態(tài)學

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();