在FPGA内部设置一个RAM,这个RAM里初始化时存放一堆DAC的数据。简单来说存放:
1)方波,2个幅值的;
2)锯齿波,2个幅值的;
3)三角波,2个幅值的;
4)正弦波,2个幅值的。
然后ABD三个拨码开关选择地址——8个起始地址,其中每个起始地址后面都存放128个数据(具体大团雀小看设置),让fpga定时在其中循环扫描输出数据到DAC。
最后由D开关控制扫描定时器时间2个档位。
我以前设计的板卡用FPGA控制32路塌唯早DAC输出,工作方法和这个类似,当然产品化的东西比较麻烦了。
用51单片机或者FPGA完全可以实现正弦波的输出,具体的方法有:1.你说的查表法,就是在ROM里面建一个表格,只需要四分之一正弦波的数据就可以了,然后用DA输出;
2.用扮枣PWM波的方法,就是用单片机的定时计数器输出不同占空比的方波,后端用厅枝拆合适的低通滤波器滤波,就能产生不同幅值的模拟信号正弦波,低通滤波器将方波的高频部分滤掉,PWM波的占空比越大,输出的模拟信号幅值就越高;
3.使用DDS技术,一块DDS芯片中主要包括频率控制寄存器、高速相位累加器和正弦计算器三搭升个部分。频率控制寄存器可以串行或并行的方式装载并寄存用户输入的频率控制码;而相位累加器根据
dds频率控制码在每个时钟周期内进行相位累加,得到一个相位值;正弦计算器则对该相位值计算数字化正弦波幅度(芯片一般通过查表得到)。DDS芯片输出的一般是数字化的正弦波,因此还需经过高速D/A转换器和低通滤波器才能得到一个可用的模拟频率信号
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)