《2021-2022收藏资料基于数字滤波的单片机仿真和C语言开发报告.doc》由会员分享,可在线阅读,更多相关《2021-2022收藏资料基于数字滤波的单片机仿真和C语言开发报告.doc(23页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、HUBEI NORMAL UNIVERSITY综合课程设计(一)Integrated Curriculum Design(1)所在院系教育信息与技术学院专业名称信息工程班级1005题目 基于单片机的数字滤波器指导教师 黎明 成员 尤杉.陈小豪.钱德超.柯俊完成时间2013.1.5 摘要I1 绪论11.1仿真软件介绍11.2数字滤波器介绍12 单片机和AD/DA相关知识32.1 51单片机相关知识32.2 AD转换器相关知识42.3 DA转换器相关知识53 数字滤波器设计63数字滤波器系统设计63.1 数字滤波器理论分析设计63.2 单片机电路73.3 数据采集电路83.4 数模转换输出电路93
2、.5 数字电压表系统电路原理图104 程序设计104.1程序流程图114.2 AD转换器程序124.3 程序代码136 心得与体会20参考文献211 绪论1.1仿真软件介绍现代工业控制系统中,电路系统越来越复杂,因而带来的相互干扰也越来越强烈,模拟滤波电路已经不能满足要求,数字滤波应运而生。数字滤波器的实现过程的实现过程是把输入的模拟信号数字化,也就是由采样器对输入的模拟信号进行周期性的采样,并对每个样本进行量化和编码,即模数转换。从ADC输出的数字信号送入到数字信号处理器进行处理变化,处理器输出的数字信号再通过数模转换为模拟信号,这个过程要用到DAC来转换实现模拟信号的输出。1.2数字滤波器
3、介绍Proteus ISIS是英国Labcenter公司开发的电路分析与实物仿真软件。它运行于Windows操作系统上,可以仿真、分析(SPICE)各种模拟器件和集成电路,该软件的特点是:(1)现了单片机仿真和SPICE电路仿真相结合。具有模拟电路仿真、数字电路仿真、单片机及其外围电路组成的系统的仿真、RS232动态仿真、I2C调试器、SPI调试器、键盘和LCD系统仿真的功能;有各种虚拟仪器,如示波器、逻辑分析仪、信号发生器等。(2)支持主流单片机系统的仿真。目前支持的单片机类型有:68000系列、8051系列、AVR系列、PIC12系列、PIC16系列、PIC18系列、Z80系列、HC11系
4、列以及各种外围芯片。(3)提供软件调试功能。在硬件仿真系统中具有全速、单步、设置断点等调试功能,同时可以观察各个变量、寄存器等的当前状态,因此在该软件仿真系统中,也必须具有这些功能;同时支持第三方的软件编译和调试环境,如Keil C51 uVision2等软件。(4)具有强大的原理图绘制功能。可以仿真51系列、AVR、PIC、ARM、等常用主流单片机。还可以直接在基于原理图的虚拟原型上编程,再配合显示及输出,能看到运行后输入输出的效果。配合系统配置的虚拟逻辑分析仪、示波器等,Proteus建立了完备的电子设计开发环境。在PROTEUS绘制好原理图后,调入已编译好的目标代码文件:*.HEX,可以
5、在PROTEUS的原理图中看到模拟的实物运行状态和过程。 PROTEUS 是单片机课堂教学的先进助手。 PROTEUS不仅可将许多单片机实例功能形象化,也可将许多单片机实例运行过程形象化。前者可在相当程度上得到实物演示实验的效果,后者则是实物演示实验难以达到的效果。 它的元器件、连接线路等却和传统的单片机实验硬件高度对应。这在相当程度上替代了传统的单片机实验教学的功能,例:元器件选择、电路连接、电路检测、电路修改、软件调试、运行结果等。 课程设计、毕业设计是学生走向就业的重要实践环节。由于PROTEUS提供了实验室无法相比的大量的元器件库,提供了修改电路设计的灵活性、提供了实验室在数量、质量上
6、难以相比的虚拟仪器、仪表,因而也提供了培养学生实践精神、创造精神的平台。2 单片机和AD/DA相关知识2.1 51单片机相关知识51单片机是对目前所有兼容intel 8031指令系统的单片机的统称。该系列单片机的始祖是intel的8031单片机,后来随着技术的发展,成为目前广泛应用的为单片机之一。单片机是在一块芯片内集成了CPU、RAM、ROM、定时器计数器和多功能I/O口等计算机所需要的基本功能部件的大规模集成电路,又称为MCU。51系列单片机内包含以下几个部件:一个位CPU;一个片内振荡器及时钟电路;4KB的ROM程序存储器;一个128B的RAM数据存储器;寻址64KB外部数据存储器和64
7、KB外部程序存储空间的控制电路;32条可编程的I/O口线;两个16位定时计数器;一个可编程全双工串行口;个中断源、两个优先级嵌套中断结构。51系列单片机如下图:图1 51单片机引脚图2.2 AD转换器相关知识ADC0809是美国国家半导体公司生产的CMOS工艺8通道,8位逐次逼近式转换器。其内部有一个8通道多路开关,它可以根据地址码锁存译码后的信号,只选通8路模拟输入信号中的一个进行A/D转换。(1)主要特性: 1)8路输入通道,8位A/D转换器,即分辨率为8位。 2)具有转换起停控制端。 3)转换时间为100s(时钟为640kHz时),130s(时钟为500kHz时) 4)单个+5V电源供电
8、 5)模拟输入电压范围0+5V,不需零点和满刻度校准。 6)工作温度范围为-40+85摄氏度 7)低功耗,约15mW。 (2)内部结构ADC0809是CMOS单片型逐次逼近式A/D转换器,内部结构如图1322所示,它由8路模拟开关、地址锁存与译码器、比较器、8位开关树型A/D转换器、逐次逼近寄存器、逻辑控制和定时电路组成。 图2 ADC0809引脚2.3 DA转换器相关知识根据对DAC0832的数据锁存器和DAC寄存器的不同的控制方式,DAC0832有三种工作方式:直通方式、单缓冲方式和双缓冲方式。主要性能如下:(1)分辨率为8位; (2)电流稳定时间1us; (3) 可单缓冲、双缓冲或直接数
9、字输入; (4) 只需在满量程下调整其线性度; (5)单一电源供电(+5V+15V); (6) 低功耗,20mW。 DAC0832引脚功能电路应用原理图DAC0832是采样频率为八位的D/A转换芯片,集成电路内有两级输入寄存器,使DAC0832芯片具备双缓冲、单缓冲和直通三种输入方式,以便适于各种电路的需要(如要求多路D/A异步输入、同步转换等)。所以这个芯片的应用很广泛,关于DAC0832应用的一些重要资料见下图: D/A转换结果采用电流形式输出。若需要相应的模拟电压信号,可通过一个高输入阻抗的线性运算放大器实现。运放的反馈电阻可通过RFB端引用片内固有电阻,也可外接。DAC0832逻辑输入
10、满足TTL电平,可直接与TTL电路或微机电路连接。图2 ADC0809引脚图2 ADC0809引脚图3 DAC0832引脚3 数字滤波器设计3数字滤波器系统设计3.1 数字滤波器理论分析设计数字滤波方法有很多种,如中值滤波、算术平均滤波、加权平均滤波,限幅滤波等等。本次课程设计我选用的是限幅滤波方法和中位值滤波法限幅滤波的基本原理是把两次相邻时刻(n和n-1)的采样值Yn和Yn-1相减,求出其差值,以绝对值表示,然后将这个差值与两次采样允许的最大偏差值Y比较,如果两次采样值的差值超过了允许的最大偏差值Y,则认为发生了随机干扰,并认为最后一次采样值Yn非法,应予剔除。剔除Yn后,可用Yn-1代替
11、Yn;若未超过允许的最大偏差值范围,则认为本次采样值有效。可用如下公式表示:|Yn-Yn-1|Y;则Yn有效|Yn-Yn-1|Y;则Yn-1有效此算法的样例子程序如下:#define A 10 /A值可根据实际情况调整char data; /上一次的数据char filter_1()char datanew; /新数据变量datanew=get_data(); /获得新数据/滤波算法uchar filter1() uchar new_value,value;value=get_data(N-2); /把第十个值给valuenew_value = get_data(N-1); / 第十一个值给n
12、ew_valueif ( ( new_value - value A ) | ( value - new_value A ) ) /如果差值大于0.002 return value; return new_value;/中位值滤波算法void filter2() int count,i,j; /定义存储数据的数组 uchar temp; /定义存储数据的数组for(count=0;countN;count+) /获取数据 bufcount=get_data(count); for(j=0;jN-1;j+) /用冒泡法对数据进行排序,当然最好用其他排序方法 for(i=0;ibufi+1) te
13、mp=bufi; bufi=bufi+1; bufi+1=temp; res=buf(N-1)/2; /11个数排序后取中间的数值该算法主要用于处理变化比较缓慢的数据,如温度、物体的位置等。使用时关键在于最大偏差值的y的选择,通常可根据经验获得,也可按照输出参数可能的最大变化速度Vmax及采样周期T来决定Y的值,即Y=VmaxT。3.2 单片机电路单片机最小系统如下图所示,各个引脚都已经标出。图4 单片机最小系统使用51系列单片机AT89C51,利用这个单片机进行编程,实现对输入信号的滤波。我使用了P0口作为接受AD转换的结果的端口,而P1口则输出数据到DA转换器。另外还利用了P2作为控制端口
14、,P2.0-P2.2用来控制AD转换器,而P2.3-P2.6外接四个开关,用来实现滤波方式的选择。3.3 数据采集电路由于ADC0809是带地址锁存的模数转换器件,ADDA、ADDB、ADDC为模拟通道选择,编码为000111分别选中IN0IN7。ALE为地址锁存信号,其上升沿锁存ADDA、ADDB、ADDC的信号,译码后控制模拟开关,接通八路模拟输入中相应的一路。CLK为输入时钟,为AD转换器提供转换的时钟信号,典型工作频率为640KHz。START为AD转换启动信号,正脉冲启动ADDAADDC选中的一路模拟信号开始转换。OE为输出允许信号,高电平时候打开三态输出缓存器,是转换后的数字量从D
15、0D7输出。EOC为转换结束信号,启动转换后EOC变为低电平,转换完成后EOC编程高电平。图5 ADC模数转换3.4 数模转换输出电路这里我用了DA0832来进行数模转换。DA0832的引脚图如下图所示:图6 DAC数模转换DA0832有三种数模转换方法,直通方式、单缓冲方式、双缓冲方式,因为单片机输出后可以直接进行数模转换,所以这里我采用了不需要单片机控制的最为简单的直通方式,但是DA0832若用于直通方式。若用于直通方式下,则GND均接地,而VCC和ILE则接正电源。VREF是参考电源。IOUT1、IOUT2是两个输出端。DA0832输出的是电流,要利用运算放大器转换成电压信号。3.5 数
16、字电压表系统电路原理图 如下是此次设计仿真的数字滤波器电路总原理图。此图总共分为三个部分,分别是采用电路ADC,处理分析部分单片机,调理信号输出部分DAC。图8 数字滤波器设计总原理图4 程序设计4.1程序流程图开始结束初始化AD采样量化单片机处理DA转换输出图9 程序流程图4.2 AD转换器程序因为START为转换启动信号,在其上跳变时,所有内部寄存器清零,在其下跳变时,开始进行AD转换。所以设计程序时,要先让START为0,在让START为1,最后让START为0。开始采集数据后就要让OE为1,进行数据输入。同时数据采集结束时,利用查询语句,查看EOC是否为1,如果是1,则处于等待状态,如
17、果变成1,则可以进行数据输入了。AD转换的程序如下:START = 0;START = 1;START = 0;while(EOC=0);OE = 1;a = P0;这里a是一个变量,用来存储AD输入的数据4.3 程序代码#include #define uchar unsigned char#define A 0.002#define N 11sbit con1=P10; /滤波方法选择sbit con2=P11;sbit key=P14; /控制是否滤波sbit led=P15;sbit OE=P30;sbit START=P31;sbit EOC= P32;sbit CLOCK=P34;
18、uchar a;uchar res;uchar bufN =0;void ADC0808();/模数转换函数声明void change(); /数值更新函数声明uchar get_data(n);uchar filter1(); / 限幅滤波函数声明void filter2(); /中值滤波函数声明void delay(uchar z);void inint();void main() /主函数while(1) inint(); ADC0808(); P2=res; void ADC0808() START = 0; START = 1; START = 0; led=0; EOC=EOC;/
19、取反负跳变进入外部中断 delay(1);if(key=0) if(con1=0) /选择限幅滤波 res=filter1(); if(con2=0) /选择中值滤波 filter2(); else res=a; void change()uchar i;for(i=0;i A ) | ( value - new_value A ) ) return value; return new_value; /中值滤波法void filter2() int count,i,j; /定义存储数据的数组 uchar temp; /定义存储数据的数组for(count=0;countN;count+) /获
20、取数据 bufcount=get_data(count); for(j=0;jN-1;j+) /用冒泡法对数据进行排序,当然最好用其他排序方法 for(i=0;ibufi+1) temp=bufi; bufi=bufi+1; bufi+1=temp; res=buf(N-1)/2; /11个数排序后取中间的数值 void exter0() interrupt 0 led=1; P0=0xff; /P0端口作为输入预先置1 OE = 1; /使能输出置1 a = P0; OE=0; /使能输出关闭 void timer0() interrupt 1 /产生500KhZ 提供给ADC0808TH0
21、=(65536-2)/256;TL0=(65536-2)%256;CLOCK=CLOCK;void timer1() interrupt 3 / 采样频率20HZTH1=(65536-50000)/256;TL1=(65536-50000)%256; a = P0;void inint() TMOD=0x11; /设置定时器工作方式 TH0=(65536-2)/256;/装初值 TL0=(65536-2)%256; TH1=(65536-50000)/256; TL1=(65536-50000)%256; EA=1; / 开总中断 ET0=1; /开定时器0中断 TR0=1; /启动定时器0中
22、断 ET1=1; /开定时器1,启动定时器1 TR1=1;EX0=1; /开外部中断 IT0=1; /外部中断触发方式 void delay(uchar z)/延时函数uchar x,y;for(x=z;x0;x-)for(y=110;y0;y-);5 仿真及结果分析通过正确的编写程序和不断调试发现,比较理想的滤波效果的仿真结果如下图所示限幅滤波的效果:图10 仿真结果限幅滤波的效果是和A值有关的,一般情况下,A值越小,则代表允许的噪声要越小,限幅滤波很适用于使幅值突变的噪声。限幅滤波适用于变化缓慢的场合,比如主要用于处理变化比较缓慢的数据,如温度、物体的位置等。使用时关键在于最大偏差值的y的
23、选择,通常可根据经验获得。而且通过仿真过程中不断修改A的值,滤波效果会明显发生变化,通过改变信号的频率,滤波的结果也会发生明显变化,当信号的频率过高时,滤波效果会使最终的波形发生明显的失真现象。6 心得与体会通过与同学的讨论与认真计算设计分析所完成的,课程设计的任务是设计、组装并调试一个数字电压表测量系统。需要我们综合运用单片机等课程的知识,通过查阅资料、方案论证与选定;设计和选取电路和元器件;分析指标及讨论,完成设计任务。在这次课程设计中,我学会了怎样去根据课题的要求去设计电路和调试电路。动手能力得到很大的提高。从中我发现自己并不能很好的熟练去使用我所学到的高频电路知识。在以后学习中我要加强
24、对使用电路的设计和选用能力。但由于电路比较简单、定型,而不是真实的生产、科研任务,所以我们基本上能有章可循,完成起来并不困难。把过去熟悉的定型分析、定量计算逐步,元器件选择等手段结合起来,掌握工程设计的步骤和方法,了解科学实验的程序和实施方法。这对今后从事技术工作无疑是个很好的训练。通过这种综合训练,我们可以掌握电路设计的基本方法,提高动手组织实验的基本技能,培养分析解决电路问题的实际本领,为以后毕业设计和从事电子实验实际工作打下基础。同时也让我充分认识到自己的空想与实践的差别,认识莫眼高手低,莫闭门造车,知识都在不断更新和流动之中,而扎实的基础是一切创造的源泉,只有从本质上理解了原理,才能更
25、好的于疑途寻求柳暗花明,实现在科学界的美好畅游和寻得创造的快乐。还有就是每次在组团做试验都会感觉特别的充实,我们可以按照自己设计的电路去完成,老师也不是死板的要求我们怎么怎么,而是给了我们尽可能大的自己决定的余地,这次的元器件都是按照我们设计出来的电路参数给定的,而且每位老师都很耐心的为我们解决试验中所出现的问题,最后真心的感谢老师对我们课程设计的建议和帮助,我们才得以圆满的完成这次课程设计!参考文献1 李群芳,肖看.单片机原理接口与应用.北京:清华大学出版社,20052余永权.ATMEL89系列单片机应用技术.北京:北京航空航天大学出版社,203陈小忠.单片机实用接口技术子程序.人民邮电出版社,20054阎石.数字电子技术基础(第三版).北京:高等教育出版社,20035高峰.单片微机应用系统设计及应用技术.北京:机械工业出版社,20046 郭天祥 51单片机c语言教程.电子工业出版社22