Matlab、ISE联合开发实例之中值滤波(二)FPGA硬件架构实现

本文介绍了使用Matlab和ISE结合实现FPGA中值滤波的过程。通过硬件架构设计,避免了排序,提高并行处理效率。采用3组比较寻找最小值、中间值和最大值,最后确定中值。Verilog代码中调用IP核compare8,仿真结果显示中值滤波功能正确。下篇将探讨如何处理真实图片数据和大数据量的测试验证。
摘要由CSDN通过智能技术生成

声明:主要程序及架构思想均来自徐文波、田耘《Xilinx FPGA开发实用教程(第二版)》,本人在学习过程中按照书上指导将其实现,将其拿出与初学者交流分享。所有步骤均经过验证(并修正了书上若干细节小错误)。O(∩_∩)O~


硬件架构要充分考虑硬件自身的特点,比如说并行性。这里我们要发现中值滤波的特点,实际上仅仅为了找出9个数的中值是不需要排序的。

算法如下:(后面有时间再画一张图说明)

9个数,先分为3组分别找每组的最小值MIN、中间值MED、最大值MAX(对于3*3小矩阵,按行或列比较即可)

然后将三组的最小值MIN1、MIN2、MIN3合成一组,找出其最大值,记为A1

将三组的中间值MED1、MED2、MED3合成一组,找出其中间值,记为A2

将三组的最大值MAX1、MAX2、MAX3合成一组,找出其最小值,记为A3

最后,找出A1、A2、A3的中间值,就是所求的9个数的中间值。大家只要画个图就发现这种方法很利于并行化处理。

接下来是verilog实现代码,zhongzhilvbo是主模块,其中调用了uutcompare8比较每个数,然后用case语句来判断MIN、MED和MAX

module zhongzhilvbo(
    clk_pixel, rst_n, 
	 din1, din2, din3, din4, din5, din6, din7, din8, din9, dout
    );
    input         clk_pixel;
	 input         rst_n;
    input  [7:0] 	din1, din2, din3, din4, din5, din6, din7, din8, din9;
    output [7:0]  dout;
	 
	 reg    [7:0]  dout;

    wire   d12, d13, d23;
    wire   d45, d46, d56;
    wire   d78, d79, d89;
	 
    wire   dd12, dd13, dd23;
    wire   dd45, dd46, dd56;
    wire   dd78, dd79, dd89;	 
	 
	 wire   ddd12, ddd13, ddd23;
	 
    reg [7:0]  dtm11, dtm12, dtm13, dtm21, dtm22, dtm23, dtm31, dtm32, dtm33;
	 reg [7:0]  dtm221, dtm222, dtm223;
	 
	 // First
	 always @(posedge clk_pixel) begin
	    if(!rst_n) begin//同步复位
		    dtm11 <= 0;
			 dtm12 <= 0;
		    dtm13 <= 0;
			 dtm21 <= 0;
		    dtm22 <= 0;
			 dtm23 <= 0;
			 dtm31 <= 0;			 
		    dtm32 <= 0;
			 dtm33 <= 0;			 
		 end
		 else begin
		    //3个一组进行大小比较,d12=0表示din1>din2,以此类推
			 //其中dtm11为3者中最大值,dtm12为中间值,dtm13为最小值
          case({d12, d13, d23})
	
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值