高速数据采集系统设计

高速数据采集系统设计

ID:63515189

大小:203.96 KB

页数:9页

时间:2021-09-08

高速数据采集系统设计_第1页
高速数据采集系统设计_第2页
高速数据采集系统设计_第3页
高速数据采集系统设计_第4页
高速数据采集系统设计_第5页
高速数据采集系统设计_第6页
高速数据采集系统设计_第7页
高速数据采集系统设计_第8页
高速数据采集系统设计_第9页
资源描述:

《高速数据采集系统设计》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、基于FPG序口SoC单片机的高速数据采集系统设计一.选题背景及意义随着信息技术的飞速发展,各种数据的实时采集和处理在现代工业控制和科学研究中已成为必不可少的部分。高速数据采集系统在自动测试、生产控制、通信、信号处理等领域占有极其重要的地位。随着SoC单片机的快速发展,现在已经可以将采集多路模拟信号的A/D转换子系统和CPUK集成在一片芯片上,使整个数据采集系统几乎可以单芯片实现,从而使数据采集系统体积小,性价比高。FPGM实现高速数据采集提供了一种理想的实现途径。利用FPGA®速性能和本身集成的几万个逻辑门和嵌入式存储器块,把数据采集系统中的数据缓存和控制电路全部集成在一片FPGA5片中,

2、大大减小了系统体积,提高了灵活性。FPGA还具有系统编程功能以及功能强大的EDAa件支持,使得系统具有升级容易、开发周期短等优点。二.设计要求设计一高速数据采集系统,系统框图如图1-1所示。输入模拟信号为频率200KHzVpp=0.5V的正弦信号。采样频率设定为25MHz通过按键启动一次数据采集,每次连续采集128点数据,单片机读取128点数据后在LCD真块上回放显示信号波形。佶号图1-1高速数据采集原理框图三.整体方案设计高速数据采集系统采用如图3-1的设计方案。高速数据采集系统由单片机最小系统、FPGA最小系统和模拟量输入通道三部分组成。输入正弦信号经过调理电路后送高速A/D转换器,高

3、速A/D转换器以25MHzI勺频率采样模拟信号,输出的数字量依次存入FPG秋部的FIFO存储器中,并将128字节数据在LCD真块回放显示。9电片机最小系垓LCD模块FPGA的小系统高速ADC图3-1高速数据采集系统设计方案信号而理200kHzVp*0.5T正靠信号四.硬件电路设计1.模拟量输入通道的设计模拟量输入通道由高速A/D转换器和信号调理电路组成。信号调理电路将模拟信号放大、滤波、直流电平位移,以满足A/D转换器对模拟输入信号的要求。2.高速A/D转换电路设计9五.FPGA莫块设计本设计的数据缓冲电路采用FIFO存储器。FIFO数据缓冲电路原理如图5-1FIFO数据缓冲电算高速A/D

4、转搅器单片机越小系统rL图5-1FIFO数据缓冲电路原理FIFO的写端口的数据线与ADS931的数据线直接相连,FIFO的写时钟和ADS931采用同一时钟信号CLKQFIFO的读端口与单片机并行总线相连,数据输出端口加了三态缓冲器。地址译码器的片选信号CS1和读信号RD相或非后作为FIFO的读时钟电路和三态缓冲的使能信号。FIFO数据顶层原理图如图5-2。9崔标高位为r?即EOC=0图5-2FIFO数据顶层原理图六.F360单片机模块设计们加入了一个频率测试显示功能。主程序流程图如图6-2主程序源代码如下:voidmain(){主程序完成C8051F36W片机初始化、检测有无按键输入等功能

5、。在此系统中我(5m)图6-2主程序流程图,I4j_iu«a!ijia■■■■■MavrimH■■■■«■!HTiJh一■■■umm■■i■■■■阖用波形髭木程序fifofl升如求至荻黑START=1虞"8字岸数据4113(7..0]nferpty依智门诺柏鹏rdrgq>rddk分析数据,得波峰就不位置LCD显不初始界面臼6。可始化.LCD初始化脑示计耳频率FIU4用■,3F”式PIn31F”式FiO-F网;褪PIN_『START=O计算模拟储号颍率设置堆栈指针9ucharxdata*addr1;uinti;floatf,ts;ucharfuzhi;intup,down,m,n;up=0;

6、down=0;m=0;n=0;ts=0.04;InitDevice();〃F360初始化InsitiLcd();//LCD模块初始化DispHan(hanzi10,0x80,0x10);DispHan(hanzi11,0x92,0x08);DispHan(hanzi12,0x8a,0x08);DispHan(hanzi13,0x98,0x08);DispHan(hanzi14,0x9c,0x08);addr1=LEDENCS;*addr1=0x01;START=0;EOC=1;while(1){if(keysign==1){keysign=0;if(keycode==0x00)//k0键{

7、START=1;while(EOC==0);//等待数据采集完START=0;addr1=CS1;while(EOC==1)//等待读出第一个有效数据{WaveData[0]=*addr1;}for(i=1;i<128;i++){WaveData[i]=*addr1;if(i>3){if(WaveData[i]>=WaveData[i-2])up=1;if((WaveData[i]<=WaveData[i-2])&&(u

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。