Matlab、Modelsim联合仿真--FPGA图像处理

Matlab、Modelsim联合仿真

学了一段时间FPGA后,个人觉得仿真是学习FPGA最应该具备能力,有很多时候仿真调试占整体开发时间的90%,剩下的10%是上机调试和解决其它问题的时间。在之前刚学习FPGA图像处理时主要是利用Matlab将图像生成TXT文件,然后通过串口助手将数据传到FPGA上,再通过VGA接口将图像显示出来。这种方式繁琐就不说了,主要是没有办法直观的观察图像数据的变化,只能通过显示屏来宏观上的验证,如果想要更改图片尺寸的时候一发而动全身,各个模块的参数都要修改。
经过一段时间的学习,发现有一个更加简单的方法——Matlab、Modelsim联合仿真,即使没有开发板也可以验证处理算法各个层次的正确与否。
在PC自带的画图,首先创建一张黑白各占50%的1024*1280的图片,命名test.jpg(如图1)保存到自己创建的文件夹中。
在这里插入图片描述
打开Matlab,新建一个脚本,命名为image_rgb.m保存到存放图片的文件夹,输入以下代码,并运行:
在这里插入图片描述
在文件夹中就会出现,rgb_data.txt这个文件,该文件就是前面的图像生成的16进制数据:
在这里插入图片描述
图像一共有1280x1024x3共3,932,160个数据,生成的数据与原图一致:
在这里插入图片描述

initial $readmemh("rgb_data.txt",gray_gaussian_mem); 
..............
repeat (3932160) begin
      @ (posedge clk);
      # 2;
      gray_data = gray_gaussian_mem[addr];
      gray_dataen = 1'b1;
      # 5
      addr = addr + 1'b1;
    end

通过以上代码,即可将图像数据加载到Modelsim进行仿真。再通过以下代码将仿真产生的数据写到一个新的TXT文件:

initial fid = $fopen("filter_data.txt");
  
  always @ (posedge clk) begin
    if (filter_dataen == 1'b1)
      $fdisplay(fid, "%d", filter_data);
  end

最后再回到Matlab,输入以下代码即可出图:

fid = fopen('filter_data.txt','r');
gray_data = fscanf(fid, '%d');
fclose(fid);
for i = 1 : ROW
   for j = 1 : COL
       pic_gray_fpga(i,j) = uint8(gray_data((i-1) * COL + j));
   end
end

figure('name','pic_gray_fpga'); imshow(pic_gray_fpga);

以上便是一种简单的Modelsim联合Matlab的仿真方法。

声明
本人所写的文章主要是记录在学习FPGA图像处理过程中个人的理解,没有太大的营养,谨慎吸收!

  • 10
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MatlabModelsim联合仿真可以实现FPGA图像处理的验证。具体步骤如下: 1. 使用Matlab对原始图像进行处理,生成txt文档(例如post_img.txt),可以使用img_data_gen.m脚本来实现这一步骤。这个txt文档包含了图像的数据。 2. 在Modelsim中建立一个工程,命名为top_tb,并编写测试代码。测试代码中需要包含待测试的模块top.v,该模块包含了图像处理模块和图像生成模块(类似于VGA模块)。测试代码的文件名为top_tb.v。 3. 在测试模块top_tb中,可以进行仿真波形的查看。同时,通过代码中的逻辑,将VGA数据逐像素地写入到post_img.txt文档中。 4. 使用Matlab对post_img.txt文档进行处理,将其转换成图像的形式。可以使用img_data_show.m脚本来实现这一步骤。 通过以上步骤,就可以实现MatlabModelsim联合FPGA图像处理仿真。具体实现方法可以参考上述引用\[1\]和\[2\]中提供的原理图和步骤分析。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* *3* [Modelsim联合Matlab进行FPGA图像处理仿真与测试的学习总结(以RGB转Ycbcr转Gray为例)](https://blog.csdn.net/H19981118/article/details/124799121)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值