还有就是不知道你的信号发生器要求频率和精度是多少
一般有两种实现方式:一种是控制AD输出模拟量,另一种是通过SPWM和低通整流而来
本程序是第二种
工作机理有两部分组成:PWM的产生和表
产生部分由两个寄存器和一个计数器组成,计数器不听累加同时与两个寄存器作比较,两个寄存器一个控制置底一个控制拉高,一般把一个固定就行了告歼(有的地方说是一个控制周期一个控制高电平时间,其实是一样的)
表里放的是一个正弦数组(产生正弦波),之后有一个寄存器控制读取表的速度(间隔),把读取出的表值存入上面那个没固定的寄存器就行了
http://blog.sina.com.cn/s/blog_6e22b1da0100n52r.html
我的博客里有一篇关于SPWM模式的DDS的文章
你可以看一看
不懂得话可以给我留言
A/D转换的方法要比SPWM的方法简单,首先你要新建一个存储空间,里面存上A/D的电压控制量的一维数组,数组中存在的数值对应的电压从前到后呈正弦波形排列,每个周期从数组中每隔n个元素依次读取数组付给A/D转换器,这样A/D就可以输出启郑正弦波了,而里面的n步进是由一个寄存器控制的,n的大小决定了你的频率。
至于你说的液晶显示,按键等。我建议你用SOPC实现,Alter公司有Nois2的ip核。它相当于把FPGA当单片机用,你将液晶控制、按键控制、波形生成分别变成自定义IP核集成于系统,之后在袜旁冲顶层用C语言实现目的即可。
如果你不会HDL语言的话,必须先把它学了。如果你不了解SOPC的话,给你介绍一个很好的资料,估计你按这个一步一步来,1周就能学会。
http://wenku.baidu.com/view/dd7ade360b4c2e3f57276360.html
这是百度文库的链接,一共是五章,你可以自己搜索。
今年的电子大赛FPGA组的比赛有不少省市都和你这道题有关,虽然是XILINX公司的,但是大同小异。
和51一样都是要根据时序图的,用FPGA编写的代码在有时序图或者较复杂的功能上时用状态机碰码磨编写是很方便的,根据时序图按时间看出各种状态,再从各个状态中编写代码,比较容易实现,再仿真时笑斗序是否符合和生成状态图,模塌这样编程就方便了。AD芯片是TLC549,EP2c5t144单线的串行数据传送。
先例化一个sdram controller,再打个testbench,然后再build image,再上板测试。这可早碧能是比较快的方式了。最好要对sdram的读写时序比较熟悉,然后例化的controller才能比较靠谱,如果能搞到sdram的bfm模型,那可能更好。
AD输出的数据直接进FPGA,不管是高速AD的串行输出还是并行差分数据,FPGA的IO都可以支持。进FPGA后数据可以存在FPGA的BRAM里面。
FPGA(Field-Programmable Gate Array),即现场可编程门阵列,它是在PAL、陆历举GAL、CPLD等可编程器件的基础上进一步发展的产物。它是作为专用集成电路(ASIC)领域中的一种半定制电路而出现的烂并,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)