(一)这个方法只在matlab中生成数据表,需要自己手动的
往mif文件中添加数据
1.假设用到的DA芯片困唯为14为,则2^14=16384
2.一个完整的正弦波为0-2pi
3.正弦波ROM的深度为4096(地址总数)
4.由于FPGA中不识别负数,加入一个直流分量,加8192
则用matlab产生正弦表的函数为:
Y=ceil((16384/2-1)*sin(0:pi*2/4096:2*pi)+8192)
其中ceil函数描述如下:
ceil(x) : 大于x 的最小整数
>>ceil( [3.12 -3.12])ans =4 -3
(二)可以直接生成mif文件
直接生成mif文轿脊件
depth = 4096width =14x=ceil(16384/2*sin(0:pi*2/4096:2*pi)+8192)
fid = fopen('d:\romdata1.mif','w')
fprintf(fid,'depth= %d
',depth)
fprintf(fid,'width= %d
',width)
fprintf(fid,'address_radix=uns
')
fprintf(fid,'data_radix = uns
')
fprintf(fid,'Content Begin
')
for(k=1:depth)
fprintf(fid,'%d: %d
',k-1,x(k))endfprintf(fid,'end')
用上面这段程序最大值会出现16384,在Quartus II中会认为是超出数据
范围,所以需要手动的改写为16383.------
----把x=ceil(16384/闭尺渗2*sin(0:pi*2/4096:2*pi)+8192) 改写为下面语句
x=ceil((16384/2-1)*sin(0:pi*2/4096:2*pi)+8192) 就不存在上述问题了
数据量小的话,可以用第一种方法,要是数据量大的话,介意用第二种方法。
keil如何生成正弦波数据表,回答如下:
1、在CODE区建立一个正弦表,使用的时候就查表。这样速度比较快,但精度受表的大小影响
2、在程序中滑蔽明增加MATH.H头文件,直接调用SIN函信告数,精度高并察,但速度相对查表法慢,受CPU影响。
SIN2IMG用于固件ftf中system.sin的解包
使用方法:将固件ftf文件用rar打开,解压出system.sin文件,铅颤将该文件槐芹败于SIN2IMG.exe放在同一个文件夹里面,比如说h:\下,进入CMD,用cd命令进入h:\目录,输入SIN2IMG.exe
system.sin
system.img稍等一会,system.img就首碰解包出来了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)