单片机在多种波形发生器中的应用
发布时间:2008/5/27 0:00:00 访问次数:521
摘要:介绍了基于80c51单片机产生几种基本波形的方法。采用微处理器兼容的14位数模转换器max7534,高速,稳定,具有良好的线性。用户通过按键选择输出需要的波形,波形精度能够满足一般的使用条件。
关键词:波形发生器;单片机;max7534;方波;锯齿波;正弦波
本文利用80c51单片机外接数模转换器和i/v转换电路,由用户通过按键选择输出实验中经常使用到的几种基本波形:方波、锯齿波、正弦波。方波由80c51单片机内部自带的计数器/定时器产生,并由用户通过小键盘选择波形周期。与微处理器兼容的14位数模转换器max7534将数字量转换为模拟量电流信号,通过i/v转换电路得到双极性的锯齿波和正弦波信号,波形保证了他的精度和平滑、稳定。
1硬件电路设计
80c51单片机时钟电路采用内部方式,外接陶瓷谐振器(频率为12mhz),微调电容值为30pf。系统复位采用按键式外部复位方式,复位信号至少保持8μs以上。通过按键由用户选择要输出的波形,按键选择占用p1.1~p1.7口,采用独立式键盘结构。利用80c51单片机内部自带的计数器/定时器在p1.0口上产生连续方波,由用户通过按键选择输出方波周期。系统结构框图如图1所示。
1.1d/a转换电路
本文采用美国maxim公司的微处理器兼容高性能单片14位数模转换器max7534。max7534内部功能框如图2所示。max7534的高质量、激光校准、薄膜电阻和带温度补偿的nmos开关等确保了器件在整个工作温度范围内具有良好的线性和增益稳定性。max7534接收8位总线的2个字节,内部包括1个ls输入寄存器和1个ms输入寄存器,分时接收低8位和高6位的14位待转换数字量、1个14位dac寄存器、1个14位dac数模转换器和逻辑控制电路。数模转换器(dac)电路包括由激光校准的11个薄膜r2r电阻阵、1个3位分段电阻阵和nmos电流开关。该d/a转换器具有保护cmos寄存器的功能,无需使用外加肖特基二极管保护。
max7534与80c51的具体连接见图3。工作时,通过a1、a0引脚确定max的工作过程,其对应关系见下表,当出现表中的第3种情况时,14位待转换的数字量通过max7534内部总线输入到14位dac进行转换。转换结束,模拟量以电流形式输出。
1.2i/v转换电路
由max7534转换得到的模拟量电流信号要转换成电压信号,需外加i/v转换电路。i/v转换电路与max7534的具体连接见图3。
图3是max7534的双极性或四象限乘法工作电路图电路提供的是偏移二进制码,为解决高温时的低泄漏,对vss进行负偏置;c1为补偿电容,用来消除由dac的输出电容和内部反馈电阻构成的极点,其值根据采用运放的不同而不同;在接近dac的vdd和gnd管脚处放置1个1μf的旁路电容,再与1个0.01μf的陶瓷电容相并联,抑制高频噪声。按图中给定的器件参数,输出电压的表达式为:
vout=[(d-8192)/8192]×vin
vin=+5v,当d=0时,vout=-5v;当d=8192时,vout=0v;当d=16384时,vout=4.96v。转换关系见表2。
2软件设计
在硬件设计的基础上进行软件编程。由用户通过按键选择需要输出何种波形。
2.1方波输出
本文通过80c51单片机内部自带的定时器/计数器实现方波输出。采用定时器/计数器t1,工作方式1,计数器位数是16位;门控位gate置0,定时器的运行只受控制寄存器tcon中运行控制位(tr)的控制;计数器初值的设定由以下公式计算得到:
n=2n-tcfosc/12
n为计数器位数;tc为定时时间;fosc为振荡频率。通过小键盘,由用户键入需要输出方波的周期(周期只能为正数,如1ms,2ms,10ms等,最大为65ms),在p0口将得到所需的方波波形。
2.2锯齿波、正弦波输出
锯齿波中的斜线用一个个小台阶来逼近,在一个周期内从最小值开始逐步递增,当达到最大值后又回到最小值,如此循环,当台阶间隔很小时,波形基本上近似于直线。适当选择循环的时间,可以得到不同周期的锯齿波。由图3所示连接可知:选通max7534的ls寄存器地址为5fffh;选通ms寄存器地址为:3fffh;选通dac寄存器地址为:7fffh;选通dac转换地址为:1fffh。锯齿波产生程序流程图如图4所示。
正弦波的产生采用查表法,单片机的i/o输出均为+5v的ttl电平,因此产生的正弦波幅值为+5v。将一个周期内的正弦波形等分为n份,那么第1点的角度为0°,对应的正弦值为5sin0°;第2点的角度为360°/n,对应的正弦值为5sin(360°/n)……,如此计算下去,将这些模拟量正弦值都转换为双极性方式下的数字量,得到一张按照点号顺序排列的数字量正弦值表格。程序流程图与锯齿波产生子程序流程大致一致,只是每次送到max7534转换的14位数字量是根据得到的表格所查得的。
3结语
本文基于80c51单片机的多种波形发生器产生的3种波形完全能够满足实验中的使用要求。采用的高性能数模转换芯片保证了输出波形的精度和稳定性。通过软件实现可以输出更多的基本波形如:梯形波
摘要:介绍了基于80c51单片机产生几种基本波形的方法。采用微处理器兼容的14位数模转换器max7534,高速,稳定,具有良好的线性。用户通过按键选择输出需要的波形,波形精度能够满足一般的使用条件。
关键词:波形发生器;单片机;max7534;方波;锯齿波;正弦波
本文利用80c51单片机外接数模转换器和i/v转换电路,由用户通过按键选择输出实验中经常使用到的几种基本波形:方波、锯齿波、正弦波。方波由80c51单片机内部自带的计数器/定时器产生,并由用户通过小键盘选择波形周期。与微处理器兼容的14位数模转换器max7534将数字量转换为模拟量电流信号,通过i/v转换电路得到双极性的锯齿波和正弦波信号,波形保证了他的精度和平滑、稳定。
1硬件电路设计
80c51单片机时钟电路采用内部方式,外接陶瓷谐振器(频率为12mhz),微调电容值为30pf。系统复位采用按键式外部复位方式,复位信号至少保持8μs以上。通过按键由用户选择要输出的波形,按键选择占用p1.1~p1.7口,采用独立式键盘结构。利用80c51单片机内部自带的计数器/定时器在p1.0口上产生连续方波,由用户通过按键选择输出方波周期。系统结构框图如图1所示。
1.1d/a转换电路
本文采用美国maxim公司的微处理器兼容高性能单片14位数模转换器max7534。max7534内部功能框如图2所示。max7534的高质量、激光校准、薄膜电阻和带温度补偿的nmos开关等确保了器件在整个工作温度范围内具有良好的线性和增益稳定性。max7534接收8位总线的2个字节,内部包括1个ls输入寄存器和1个ms输入寄存器,分时接收低8位和高6位的14位待转换数字量、1个14位dac寄存器、1个14位dac数模转换器和逻辑控制电路。数模转换器(dac)电路包括由激光校准的11个薄膜r2r电阻阵、1个3位分段电阻阵和nmos电流开关。该d/a转换器具有保护cmos寄存器的功能,无需使用外加肖特基二极管保护。
max7534与80c51的具体连接见图3。工作时,通过a1、a0引脚确定max的工作过程,其对应关系见下表,当出现表中的第3种情况时,14位待转换的数字量通过max7534内部总线输入到14位dac进行转换。转换结束,模拟量以电流形式输出。
1.2i/v转换电路
由max7534转换得到的模拟量电流信号要转换成电压信号,需外加i/v转换电路。i/v转换电路与max7534的具体连接见图3。
图3是max7534的双极性或四象限乘法工作电路图电路提供的是偏移二进制码,为解决高温时的低泄漏,对vss进行负偏置;c1为补偿电容,用来消除由dac的输出电容和内部反馈电阻构成的极点,其值根据采用运放的不同而不同;在接近dac的vdd和gnd管脚处放置1个1μf的旁路电容,再与1个0.01μf的陶瓷电容相并联,抑制高频噪声。按图中给定的器件参数,输出电压的表达式为:
vout=[(d-8192)/8192]×vin
vin=+5v,当d=0时,vout=-5v;当d=8192时,vout=0v;当d=16384时,vout=4.96v。转换关系见表2。
2软件设计
在硬件设计的基础上进行软件编程。由用户通过按键选择需要输出何种波形。
2.1方波输出
本文通过80c51单片机内部自带的定时器/计数器实现方波输出。采用定时器/计数器t1,工作方式1,计数器位数是16位;门控位gate置0,定时器的运行只受控制寄存器tcon中运行控制位(tr)的控制;计数器初值的设定由以下公式计算得到:
n=2n-tcfosc/12
n为计数器位数;tc为定时时间;fosc为振荡频率。通过小键盘,由用户键入需要输出方波的周期(周期只能为正数,如1ms,2ms,10ms等,最大为65ms),在p0口将得到所需的方波波形。
2.2锯齿波、正弦波输出
锯齿波中的斜线用一个个小台阶来逼近,在一个周期内从最小值开始逐步递增,当达到最大值后又回到最小值,如此循环,当台阶间隔很小时,波形基本上近似于直线。适当选择循环的时间,可以得到不同周期的锯齿波。由图3所示连接可知:选通max7534的ls寄存器地址为5fffh;选通ms寄存器地址为:3fffh;选通dac寄存器地址为:7fffh;选通dac转换地址为:1fffh。锯齿波产生程序流程图如图4所示。
正弦波的产生采用查表法,单片机的i/o输出均为+5v的ttl电平,因此产生的正弦波幅值为+5v。将一个周期内的正弦波形等分为n份,那么第1点的角度为0°,对应的正弦值为5sin0°;第2点的角度为360°/n,对应的正弦值为5sin(360°/n)……,如此计算下去,将这些模拟量正弦值都转换为双极性方式下的数字量,得到一张按照点号顺序排列的数字量正弦值表格。程序流程图与锯齿波产生子程序流程大致一致,只是每次送到max7534转换的14位数字量是根据得到的表格所查得的。
3结语
本文基于80c51单片机的多种波形发生器产生的3种波形完全能够满足实验中的使用要求。采用的高性能数模转换芯片保证了输出波形的精度和稳定性。通过软件实现可以输出更多的基本波形如:梯形波