精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

FPGA圖像處理--高斯模糊(二)

FPGA開源工坊 ? 來源:FPGA開源工坊 ? 2023-10-29 16:26 ? 次閱讀

FPGA圖像處理--高斯模糊(一)中介紹了怎么使用Python生成高斯模糊需要使用的高斯核,在這個文章中就介紹一下怎么在FPGA中完成高斯模糊。

首先我們使用Python生成一個高斯模糊的參考模型,代碼如下:

import cv2 as cv
import numpy as np


img_path = "./sim/img/img.png"
img = cv.imread(img_path)
img_gray = cv.cvtColor(img, cv.COLOR_RGB2GRAY)
h, w = img_gray.shape
# kernel_1d = cv.getGaussianKernel(3, 0.8, ktype=cv.CV_32F)
# kernel_2d = kernel_1d * kernel_1d.T
# kernel_2d = kernel_2d * (1 / kernel_2d[0][0])
# print(kernel_2d)
gauss_kernel = [[1, 2, 1],
                [2, 4, 2],
                [1, 2, 1]]
img_padding = np.zeros((h + 2, w + 2), np.uint8)
img_padding[1:h + 1, 1:w + 1] = img_gray
img_padding[0:1, 1:w + 1] = img_gray[0:1, :]
img_padding[h + 1:h + 2, 1:w + 1] = img_gray[h - 1:h, :]
img_padding[:, 0:1] = img_padding[:, 1:2]
img_padding[:, w + 1:w + 2] = img_padding[:, w:w + 1]
# gauss_img = cv.GaussianBlur(img_gray, (3, 3), 0.8)
gauss_img = np.zeros((h, w), np.uint8)
for i in range(1, h + 1):
    for j in range(1, w + 1):
        gauss_img[i - 1][j - 1] = (img_padding[i - 1][j - 1] * gauss_kernel[0][0] + img_padding[i - 1][j] *
                                   gauss_kernel[0][1] + img_padding[i - 1][j + 1] * gauss_kernel[0][2] + img_padding[i][
                                       j - 1] * gauss_kernel[1][0] + img_padding[i][j] * gauss_kernel[1][1] +
                                   img_padding[i][j + 1] * gauss_kernel[1][2] + img_padding[i + 1][j - 1] *
                                   gauss_kernel[2][0] + img_padding[i + 1][j] * gauss_kernel[2][1] + img_padding[i + 1][
                                       j + 1] * gauss_kernel[2][2]) / 16




def save_file(img, path):
    fp = open(path,'w')
    for i in range(img.shape[0]):
        for j in range(img.shape[1]):
            if i == img.shape[0] - 1 and j == img.shape[1] - 1:
                fp.write(str(img[i][j]))
            else:
                fp.write(str(img[i][j]) + "
")
    fp.close


def img2txt(img, dst):
    f = open(dst,"w")
    for i in range(img.shape[0]):
        for j in range(img.shape[1]):
            if i == img.shape[0] - 1 and j == img.shape[1] - 1:
                f.write(str(img[i][j][0]) + " " + str(img[i][j][1]) + " " + str(img[i][j][2]))
            else:
                f.write(str(img[i][j][0]) + " " + str(img[i][j][1]) + " " + str(img[i][j][2])  + "
")
            
    f.close()


file_path = "./sim/test.txt"
file_path_ref = "./sim/ref.txt"
img2txt(img, file_path)
save_file(gauss_img, file_path_ref)


cv.imshow("lena", img_gray)
cv.imshow("lena_gauss_img", gauss_img)
cv.waitKey()
cv.destroyAllWindows()

在上述代碼中完成了讀取一張圖片,然后進行轉灰度和進行高斯模糊的操作,并將原圖和高斯模糊后圖像數據存到了兩個txt中,用于我們仿真

在FPGA中完成高斯模糊比較簡單,使用以下代碼完成高斯矩陣的乘加。

c2ce1cc8-7632-11ee-939d-92fbcf53809c.png

仿真代碼:

首先使用一個模塊來讀取之前用python生成的原圖數據,用于高斯模糊的激勵。

c2e330f4-7632-11ee-939d-92fbcf53809c.png

然后例化我們寫的高斯模糊模塊

c2f4b6f8-7632-11ee-939d-92fbcf53809c.png

最后將仿真結果保存起來,并且在仿真的時候對dut輸出的結果和參考模型進行比對,如果出現錯誤就停止仿真。

c3051f02-7632-11ee-939d-92fbcf53809c.png

仿真結果如下:

c308de6c-7632-11ee-939d-92fbcf53809c.jpg

在仿真的時候會實時打印DUT和參考模型的結果是否比對成功。因為設置了DUT和參考模型的結果之間的閾值為5,所以當兩者差值在5以內時都會打印sim success。

仿真對比如下:

c3257c5c-7632-11ee-939d-92fbcf53809c.png

c338f8d6-7632-11ee-939d-92fbcf53809c.png


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1626

    文章

    21666

    瀏覽量

    601830
  • 圖像處理
    +關注

    關注

    27

    文章

    1281

    瀏覽量

    56638
  • python
    +關注

    關注

    56

    文章

    4782

    瀏覽量

    84453

原文標題:FPGA圖像處理--高斯模糊(二)

文章出處:【微信號:FPGA開源工坊,微信公眾號:FPGA開源工坊】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    模糊圖像處理解決方案

    造成圖像模糊的原因有很多,且不同原因導致的模糊圖像需要不同的方法來進行處理。##圖像復原
    發表于 06-11 10:24 ?1.1w次閱讀

    FPGA設計經驗之圖像處理

    的; 如何基于FPGA進行統計呢? 1)由于是統計圖像的直方圖,所以一定是統計結果會在圖像經過之后才能產生,因此需要進行緩存; 緩存一:統計后的結果; 緩存:經過統計
    發表于 06-12 16:26

    FPGA圖像與視頻處理培訓

     FPGA圖像與視頻處理培訓課程目標:  1、深入了解JPEG標準和H.264標準協議;  2、掌握FPGA圖像
    發表于 07-16 14:05

    FPGA將3路圖像拼接,什么好算法能模糊拼接處?

    3路sensor采集到的3路圖像FPGA將它們從左至右拼接為1副圖像。這樣,圖像1和圖像2、圖像
    發表于 02-19 10:40

    【NanoPi M2試用體驗】圖像模糊

    `OpenCV有幾個函數,是可以將圖像進行模糊處理的,但其實是幾個濾波的函數。一、medianBlur函數這個函數就是一個中值濾波的函數,但是運行的結果就是把圖像
    發表于 06-19 23:18

    區間模糊高斯型隸屬度函數Matlab仿真的問題

    本帖最后由 wanggy0225 于 2017-2-13 21:53 編輯 我想實現區間模糊高斯型隸屬度函數仿真及matlab程序,下面的程序是計算m的上下隸屬度值的,但其中的P是什么不知道,請大神幫忙解決一下。謝謝
    發表于 02-13 15:50

    基于FPGA圖像平滑處理

    基于FPGA圖像平滑處理AT7_Xilinx開發板(USB3.0+LVDS)資料共享騰訊鏈接:https://share.weiyun.com/5GQyKKc百度網盤鏈接:https
    發表于 07-05 13:51

    FPGA學習案例分享】基于FPGA圖像邊緣檢測例程

    、灰度轉換、值化、高斯濾波、 sobel算法等圖像處理算法,以及FPGA的實現2、 SDRAM高速接口以及
    發表于 11-29 09:52

    薦讀:FPGA設計經驗之圖像處理

    從中流過,完成一個階段的運算之后就直接流入第個階段,不需要把一個計算階段完成后的數據再送回內存中,再讀出來交給下一個階段的運算。這樣就會節省很多時間和功耗。現在用FPGA圖像處理
    發表于 06-08 15:55

    為什么高斯濾波廣泛的應用在圖像處理中?

    為什么高斯濾波廣泛的應用在圖像處理
    發表于 10-09 06:31

    FPGA圖像處理

    FPGA圖像處理
    發表于 12-14 22:29 ?19次下載

    基于梯度方向直方圖與高斯金字塔的車牌模糊漢字識別方法

    ,第一層描述了模糊漢字的細節特征,通過對第一層作平滑處理并向下采樣得到第層,在描述模糊圖像細節特征的基礎上突出主體特征;然后對兩層
    發表于 12-25 10:43 ?0次下載
    基于梯度方向直方圖與<b class='flag-5'>高斯</b>金字塔的車牌<b class='flag-5'>模糊</b>漢字識別方法

    基于FPGA灰度圖像高斯濾波算法的實現

    FPGA仿真篇-使用腳本命令來加速仿真 基于FPGA的HDMI高清顯示借口驅動 基于FPGA灰度圖像
    發表于 02-20 20:49 ?7597次閱讀
    基于<b class='flag-5'>FPGA</b>灰度<b class='flag-5'>圖像</b><b class='flag-5'>高斯</b>濾波算法的實現

    基于FPGA圖像處理高斯模糊實現

    高斯模糊(Gaussian Blur)是一種高斯低通濾波,可以過濾掉圖像的高頻部分,保留低頻部分,對于去除高斯噪聲非常有效果,常常被用于
    發表于 10-26 09:36 ?741次閱讀
    基于<b class='flag-5'>FPGA</b><b class='flag-5'>圖像</b><b class='flag-5'>處理</b>的<b class='flag-5'>高斯</b><b class='flag-5'>模糊</b>實現

    高斯卷積核函數在圖像采樣中的意義

    。這種平滑處理通過減小圖像中像素之間的差異來模糊圖像,有助于去除圖像中的高頻噪聲和細節紋理,使圖像
    的頭像 發表于 09-29 09:33 ?310次閱讀