MATLAB 生成 Verilog调用MIF 文件教程一

一.背景
使用Verilog的内核RAM完成特殊函数的硬件设计,比如使用Sin(x)函数的Verilog设计。设计模块目的是在FPGA实现复杂的运算。
二.方法
Sin(x)在FPGA中的计算主要依靠的是查表法实现。查表法是快速高效的计算器计算方式,软件实现简单,该方法在要求实时高速的嵌入式芯片软件开发过程中经常使用。
查表法实现Sin(x)函数的计算,根本问题是解决表中每个数据的计算,这里,采样Sin(x)的0°~90°查表,其他三象限是相同的方式。只采样0-90°可以节省FPGA的RAM资源。PS:FPGA的RAM资源非常有效,不像RAM、DSP芯片。
三.过程
1) MATLAB生产表数据,文件格式是MIF
源代码如下:
clear all;
clc;

gAngle = 0:0.1:90 ;
gAngle = gAnglepi/180;
gSinValueQ16 = int32( (2^16-1)
(sin(gAngle)) );
% 下面MIF的文件格式要要求,必须按照下面方式写
gMifHandle = fopen( ‘SinMifFile.mif’, ‘w’);
fprintf( gMifHandle ,‘Depth = %d ;\n’, 901 );
fprintf( gMifHandle ,‘Width = %d ;\n’, 16 );
fprintf( gMifHandle ,’%s\n’,‘ADDRESS_RADIX = DEC;’);
fprintf( gMifHandle,’%s\n’,‘DATA_RADIX = DEC;’);
fprintf( gMifHandle,’%s\n’,‘CONTENT’);
fprintf( gMifHandle,‘BEGIN\n’);
%将表格数据写入 第一列是索引Index(0~900) 第二列是数值 Value
for i=1:length(gAngle)
fprintf( gMifHandle,’%d:%d;\n’,(i-1),gSinValueQ16(i));
end
%MIF文件写完成
fprintf( gMifHandle,‘END\n’);

  1. Verilog 实现
    参考调用:IP RAM 内核使用方法;

四.ModelSim仿真
1)仿真Verilog代码
`timescale 1 ps/ 1 ps
module TEST_vlg_tst();
// constants
// general purpose registers
reg eachvec;
// test vector input registers
reg [9:0] gAddr;
reg sys_clk;
// wires
wire [15:0] qOutData;

TEST i1 (
.gAddr(gAddr),
.qOutData(qOutData),
.sys_clk(sys_clk)
);
initial
begin
gAddr = 16’d0000;
sys_clk = 1’b1 ;
$display(“Running testbench”);
end
always #5 sys_clk = ~sys_clk ;
initial
begin
#20 gAddr = 16’d1 ;
#25 gAddr = 16’d2 ;
#30 gAddr = 16’d3 ;
#35 gAddr = 16’d4 ;
#40 gAddr = 16’d5 ;
#45 gAddr = 16’d800 ;
#50 gAddr = 16’d801 ;
#55 gAddr = 16’d901 ;
#60 $finish;
end
endmodule

  1. 仿真结果如下
    在这里插入图片描述

撰写人:w3022
邮箱:ysu_wangli@163.com

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值