问答 店铺
热搜: ZYNQ FPGA discuz

QQ登录

只需一步,快速开始

微信登录

微信扫码,快速开始

微信扫一扫 分享朋友圈

已有 41 人浏览分享

开启左侧

FPGA图像处理-图像二值化腐蚀处理

[复制链接]
41 0
安路-FPGA课程
安路课程: 图像算法 » 图像新手入门实验
安路系列: EG4
本帖最后由 UT发布 于 2025-4-3 09:40 编辑

软件版本:Anlogic -TD5.6.1-64bit
操作系统:WIN10 64bit
硬件平台:适用安路(Anlogic)FPGA
登录米联客”FPGA社区-www.uisrc.com视频课程、答疑解惑!
1概述

本文简述了图像二值化腐蚀处理的算法,讲解如何进行Verilog的算法实现,并进行上板实验。

2算法原理简介

腐蚀操作是形态学图像处理的基础。

腐蚀操作是“收缩”或“细化”二值图像中的物体。以3x3的滑动模板为例,具体操作是当这九个像素点全为白色(1”)时输出白色(“1”),否则输出黑色(“0”)。使用逻辑与运算进行操作,就可以实现腐蚀的效果。算法仿真

3Matlab算法仿真
3.1Matlab算法代码分析

源代码如下:

  1. clear;clear all;clc;
  2. image_in = imread('lena_1280x720.jpg');
  3. [row,col,n] = size(image_in);
  4. image_gray  = rgb2gray(image_in);
  5. image_binary=zeros(row,col);
  6. for i=1:row   
  7.     for j=1:col   
  8.         if image_gray(i,j) > 92   
  9.             image_binary(i,j)=255;   
  10.         else   
  11.             image_binary(i,j)=0;   
  12.         end   
  13.     end   
  14. end  
  15. image_erode_0=zeros(row,col);
  16. for i = 2:1:row-1
  17.     for j = 2:1:col-1
  18.                 image_erode_0(i,j) =...
  19.                 image_binary(i-1,j-1)&image_binary(i-1,j)&image_binary(i-1,j+1)&...
  20.                 image_binary(i,j-1)  &image_binary(i,j)  &image_binary(i,j+1)  &...
  21.                 image_binary(i+1,j-1)&image_binary(i+1,j)&image_binary(i+1,j+1);
  22.     end
  23. end
  24. image_erode_1=zeros(row,col);
  25. for i = 2:1:row-1
  26.     for j = 2:1:col-1
  27.                 image_erode_1(i,j) =...
  28.                 image_erode_0(i-1,j-1)&image_erode_0(i-1,j)&image_erode_0(i-1,j+1)&...
  29.                 image_erode_0(i,j-1)  &image_erode_0(i,j)  &image_erode_0(i,j+1)  &...
  30.                 image_erode_0(i+1,j-1)&image_erode_0(i+1,j)&image_erode_0(i+1,j+1);
  31.     end
  32. end
  33. image_erode_2=zeros(row,col);
  34. for i = 2:1:row-1
  35.     for j = 2:1:col-1
  36.                 image_erode_2(i,j) =...
  37.                 image_erode_1(i-1,j-1)&image_erode_1(i-1,j)&image_erode_1(i-1,j+1)&...
  38.                 image_erode_1(i,j-1)  &image_erode_1(i,j)  &image_erode_1(i,j+1)  &...
  39.                 image_erode_1(i+1,j-1)&image_erode_1(i+1,j)&image_erode_1(i+1,j+1);
  40.     end
  41. end
  42. subplot(321);  
  43. imshow(image_gray); title('the image gray image');
  44. subplot(322);  
  45. imshow(image_binary); title('the image binary image');
  46. subplot(323);  
  47. imshow(image_erode_0); title('the image erode 0 image');
  48. subplot(324);  
  49. imshow(image_erode_1); title('the image erode 1 image');
  50. subplot(325);  
  51. imshow(image_erode_2); title('the image erode 2 image');
复制代码
3.2Matlab实验结果

我们对实验图像进行了二值化操作,然后进行了三次腐蚀操作,每次腐蚀的结果显示在图中,我们可以看到腐蚀的次数越多,白色线条变的越来越细。

image.jpg

3.3Verilog算法仿真
3.3.1Modelsim仿真
3.3.1.1仿真执行

在件夹Algorithm_simulation下进行算法的仿真,分为simsrctb三个子文件夹。在sim文件夹下有win系统的快捷执行文件sim.bat,可以一键进行仿真,src文件下放的是Verilog的核心图像算法及其顶层与输入图像激励,tb文件下放的是测试激励文件及输出图像的保存。

双击执行sim文件夹下sim.bat,自动打开Modelsim仿真,自动添加仿真波形,执行完成后自动保存图像,仿真波形如图所示:

image.jpg
3.3.1.2仿真关键部分代码解析

Sim.do执行仿真代码,文件内容如下:

  1. #
  2. # Create work library
  3. #
  4. vlib work
  5. #
  6. # Compile sources
  7. #
  8. vlog "../src/*.v"
  9. vlog "../tb/*.v"
  10. #
  11. # Call vsim to invoke simulator
  12. #
  13. vsim -voptargs=+acc work.top_tb
  14. #
  15. # Add waves
  16. #
  17. do wave.do
  18. #
  19. # Run simulation
  20. #
  21. run -all
  22. #
  23. # End
复制代码

图像输入代码部分:

  1. reg                 en;
  2. reg [12:0]         h_syn_cnt = 'd0;
  3. reg [12:0]         v_syn_cnt = 'd0;
  4. reg [23:0]         image [0 : H_ACTIVE*V_ACTIVE-1];
  5. reg [31:0]         image_cnt = 'd0;
  6. //读取txt文件到image数组中
  7. initial begin
  8.         $readmemh("../matlab_src/image_720_1280_3.txt", image);
  9. end
  10. // 行扫描计数器
  11. always@(posedge i_clk)
  12. begin
  13.         if(h_syn_cnt == H_TOTAL_TIME-1)
  14.         h_syn_cnt <= 0;
  15.     else
  16.         h_syn_cnt <= h_syn_cnt + 1;
  17. end
  18. // 列扫描计数器
  19. always@(posedge i_clk)
  20. begin
  21.         if(h_syn_cnt == H_TOTAL_TIME-1)
  22.         begin
  23.         if(v_syn_cnt == V_TOTAL_TIME-1)
  24.             v_syn_cnt <= 0;
  25.         else
  26.             v_syn_cnt <= v_syn_cnt + 1;
  27.         end
  28. end
  29. // 行同步控制
  30. always@(posedge i_clk)
  31. begin
  32.     if(h_syn_cnt < H_SYNC_TIME)
  33.         o_hsyn <= 0;
  34.     else
  35.         o_hsyn <= 1;
  36. end
  37. // 场同步控制
  38. always@(posedge i_clk)
  39. begin
  40.     if(v_syn_cnt < V_SYNC_TIME)
  41.         o_vsyn <= 0;
  42.     else
  43.         o_vsyn <= 1;
  44. end
  45. // 坐标使能.
  46. always@(posedge i_clk)
  47. begin
  48.     if(v_syn_cnt >= V_SYNC_TIME + V_BACK_PORCH && v_syn_cnt < V_SYNC_TIME + V_BACK_PORCH + V_ACTIVE)
  49.     begin
  50.         if(h_syn_cnt >= H_SYNC_TIME + H_BACK_PORCH && h_syn_cnt < H_SYNC_TIME + H_BACK_PORCH + H_ACTIVE)
  51.             en <= 1;
  52.         else
  53.             en <= 0;
  54.     end
  55.     else
  56.         en <= 0;
  57. end
  58. always@(posedge i_clk)
  59. begin
  60.     if(en)
  61.         begin
  62.                 o_r                 <= image[image_cnt][23:16];
  63.                 o_g                 <= image[image_cnt][15:8];
  64.                 o_b                 <= image[image_cnt][7:0];
  65.             image_cnt         <= image_cnt + 1;
  66.         end
  67.         else if(image_cnt == H_ACTIVE*V_ACTIVE)
  68.         begin
  69.                 o_r                 <= 8'h00;
  70.                 o_g                 <= 8'h00;
  71.                 o_b                 <= 8'h00;
  72.             image_cnt         <= 'd0;
  73.         end        
  74.     else
  75.         begin
  76.                 o_r                 <= 8'h00;
  77.                 o_g                 <= 8'h00;
  78.                 o_b                 <= 8'h00;
  79.             image_cnt         <= image_cnt;
  80.         end        
  81. end
  82. always@(posedge i_clk)
  83. begin
  84.         // if(image_cnt >= H_ACTIVE*V_ACTIVE)
  85.                 // o_en <= 0;
  86.         // else
  87.                 o_en <= en;
  88. end
复制代码

图像输出保存代码部分:

  1. module top_tb;
  2. reg             clk;
  3. reg             rst_n;
  4. integer                 image_txt;
  5. reg [31:0]                 pixel_cnt;
  6. wire[7:0]              data;
  7. wire            de;
  8. top u_top
  9. (
  10.     .i_clk         (clk     ),
  11.     .i_rst_n (rst_n   ),
  12.     .o_data  (data    ),
  13.     .o_de    (de      )
  14. );
  15. always #(1) clk = ~clk;
  16. initial
  17. begin
  18.         clk   = 1;
  19.     rst_n = 0;         
  20.         #100
  21.     rst_n = 1;
  22.         
  23. end
  24. initial
  25. begin
  26.     image_txt = $fopen("../matlab_src/image_720_1280_1_out.txt");
  27. end
  28. always@(posedge clk or negedge rst_n)
  29. begin
  30.     if(!rst_n)
  31.         begin
  32.         pixel_cnt <= 0;
  33.     end
  34.     else if(de)
  35.         begin
  36.         pixel_cnt = pixel_cnt + 1;
  37.         $fwrite(image_txt,"%h\n",data);
  38.     end
  39. end
  40. always@(posedge clk )
  41. begin
  42.         if(pixel_cnt == 720*1280)
  43.         begin
  44.                 $display("*******************************************************************************");               
  45.                 $display("*** Success:image_720_1280_1_out.txt is output complete! %t", $realtime, "ps***");
  46.                 $display("*******************************************************************************");
  47.                         $fclose(image_txt);
  48.                 $stop;
  49.         end        
  50. end
  51. endmodule
复制代码

3.3.2
Modelsim实验结果

matlab查看输入输出的图像代码部分:

  1. clear;clear all;clc;
  2. row = 720;  
  3. col = 1280;  
  4. n   = 3;   
  5. image_sim_pass = uint8(zeros(row,col,n));
  6. fid = fopen('image_720_1280_3_out.txt','r');
  7. for x = 1:row
  8.     for y = 1:col
  9.         RGB = fscanf(fid,'%s',1);
  10.         image_sim_pass(x,y,1) = uint8(hex2dec(RGB(1:2)));
  11.         image_sim_pass(x,y,2) = uint8(hex2dec(RGB(3:4)));
  12.         image_sim_pass(x,y,3) = uint8(hex2dec(RGB(5:6)));              
  13.     end
  14. end
  15. fclose(fid);
  16. image_1 = imread('lena_1280x720.jpg');
  17. subplot(121);
  18. imshow(image_1), title('The original image');
  19. subplot(122);
  20. imshow(image_sim_pass),title('After processing images');
  21. imwrite(image_sim_pass,'lena_720x128_sim_pass.jpg');   
复制代码
image.jpg
4工程实现
4.1Verilog代码分析
  1. module image_erode_filtering
  2. (
  3.         input   wire                                i_clk,
  4.         input   wire                                i_rst_n,
  5.         input        wire                                i_hsyn,
  6.         input        wire                                i_vsyn,
  7.         input        wire                                i_en,
  8.         input        wire [7:0]                        i_binary,
  9.         
  10.         output        wire                                 o_hs,
  11.         output        wire                                 o_vs,
  12.         output        wire                                 o_en,        
  13.         output  wire [7:0]                        o_binary
  14. );
  15. reg                    i_hsyn_d;
  16. reg                    i_vsyn_d;
  17. reg                    i_en_d;
  18. reg         erode_and;
  19. reg  [7:0]        binary_reg;
  20. wire [7:0]        r_temp_11;
  21. wire [7:0]        r_temp_12;
  22. wire [7:0]        r_temp_13;
  23. wire [7:0]        r_temp_21;
  24. wire [7:0]        r_temp_22;
  25. wire [7:0]        r_temp_23;
  26. wire [7:0]        r_temp_31;
  27. wire [7:0]        r_temp_32;
  28. wire [7:0]        r_temp_33;
  29. assign o_hs         = i_hsyn_d;
  30. assign o_vs         = i_vsyn_d;
  31. assign o_en         =   i_en_d;
  32. assign o_binary        = binary_reg;
  33. always@(posedge i_clk )
  34. begin
  35.         i_hsyn_d <=        i_hsyn;
  36.         i_vsyn_d <=        i_vsyn;
  37.         i_en_d         <=          i_en;
  38.             
  39. end
  40. image_template u_r_template
  41. (
  42.         .i_clk                        (i_clk                                ),
  43.         .i_rst_n                (i_rst_n                        ),
  44.         .i_en                        (i_en                                ),
  45.         .i_data                        (i_binary                        ),
  46.         .o_en                        (                                        ),
  47.         .o_temp_11                (r_temp_11                        ),
  48.         .o_temp_12                (r_temp_12                        ),
  49.         .o_temp_13                (r_temp_13                        ),        
  50.         .o_temp_21                (r_temp_21                        ),
  51.         .o_temp_22                (r_temp_22                        ),
  52.         .o_temp_23                (r_temp_23                        ),               
  53.         .o_temp_31                (r_temp_31                        ),
  54.         .o_temp_32                (r_temp_32                        ),
  55.         .o_temp_33                (r_temp_33                        )
  56. );
  57. always@(posedge i_clk or negedge i_rst_n)
  58. begin
  59.     if(!i_rst_n)
  60.         begin
  61.         erode_and <= 'd0;
  62.     end
  63.     else
  64.         begin
  65.                 erode_and <= r_temp_11[0] &&
  66.                              r_temp_12[0] &&
  67.                              r_temp_13[0] &&
  68.                              r_temp_21[0] &&
  69.                              r_temp_22[0] &&
  70.                              r_temp_23[0] &&
  71.                              r_temp_31[0] &&
  72.                              r_temp_32[0] &&
  73.                              r_temp_33[0];
  74.     end
  75. end
  76. always@(posedge i_clk or negedge i_rst_n)
  77. begin
  78.     if(!i_rst_n)
  79.         begin
  80.         binary_reg <= 'd0;
  81.     end
  82.     else if(erode_and)
  83.         begin
  84.                 binary_reg <= 'd255;
  85.     end
  86.     else
  87.         begin
  88.                 binary_reg <= 'd0;
  89.     end        
  90. end
  91. endmodule
复制代码
4.2工程结构
image.jpg
5上板实验
image.jpg

点击下载后,可以看到正常的输出如下所示:

image.jpg






































您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

0

关注

0

粉丝

272

主题
精彩推荐
热门资讯
网友晒图
图文推荐

  • 微信公众平台

  • 扫描访问手机版