- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实用文档
标准
FPGA产生正弦波方法(1/4周期)COE文件
本文主要介绍通过查表法产生正弦波。涉及利用matlab生成四分之一周期的正弦相位、幅值对应表,生成COE文件的IP核方法,FPGA编程产生数字正弦信号。
正弦信号,是一个模拟信号。FPGA只能产生数字信号。因此需要用DA将数字量转化为模拟量。这里采用modelsim的模拟波形显示,不叙述DA转换相关知识了。产生正弦信号的方法有很多,这里用的是查找rom的方法,产生正弦信号。
正弦信号,是一个幅值介于-1和1之间周期变化的模拟量,因此只需要将1/4周期的值存进rom里,其波形就可以根据这1/4周期幅值的变化得到。
matlab产生正弦信号的值。以0.01为步长,从0采集到pi/2,共158个点。x = linspace(0, pi/2,158); 因sin的幅值值是小数,而FPGA不能表示小数,我们把幅值乘以12位二进制后取整实现幅值整数化。即幅值放大4096倍。例如幅值为0.3,而0.3*2^12=1228.8,取整为1229。当然这样表示会有一定误差,但可以根据精度需要调整参数,使误差可接受。
生成ROM。这里rom用的是ISE的IP rom。将matlab生成的数据存入rom里面,读取rom的值,即可生成正弦信号。
首先是生成rom的初始化文件。Xilinx的rom的初始化文件的后缀为.coe。这个特殊文件有固定的格式如下:
文件前面两行的内容是固定的。MEMORY_INITIALIZATION_RADIX=10;表示下面的数字是10进制数,后面的数据是依次存入rom的值,以逗号分开,最后以一个分号结束。
生成初始化文件的matlab程序如下所示:
fid = fopen(sin_rom.txt,w);
fprintf(fid,MEMORY_INITIALIZATION_RADIX = 10;\n);
fprintf(fid,MEMORY_INITIALIZATION_VECTOR =\n);
for i = 0:1:pi/2*100
y = sin(i/100);
rom =floor( y * 2^12);
if i == 157
fprintf(fid,%d;,rom);
else
fprintf(fid,%d,,rom);
end
if mod(i,10)==0 i ~= 0
fprintf(fid,\n);
end
end
fclose(fid);
matlab生成的文件是.txt文件。将后缀直接改为.coe即可。然后复制到ISE分工程目录下。
初始化文件生成后,剩下就是编写verilog代码。
首先建一个工程,然后新建一个IP。
找到rom,打开。设置按如下设置:
这里是设置位宽,采用的是13位(第一位为符号位,后面12位为数据位)来显示sin的值。因此这里是设置为13.深度是因为要存158个值,所以这里设置为158.
将刚刚生成的.coe文件载入,生成即可。
接着就是编写verilog代码了。
首次查看用ip生成的rom的例化代码.
sin_rom your_instance_name (
.clka(clka), // input clka
.addra(addra), // input [7 : 0] addra
.douta(douta) // output [12 : 0] douta
);
从上面的程序可看出,只需要给时钟信号,和输入地址,就可以了。输出的就是正弦的数字信号了。分析正弦信号,前1/4个周期,地址从0自加,一直加到157(1/4个周期的点数)。然后再自减,减到0。然后进入到负半周,负数的表示是以二进制的补码来表示的,即绝对值数的二进制取反在加1。
编写地址自加自减的代码,然后再根据地址的值,判断输出值的正负,如为负数,则取反加1后再输出。
代码,如下所示:
module sin_top(
input clk, //输入时钟信号
input [9:0] address, //输入地址信号
output reg [12:0] data_out //输出sin的数字值
);
reg [7:0] add;
wire [12:0] douta;
// 以下是判断地址的值
always@ *
begin
if( address = 157 )
add = address;
else if( address = 314 )
add = 10d314 - address;
else if( address = 471 )
add = address - 10d314;
else if( address = 628
您可能关注的文档
- word 2010 长篇文档排版方式.doc
- JBT9002运输机械用减速器.doc
- 《电机与电气控制技术》自测题与问题详解.doc
- Y系列Y2系列电动机主要全全参数表.doc
- LNG气化站施工设计.doc
- §4.1 A B C系统磁链的电压方程式.doc
- quarter ii 4位数码管显示实验.doc
- 《计算机基础(2008版)》第5次作业.doc
- PE管材生产项目工作可行性研究报告材料.doc
- SAS统计分析报告教程方法总结材料.doc
- 国开景区管理作业2试题及答案.pdf
- 国开景区管理作业1-4试题及答案.pdf
- 河南开放大学本科《地域文化(本)》作业练习1-3试题及答案.pdf
- 2024年大型游乐设施操作证考试题库及答案很全.pdf
- 2024年门座式起重机司机考试题库及答案.pdf
- 2022-2023学年河北省衡水市武强中学高二(下)期末数学试卷【答案版】.docx
- 2022-2023学年河北省保定市崇德实验中学高二(下)期末数学试卷【答案版】.docx
- 江西省2017年中小学教师招聘考试高中化学试卷及答案.docx
- 2024年河北省八年级中考生物真题(解析版).docx
- 2024年南阳市社会保险中心(唐河县企业养老保险分中心)(参公)一级科员招录1人《行政职业能力测验》高频考点、难点(答案详解版).docx
文档评论(0)