基于单片机的全数字信号发生器设计
- 格式:doc
- 大小:128.00 KB
- 文档页数:14
基于DDS与单片机的信号发生器的设计参赛队员:陈天元杨维龙王伟健选题:信号源的设计和制作(B题)摘要在信号发生器的设计中,传统的用分立元件或通用数字电路元件设计电子线路的方法设计周期长,花费大,可移植性差。
本设计是用直接数字频率合成器(DDS)。
与传统的频率合成方法相比,DDS合成信号具有频率切换时间短、频率分辨率高、相位变化连续等诸多优点。
使用单片机灵活的控制能力与液晶显示相结合,使得可以直观的控制波形的产生与调整,带来了很大的便利。
关键词:单片机,直接数字频率合成,液晶1、现有元件电源模块7805,STC89C52单片机,DDS直接式数字合成频率计,模数转换器ADC0804,1602液晶显示模块,独立按键等。
2、设计要求一、任务在给定±12V电源电压条件下,设计并制作一个正弦波信号源。
二、要求1、基本要求:(1)输出信号频率:20Hz~300kHz;(2)信号幅度:负载50Ω时,输出电压峰峰值为1~3V可调;(3)信号源输出电阻为50Ω;(4)显示信号的频率和幅度。
2、发挥部分:(1)提高信号的输出频率至1MHz;(2)提高信号的输出电压峰峰值至1~10V可调(带50Ω负载);(3)自行扩展信号源功能。
3、可以达到的效果本设计可以将输出频率调整到1~30 MHz,而由于在超高频条件下,一般运放的带宽不足以满足放大波幅的设计要求,但是我们通过负电压增加电流的方式,使得信号输出电压峰峰值为0.7v~2.4v可调。
本设计可以通过按键进入设置模式,左右按键移动光标,上下按键加减频率,再通过旋钮调节幅值,然后按键结束设置模式,就可以从输出口输出我们在设置模式下给定的波形。
4、硬件设计4.1、总体设计通过STC89c52给定DDS频率,短接DDS上J3口,使DDS可以输出稳定频率通过按键中断进入波形设置模式,可以通过按键增减与移位调整液晶屏上的频率显示,通过调整LM348设置新的幅值,在跳出波形设置模式时,DDS会按照设置好的波形参数产生一个新的波形,用以输出。
目录引言 (2)一设计任务 (2)1设计内容 (2)2设计要求 (2)二芯片功能介绍 (2)三总体功能图和总原理图 (4)四程序流程图 (5)1 锯齿波程序流程图 (5)2 三角波程序流程图 (5)3 梯形波程序流程图 (6)4 方波程序流程图 (7)5 正弦波程序流程图 (8)6 整体程序流程图 (9)五程序设计 (10)六仿真测试 (13)七总结与体会 (16)八参考文献 (16)九致谢....................................................................... 错误!未定义书签。
引言信号发生器又称信号源或振荡器,在生产实践和科技领域中有着广泛的应用。
这次的设计分为五个模块:单片机控制及显示模块、数模转换模块、波形产生模块、输出显示模块、电源模块。
使用AT98C52作为主控台结合芯片DAC0832产生1HZ-10HZ频率可调的五种信号波(锯齿波、三角波、方波、梯形波、正弦波)。
这几种波形有几个开关控制,可以随意进行切换,十分方便。
另外,波形的频率和振幅也可以通过开关进行更改。
可以说这次的设计操作简单,内容丰富,而且电路快捷明了。
1设计任务1.1设计内容以单片机为基础,设计并开发能输出多种波形(正弦波、三角波、锯齿波、梯形波等),且频率、幅度可变的函数发生器。
1.2设计要求设计借口电路,将这些外设构成一个简单的单片机应用系统,画出接口的连接图和仿真图,并编写出控制波形的程序。
2芯片功能介绍2.1、DAC0832芯片介绍:DAC0832为一个8位D/A转换器,单电源供电,在+5~+15V范围内均可正常工作。
基准电压的范围为±10V,电流建立时间为1μs,CMOS工艺,低功耗20mW。
DAC0832的内部结构框图如下图所示。
图2.1 DAC0832的内部结构框图2.2 DAC0832的外部引脚及功能介绍图如下:图2.2 DAC0832介绍2.3 DAC0832的应用:DAC0832一是用作单极性电压输出,二是用作双极性电压输出,最后是用作程控放大器。
基于单片机制作高频DDS信号发生器在现代科学和电子技术的不断进步下,数字信号发生器(DDS)已经成为了频率控制和生成的重要工具。
尤其是高频DDS信号发生器,其在雷达、通信、电子对抗等领域的应用具有不可替代的地位。
本文将介绍如何使用单片机制作高频DDS信号发生器。
一、DDS技术概述DDS,全称Direct Digital Synthesizer,即直接数字合成器,其工作原理是将数字信号通过数模转换器(DAC)转换成模拟信号。
DDS 技术的核心是相位累加器,它将输入的数字信号的相位进行累加,从而生成新的频率信号。
二、硬件设计1、单片机选择:本设计选用具有高速、低功耗、高集成度的单片机,如STM32F4系列。
2、频率控制字:通过设置频率控制字(FCW),可以控制输出信号的频率。
频率控制字由一个16位二进制数组成,表示了相位累加的步进大小。
3、存储器:使用Flash存储器存储预设的频率波形数据。
4、DAC:数模转换器将存储器中的波形数据转换成模拟信号。
本设计选用具有高分辨率、低噪声、低失真的DAC芯片。
5、滤波器:使用LC滤波器对DAC转换后的信号进行滤波,以得到更加纯净的信号。
三、软件设计1、相位累加器:相位累加器是DDS的核心,它将输入的数字信号的相位进行累加,从而生成新的频率信号。
2、波形查找表:将所需的波形数据存储在波形查找表中,通过查表的方式获取波形数据,可以大大提高DDS的工作效率。
3、控制逻辑:控制逻辑负责处理输入的控制信号,如启动、停止、频率控制字等。
4、通信接口:为了方便远程控制,需要设计通信接口,如SPI、I2C 等。
四、性能测试1、频率范围:测试DDS输出信号的频率范围是否满足设计要求。
2、频率分辨率:测试DDS输出信号的频率分辨率是否达到设计要求。
3、信号质量:测试DDS输出信号的信噪比、失真度等指标是否满足设计要求。
4、稳定性:长时间运行后,测试DDS输出信号的频率是否稳定。
5、远程控制:测试通信接口是否正常工作,可以通过计算机或者其他控制器对DDS进行远程控制。
目录1 DDS技术的基本原理 (2)2.1 DDS结构 (2)DDS数学原理 (5)2 总体设计方案 (7)3.1系统设计原理 (7)3.2总体设计框图 (8)3系统的硬件设计 (8)3.2 DDS芯片的选择及与单片机之间的通信 (8)3.3 单片机〔AT89S52〕控制电路 (11)3.4 液晶显示模块 (14)3.5 低通滤波器的设计 (16)4 信号发生器的软件设计 (17)4.1 程序流程图 (17)4.2 键盘扫描流程图 (19)4.3 LCD的显示 (21)5部分系统的仿真和调试 (21)6 系统的程序代码................ 错误!未定义书签。
7设计心的及体会 . (25)8 参考文献 (26)1 DDS技术的基本原理2.1 DDS结构1971年,美国学者等人撰写的“A Digital Frequency Synthesizer”-文首次提出了以全数字技术,从相位概念出发直接合成所需波形的一种新组成原理。
限于当时的技术和器件产,它的性能指标尚不能与已有的技术相比,故没受到重视。
近几年间,随着微电子技术的迅速发展,直接数字频率合成器〔Direct Digital Frequency Synthesis简称DDS或DDFS〕得到了飞速的发展,它以有别于其它频率合成方法的优越性能和特点成为现代频率合成技术中的佼佼者。
具体表达在相对带宽、频率转换时间短、频率分辨率高、输出相位连续、可产生宽带正交信号及其他多种调制信号、可编程和全数字化、控制灵活方便等方面,并具有极高的性价比。
DDS是直接数字式频率合成器〔Direct Digital Synthesizer〕的英文缩写。
与传统的频率合成器相比,DDS具有低成本、低功耗、高分辨率和快速转换时间等优点,广泛使用在电信与电子仪器领域,是实现设备全数字化的一个关键技术。
直接数字频率合成器〔Direct Digital Synthesizer〕是从相位概念出发直接合成所需波形的一种频率合成技术。
目录1 绪论 (5)1.1 选题背景及意义 (5)1.1.1 本课题的研究现状 (5)1.1.2 选题目的及意义 (6)1.2 设计任务及要求 (6)1.2.1 设计的基本要求 (7)1.2.2 本文结构安排 (7)2 函数发生器系统设计 (8)2.1 设计方案的比较 (8)2.2 系统模块设计 (9)2.2.1 控制模块: (9)2.2.2 按键及其显示模块: (9)2.2.3 波形产生模块 (9)2.2.4 D/A转换 (10)2.3 系统总体框图 (12)2.4 理论分析 (12)2.4.1 电路的理论计算 (12)2.4.2 波形产生相关理论 (15)2.5 单片机软件开发系统 (15)3 系统硬件电路的设计 (17)3.1 单片机最小系统 (17)3.2 单片机的接口电路 (18)3.3 幅度控制模块 (23)3.3.1 单片机与DAC0832的接口 (23)3.3. 2DAC0832与运放的连接 (23)4 系统软件设计 (26)4.1 系统软件设计方案 (26)4.2 系统软件流程图 (26)4.3 信号产生程序 (27)4.3.1 正弦波产生 (28)4.3.2 三角波产生 (28)4.3.2 方波产生 (29)4.3.4 锯齿波的产生 (30)5 系统调试与测试 (32)5.1 调试 (32)5.2 测试 (35)6 结论与展望 (38)6.1 结论 (38)6.2 展望 (38)致谢 (39)参考文献 (51)附录 (40)附录一系统软件部分源程序 (40)附录二系统原理图 (49)附录三系统PCB图 (50)基于单片机的波形发生器的设计学生:李利刚指导老师:李敏(黄冈职业技术学院)摘要:函数发生器是一种用于产生标准信号的电子仪器,它广泛用于工业生产、科研和国防等各个领域中,所以论文选题具有一定的实用意义。
本文介在绍了函数发生器的基本概念及原理的基础上,采用AT89C51单片机为核心,完成了简易的DDS函数发生器的硬件设计和软件编程,并通过调试实现了其功能和主要技术指标。
基于单片机DDS信号发生器的硬件设计单片机DDS信号发生器是一种利用数字直接频率合成技术(Direct Digital Synthesis, DDS)来生成高精度信号波形的设备。
它通过调用存储在单片机中的频率、幅度和相位数据,实时更新波形,从而实现高速、高分辨率和低失真的信号发生器功能。
在本文中,将简要介绍单片机DDS信号发生器的设计流程以及其硬件实现。
设计流程:1.确定需求和规格:首先需要明确所需信号的频率范围、分辨率、输出幅度和失真要求等基本参数,以确定设计的方向和重点。
2.硬件选型:根据需求确定适合的单片机型号和外围器件,如振荡器、滤波器、放大器等。
3.硬件连接:根据单片机的引脚功能和外部器件的连接方式设计电路图,将各模块连接起来。
4.编程开发:编写单片机控制程序,实现DDS算法和信号波形生成,并将其烧录到单片机中。
5.调试和优化:通过实际调试和测试,不断优化硬件和软件设计,使其符合设计要求。
硬件实现:1.单片机选择:选择一款适合的高性能单片机作为控制核心,如STM32系列、PIC系列等,具有较高的计算性能和丰富的功能模块。
2.时钟源部分:基于晶振或者DDS芯片提供的时钟信号作为主时钟源,保证信号发生器稳定输出。
3.数字与模拟部分:DDS信号发生器的核心是DDS芯片,它与单片机通过SPI接口通信,实现信号波形的生成和调试。
4.输出功率放大器:将DDS芯片输出的信号通过功率放大器放大至所需的幅度,以驱动外部电路工作。
5.滤波器设计:为了消除输出信号中的高次谐波和噪声干扰,需要设计合适的低通滤波器,保证输出信号的纯净度和稳定性。
6.电源管理:为各个模块提供稳定可靠的电源,充分考虑信号发生器的功耗和稳定性要求。
7.外部控制:设计合适的用户接口和控制按钮,方便用户操作和调节信号波形的参数。
总结:单片机DDS信号发生器的硬件设计涉及到信号生成、时钟同步、数字模拟转换、输出功率放大和滤波等多个方面,需要综合考虑各个模块的性能和需求,以实现高质量、高稳定性的信号输出。
基于单片机的全数字信号发生器设计设备技术网时间:2010-4-13来源:电子技术网作者:工业设备常用频率量信号作为采集量,如使用光电编码器采信数据,当调试使用频率信号的设备时,由于机械等部份还未动作,无法采集信号,因此需要使用信号发生器。
对于在工业现场使用的设备,其要求与实验室设备并不相同,如果直接使用实验室中所用的标准信号发生器,往往会觉得其体积过大、价格太高、使用较麻烦等。
工业现场使用的设备,其绝对精度要求并不高,关键要稳定可靠,便于携带和使用。
一、性能分析这个项目的目标是替代工业现场的频率采样装置,典型的如光电编码器。
通过调查,确认最终要制作的信号发生器的性能指标如下:频率范围:0~1Hz,以0.1Hz步进,1~500Hz,以1Hz步进;波形:矩形波或方波均可;精度:频率值的相对误差不超过±1%;功能:(1)信号发生,信号发生器以给定的频率输出信号;(2)脉冲个数计数,仪器可对本身已发出的脉冲个数进行计数;(3)设定值可存储,每次上电自动调出前次设定值。
二、初步设计在确定了性能指标后,可以进行初步设计,考虑其显示、操作等方面的要求。
1、显示部分待设定的频率值最高为500HZ,只要3位数码管即可;要求对输出脉冲计数,虽未给出要求的计数值,但3位数码管最大仅能计到999,似乎太少了一些,再考虑到该仪器以后的扩展,如希望以后能加一些高端点频(600、700、800、900、1000、2000、5000、10K等),需要更多的数码管显示,因此最终选择5位数码管显示。
2、键盘部分键盘有很多方案可供选择,如工业品中常用的三键或四键方案,当然也可以用多键(如市售有一些标准的12或16键键盘)等,经过反复比较,考虑到易制作、易使用等等诸多因素,最终将键的个数确定为5个。
键盘操作方案是仪器易用性的很重要的一个方面,这并非仪器的关键部分,但键盘、显示程序的工作量往往占据整个设计的很大的一部份。
对键盘设计,重要的是要确定各按键功能,描述出各键的具体操作。
本仪器的键设计如下:1.工作状态描述由转换键切换两种状态(1)显示设定的频率值(2)显示脉冲个数值2.键定义切换键增加键减少键开启/停止键清除键3.键操作描述切换键:切换两种工作状态增加和减少键:在显示设定频率值时按,按增加键、减少键设定频率,范围为0.1~500HZ,每按一次增加键,设定值加1,如果按着键不放,稍后进入连续状态,设定值快速增加;按减少键,设定值减1,如果按着键不放,稍后进入连续状态,设定值快速减少。
当频率设定值小于1以后,每按一次增加或减少键,设定值增加或减少0.1。
开启/停止键:开始/停止信号发生清除键:用于清除当前脉冲个数的计数值。
4.工作过程开机后,信号发生器自动运行,有信号输出,按下“开启/停止”键,则信号发生器停止工作,没有信号输出,再次按下“开启/停止”键,则信号发生器又开始工作,继续输出信号。
信号灯用于指示信号发生器工作还是停止,当有信号产生时,信号指示灯闪烁,信号发生器暂停工作时,信号指示灯灭。
三、硬件电路的设计在确定了性能指标、操作方案后,可以开始设计,首先要确定信号产生的方式。
该信号发生器的绝对精度指标不高,但是其要求的最低频率低至0.1HZ,而最高分辨也要求达到0.1HZ,如果采用模拟技术难以达到,或需要付出较高代价才能做到。
考虑到仪器的最高输出频率仅为500HZ,而且只需要提供要方波或矩形波,所以采用单片机做成全数字信号发生器。
在有了这一设计思想之后,需要确定该方案是否可行,该方案准备采用单片机的定时器产生信号,由于定时器的定时时间只能是整数,因此,不可避免会在一些频率点上产生误差,为此,用Excel对计数值、真实频率值作了测算,部分表格如表1和表2所示,经过测算表明,当采用12M晶振时,绝对误差最大约0.12HZ(492Hz处),相对误差最大约0.024%(492Hz处),可以满足要求,因此决定采用这一方案。
当然,这仅是理论值,考虑到单片机定时中断的响应时间等因素,实际的误差肯定要比这个计算值大,但是要达到±1%的精度要求并不难,而其长期工作的稳定性取决于晶振的稳定度,并且晶振频率的变化引起的输出频率的变化也很微小,因此其长期工作稳定性也很好。
以下是部份测算的表格,完整的表格在本期光盘Excel文件中。
表1 较高频率算法理论频率 t(ms) 真实频率绝对误差相对误差10 100000 10 0.00E+00 0.00E+0011 90909 11.00001 1.00E-06 9.09E-0812 83333 12.00005 4.00E-06 3.33E-0713 76923 13.00001 1.00E-06 7.69E-0814 71429 13.99992 -6.00E-06 -4.29E-0715 66667 14.99993 -5.00E-06 -3.33E-0716 62500 16 0.00E+00 0.00E+0017 58824 16.99986 -8.00E-06 -4.71E-0718 55556 17.99986 -8.00E-06 -4.44E-0719 52632 18.99985 -8.00E-06 -4.21E-0720 50000 20 0.00E+00 0.00E+00表1 较低频率算法f(hz) t(ms) 次数频率值误差相对误差0.1 10000000 5000 0.1 0.00E+00 0.00E+000.2 5000000 2500 0.2 0.00E+00 0.00E+00 0.3 3333333 1667 0.29994 -2.00E-04 -6.67E-040.4 2500000 1250 0.4 0.00E+00 0.00E+000.5 2000000 1000 0.5 0.00E+00 0.00E+00 0.6 1666667 833 0.60024 4.00E-04 6.67E-04 0.7 1428571 714 0.70028 4.00E-04 5.72E-040.8 1250000 625 0.8 0.00E+00 0.00E+000.9 1111111 556 0.899281 -7.99E-04 -8.88E-04在确定了信号发生的方式以后,综合初步设计中提出的一些技术指标要求,进一步确定具体的实施方案。
根据以往的设计经验,显示部分由单片机的P0口与P2口直接驱动;数据存储则采用串行EEPROM;信号由单片机的一个I/O口输出,并经驱动后输出。
经过上述的设计后,可以确定这个仪器的框图如图1所示。
原理框图出来后,选择一款合适的机壳,然后综合考虑按键、数码管的安装方式,以便进行更详细的设计。
数码管和按键必须安装在印板上才能安装到面板上,数码管与单片机的连线较多,5位数码管,需要13根线,再加上按键的连线共有19根,如果将单片机放在另一块板上,必然要用大量导线与键盘显示板连接,而大量的连线是我们不愿意做的,这不仅使得安装困难,而且线易折断造成故障,因此干脆将单片机也装在同一块板上,只留下电源和输出电路放在另一块板上,这样,两块板间只需3根引线即可,大大降低了装配困难,也减少了故障隐患。
整个设计的原理图,如图2和图3所示。
其中图2是主板图,提供了包括数码管显示驱动、键盘等在内的大部份功能。
从图中可以看到,该电路主要由这样几部份组成:(1)数码管显示部份,由单片机及相关外围电路构成5位数码管显示电路;(2)按键部份,按设计共有5个按键;(3)EEPROM存储器,这里选择I2C接口的AT24C01A芯片;(4)一只LED指示灯;(5)输出管脚。
以上分别需要单片机片机的13、5、3、1、1个引脚,因此,单片机共要用到23只管脚。
引脚数量确定后,即可初步确定主芯片的型号,这里选用40引脚的AT89C51单片机。
如果编程中发现内部资源(如片内RAM、ROM、定时器等)不够,可以更换为89C52等其他单片机,比较灵活。
图3是电源、输出部分,从图中可以看出,仪器的输出接口采用两种方式,即集电极开路(OC门)方式和射极输出方式,其中OC门方式是很多以频率信号为输出的仪器的标准输出方式,如光电编码器、霍尔开关等。
基于单片机的全数字信号发生器设计设备技术网时间:2010-4-13全数字信号发生器的硬件部分就介绍到这里,下一期将介绍程序的编写。
图2本仪器的程序主要由键盘、显示程序、AT24C01A读写程序、信号产生程序等部分组成。
以下对部分功能作一些分析。
一、键盘程序本仪器需要调整的数值范围较大,因此,“增加”和“减少”键必须具有快速连加和快速连减的功能,否则调整速度太慢。
这种键盘可以用多种方法来实现,关键在于设计一个正确的程序结构,图1是一种实现方法的流程图。
图1流程图程序工作时,不断地扫描键盘,第一次扫描到有键按下后如常规键盘一样,进行键值处理,处理完毕,不等待键盘释放,直接退出键盘程序。
当又一次执行到键盘程序,如果检测到键还被按着,就不再直接去键值处理程序,而是将一个计数器加1,直接返回主程序,如此循环,直到计数到一个定值(如500,表示键盘程序已被执行了500次),如果键还被按着,说明用户有连加(或连减)要求,程序即将计数器减去一个数值(如30),然后进行键值处理。
这样,以后键盘程序每执行30次,就执行一次键值处进程序,实现了第一次启动时间较长,以后快速连续动作的要求。
如果检测到键已被释放,则清除所有标志,将计数器清零,准备下一次按键处理。
程序开始时定义了两个常量:Qdsj和Ljsj,如下所示const uint Qdsj=500; /*与首次启动连加(减)功能的时间有关*/const uint Ljsj=30; /*与连加(减)的速度有关*/这两个常量与第一次启动及连加、减的速度有关,具体数值应根据实际情况试验后确定。
下面是部分键处理程序,注意其中这两个变量的使用。
void Key()/*键处理*/{ ……if(!KeyValue){…无键按下,清除一切标志退出}if(KeyMark) /*第一次检测到按键吗?*/{ KeyCounter++; /*不是第一次(KeyMark已是1了)*/if(Qdsj==KeyCounter) /*连续按着已有Qdsj次了*/{ KeyCounter-=Ljsj; /*减去Ljsj次*/KeyProcess(KeyValue,1); /*键值处理*/}else{ return ; } /* 如果按着还没有到Qdsj*/}else /*第一次检测到有键按下*/{ mDelay(10); /*延时10毫秒*/…再次检测if(!KeyValue){…清除一切标志并返回}}二、小数点的处理要在LED数码管上显示小数点,可以有两种选择,一种方式是在显示0.1~0.9时用小数显示,而在显示1~500时不显示小数点,这种方式编程略麻烦一些;另一种是使用定点的方式显示小数点,即不论是在0.1~0.9Hz段,还是1~500Hz段,均在倒数第二位点亮小数点,这种显示方式比较简单,本机采用了第二种方式。