一.背景
使用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’);
- 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
- 仿真结果如下
撰写人:w3022
邮箱:[email protected]
|
请发表评论