女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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
    +關注

    關注

    1643

    文章

    21941

    瀏覽量

    613331
  • 圖像處理
    +關注

    關注

    27

    文章

    1323

    瀏覽量

    57634
  • python
    +關注

    關注

    56

    文章

    4823

    瀏覽量

    86050

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

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

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    模糊圖像處理解決方案

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

    FPGA設計經驗之圖像處理

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

    FPGA圖像與視頻處理培訓

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

    【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 ?7798次閱讀
    基于<b class='flag-5'>FPGA</b>灰度<b class='flag-5'>圖像</b><b class='flag-5'>高斯</b>濾波算法的實現

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

    高斯模糊(Gaussian Blur)是一種高斯低通濾波,可以過濾掉圖像的高頻部分,保留低頻部分,對于去除高斯噪聲非常有效果,常常被用于
    發表于 10-26 09:36 ?1212次閱讀
    基于<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 ?732次閱讀

    圖像高斯濾波的原理及FPGA實現思路

    1.概念 高斯分布 圖像濾波之高斯濾波介紹 圖像處理算法|高斯濾波
    的頭像 發表于 12-07 09:12 ?1676次閱讀
    <b class='flag-5'>圖像</b><b class='flag-5'>高斯</b>濾波的原理及<b class='flag-5'>FPGA</b>實現思路