基于51单片机、EDA技术的波形发生器的设计

发布者:dandan666最新更新时间:2011-12-21 关键字:51单片机  EDA技术  波形发生器 手机看文章 扫描二维码
随时随地手机看文章

  该波形发生器以单片机(MCS8031)为中心控制单元,由键盘输入模块、数码管显示模块、D/A波形发生模块、幅值调整模块组成。采用DDFS技术,先将要求的波形数据存储于EEPROM中,这样可以保证掉电以后波形数据不丢失。

  为了达到所要求的高速度,采用FPGA(ALTEAR 公司的 EPF10K10LC84-4, 晶振频率可达 40MHz)来实现波形的发生,通过DDFS技术(直接数字频率合成技术)、VHDL语言和单片机汇编语言编程技术的完美结合实现了对正弦波、方波和三角波三种波形的频率、幅值的设置和发生。

  随着深亚微米半导体技术的进步,可编程逻辑器件及EDA技术的应用已经相当普及。基于可编程逻辑器件的高频性质和单片机强大的数据处理功能,二者结合的技术也有相当的影响力。本设计中涉及到单片机汇编语言、VHDL语言的运用,充分地利用了二者的优点,制作了一套波形发生系统。

  1  系统设计

  整体设计由三大模块组成:单片机控制部分、可编程逻辑器件(FPGA)部分、模拟电路部分。其系统方框原理图如下所示:

波形发生采用DDS技术,可以很方便地产生各种高质量的波形,DDS的基本原理是:先将要产生的波形数据存入波形发生器,然后通过改变参考脉冲的频率,将波形数据传送给D/A转换器,滤波处理后便可以输出光滑的合成波形。为了提高所产生的波形频率,采用高频率特性的FPGA(ALTERA公司的 EPF10K10LC84-4),后级电路采用有较高的转换速度的DAC0832作为D/A转换。

  1.1 单片机部分

  在设计中,采用MCS8031为处理器,P2.7作为8279的片选端,P2.6作为FPGA的片选端, P2.5为DAC0832(a)的片选端。P0口作为三者的低8位地址和数据线。单片机控制DAC0832(a),使其输出为0~5V可变电压,作为 DAC0832(b)的参考电压,于是可控制输出波形的幅值。由于采用7位数据控制,精度可达到0.039V。

  1.2 FPGA模块

  设计中我使用了ALTRA公司的MAXPLUSⅡ 10.0系统,采用原理图和VHDL语言编程相结合的形式,充分地发挥了FPGA的高速和现场可编程的能力。

  在FPGA中通过编程片内实现比例乘法器(cc14527),在单片机的控制下,FPGA接收单片机传送过来的用户要求的波形数据及其频率数据,并送到比例乘法器以产生所需要的输出频率值。顶层图如下:

其中:P20作为FPGA的片选端,低电平有效,高电平时保持现有状态,与单片机的P2.6相连。WR为FPGA的写信号,与单片机的写端口相连。当P20为低电平时,单片机可向FPGA写数据,以达到传送命令以及数据的目的。ALE为输入信号,与单片机的ALE信号相连,用于FPGA片内锁存地址,配合WR信号进行单片机与FPGA的通讯。P0[7..0]共8条数据线,为单片机P0口的接口,用于地址和数据的传送。CLK为FPGA的基准频率(16MHz)。WR0832用于控制DAC0832(b),与其WR端相连,在其下跳沿时DAC0832(b)可以取到存储器中相应给定地址的数据。 CE:用于控制EEPROM28C64,与其片选端CE相连。CE1用于控制DAC0832(b),与其片选端CE相连。ADDRESS[9..0]为 EEPROM28C64的地址信号,用于取址。

  EEPROM28C64中存有波形数据,单片机通过控制FPGA使其输出的频率为用户所需频率的128倍,用于控制EEPROM28C64的输出值的频率,于是DAC0832(b)的输出波形频率也相应地改变。在FPGA内主要完成比例乘法器的功能,用于频率的控制。 

  单片机与FPGA通讯接口原理如下图所示:

其中:SEL信号,用于控制波形的形状,共有三种波形(正弦波、方波、三角波)。Q0[3..0]~Q5[3..0]用于6级级联比例乘法器的置数输入。ST为级联比例乘法器的片选端,低有效。

  FPGA片内实现寄存器,可对单片机传输的数据和命令进行寄存,具体如下:

  ⑴命令寄存器

  入口地址:FFH  命令字:FFH(ST有效),00H(ST无效)
入口地址:00H  命令字:E0H(显示正弦波,sel为00),E1H(显示方波,sel为01),E2H(显示三角波,sel为10)。

  ⑵ 数据寄存器

  入口地址:01H,02H,03H分别存储单片机传送的6位10进制数。这些数据是用户要求的频率数通过单片机乘8处理后传送过来的,为乘法器提供频率数据。

  FPGA对DAC0832及EEPROM28C64控制接口如下图所示:

WR0832为DAC0832读信号,下跳沿读取数据。CE、CE1分别为DAC0832、EEPROM28C64片选端。ADDRESS[9..0]为 EEPROM28C64地址信号。ADDRESS[9..0]的高两位为SEL[1..0],时钟信号CLK上升沿时ADDRESS[6..0]:自增 1,EEPROM28C64输出相应的波形数据。同时CLK下降沿时,DAC0832读取波形数据。


  3  模拟部分

  DAC0832与单片机采用单缓冲方式接口电路,由于DAC0832内部含有锁存器,具有锁存功能,所以不必通过373锁存。DAC0832的模拟电压输出电路如下:

滤波部分采用带通滤波,使低于1HZ的频率信号和高于100KHZ的频率信号被滤掉,增加波形的平滑度。

关键字:51单片机  EDA技术  波形发生器 引用地址:基于51单片机、EDA技术的波形发生器的设计

上一篇:基于单片机技术的室内报警器的设计
下一篇:基于51单片机设计的简易智能机器人

推荐阅读最新更新时间:2024-03-16 12:49

51单片机+12864液晶屏贪吃蛇
先说下我这个东西最主要的几块。 1.单片机用的是stc的,51内核,你首先要会这个··· 2.用状态机实现按键。这个里面有别人写的技术帖子·· 3.液晶是12864,2种控制器都做过,一个控制器是ST7920带字库的,一个控制器是KS0108不带字库的。2个的英文资料我都放在里面了。首先得弄懂液晶要怎么样和单片机连接。 要在液晶上面做游戏,推荐先看英文资料,一定要看英文,研究液晶读写时序和初始化方法,然后找别人的程序,实现液晶的基本操作,画点,写汉字什么的,读液晶···然后自己写程序实现液晶的所有基本操作。这样才能对液晶有充分的认识,才能开始在上面做游戏。有了这个基础,以后学别的液晶也会快的多。 4.菜单,游戏少不了要用到菜单,比
[单片机]
<font color='red'>51单片机</font>+12864液晶屏贪吃蛇
51单片机做的电子时钟
程序如下: #include reg52.h unsigned char code table1 ={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40,0x76};//字码表0-9,最后一个是一横 - unsigned int i,a,b,c,d,flag,flag1; unsigned int sec,min,h,nm,nh,nz; unsigned int w,day,mon,year; int miao1,miao2,miao3; sbit keyled=P1^0; sbit key2=P1^1; sbit keyinc=P1^2; sbit keymood
[单片机]
51单片机软件I2C驱动中的CY
做一个MSP430的项目,虽然430内部有硬件I2C的模块,略难,准备直接移植51的。。碰到一句代码 dat = 1; //移出数据的最高位 pSDA = CY; //送数据口 digitalWrite(pSCL, HIGH); //拉高时钟线 CY是什么?? 百度了一下。。 位 7: CY:进位标志。 当最后一次算术操作产生进位(加法)或借位(减法)时,该位置 1。其它算 术操作将其清 0。 右移时最高位被移入CY。循环移八次,刚好把一字节移完。 意思就是左移的时候溢出后CY会成为1 一次一次发就把8位发完了。。 移植到430上直接d
[单片机]
51单片机-液晶屏代码讲解
关于指针和1602液晶屏的知识讲解我们就不赘述了,《手把手教你学51单片机》文档第12,13章有很详细的讲解,我们也不用再自己搞些与众不同的驱动代码,没必要再“重新发明轮子”,只需直接移植使用宋老师为我们写好的代码就好。那么宋老师的液晶屏代码原理他也在文档详细讲解了,大家只需反复细读都会掌握的了的,这里笔者只对部分代码做出一些解释。打开宋老师的代码lesson12_4。 1.显示字符的执行操作 如果我们需要在液晶屏上显示下图的内容 那么在代码上需要一步步地操作来完成。 首先设置好液晶屏的使用指标,比如需要“16*2显示,5*7点阵”、“显示器开,光标关闭”、“文字不动,地址自动+1”,这些叫做液晶屏的初始化,表明液晶屏
[单片机]
<font color='red'>51单片机</font>-液晶屏代码讲解
51单片机驱动ADC0808电路图C51及汇编程序
这两天刚刚完成了一个用C编写的程序,这是我第一个用C语言编写的程序,并且调试成功。 第一个C程序,值得纪念,也值得以后参考。 本程序的功能是: 1.ADC0808转换功能;    2.数据16进制显示; 3.串行通信数据。 C51程序:工程文件下载: http://www.51hei.com/f/0808_c.rar #include absacc.h # inc lude reg51.h #define uchar unsigned char #define uint unsigned int sbit START=P3^6; //启动转换 sbit OE=P3^
[单片机]
<font color='red'>51单片机</font>驱动ADC0808电路图C51及汇编程序
51单片机:74LS138译码实验
一、实验内容 通过单片机P1.2P1.0控制74LS138译码器的使能及译码输入端口,控制其译码输出端口(Y7Y0)。 (74LS138译码单元C、B、A分别连接P1.2、P1.1、P1.0。) 把译码输出端口Y7Y0连接到L7L0八位LED电平指示输入端口,验证74LS138的逻辑译码功能。 二、仿真图 三、代码 C语言实现: 在这里插入代码片 ```#include reg52.h #include intrins.h void delay1s(void); void main() { char num; while(1) { for(num=0;num 8;num++
[单片机]
<font color='red'>51单片机</font>:74LS138译码实验
51单片机超声波四通道端口扫描方式测距
超声波四通道测距:超声波测距实现分为三大块: 其一是12864带字库的液晶驱动程序: 代码如下: /////////////////12864驱动程序/////////////////////////// //1写数据 void WriteDataLCD(unsigned char WDLCD) { ReadStatusLCD(); //检测忙 LCD_RS = 1; LCD_RW = 0; LCD_Data = WDLCD; LCD_E = 1; LCD_E = 1; LCD_E = 1; LCD_E = 0; } //2写指令 void WriteCommandLCD(unsigned ch
[单片机]
C51单片机的IO口介绍(下)
上一篇文章我们对C51的IO简单的介绍了一下,现在我们来简单了解C51的IO的结构 这里我们学习一下比较常见的单片机的IO模式,分别是准双向,开漏输出和推挽输出 (这里要提一嘴,我们用的STC88C52RC是没有推挽输出功能的,STC公司后续推出的一些机型才有推挽输出功能) 接下来我们来看看这几种模式 1.准双向 看看下面的原理图,机内信号通过一个非门取反后送入一个MOS管,MOS管负责控制这个IO的高低电平,配合内部上拉电阻完成高低电平的输出 为了方便我们分析,我们把这个MOS管看成一只NPN三极管。区别是三极管靠电流导通,MOS管靠电压导通 结合前面我们讲过的知识,对于一只NPN三极管,基极b电压比集电极c电压
[单片机]
C<font color='red'>51单片机</font>的IO口介绍(下)
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved