ImageVerifierCode 换一换
格式:DOCX , 页数:31 ,大小:904.93KB ,
资源ID:23292828      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/23292828.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(基于单片机的数字电容测量仪.docx)为本站会员(b****2)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

基于单片机的数字电容测量仪.docx

1、基于单片机的数字电容测量仪 电子技术实验报告 设计课题 基于单片机的数字式电容仪设计 学 院 信科院 姓 名 陈见峰 学 号 10 专业班级 电信10-1 指导教师 蒋存波 设计时间 【摘要】 随着科技的不断发展,人类的不断进步,在电子技术领域的发展可谓突飞猛进,然而电容器在电子线路中得到广泛的应用,它的容量大小对电路的性能有着重要的作用。因此,电容量的测量在日常使用中就不可避免。本设计详细介绍了一种基于单片机的数字式电容测量仪设计方案及实现方法。设计的主要方法是采用555芯片构成单稳态触发器,将电容容量转换为脉冲宽度。通过单片机的计时器测量脉宽, 根据已知的R值,通过单片机的运算功能,计算出

2、电容容量,最后,再通过单片机的普通I/O口控制液晶屏显示出电容容量的计算结果。系统的测量范围为10pF 500uF, 具有多个量程,可根据用户需要由用户选择,与用户的交互是通过键盘实现,不同量程的实现是通过单片机的I/O口控制继电器的吸合与断开来选择不同的R值,从而实现不同的量程。同时,本设计注重设计方法及流程,首先根据原理设计电路,再通过protues仿真,利用keil编程,进而借助altium designer 制作PCB,最后到焊接元器件,调试直至成功。【关键词】 电容测量; 脉冲宽度; 单稳态触发器; 单片机; lcd显示1 系统方案设计 设计说明及要求 设计说明框图中的外接电容是定时

3、电路中的一部分。当外接电容的容量不同时,与定时电路所对应的时间也有所不同,即C=f(t),而时间与脉冲数目成正比,脉冲数目可以通过计数译码获得。 设计要求(1)基本要求 自制稳压电源。 被测电容的容量在10pF至10000F范围内 设计四个的测量量程。 显示测量结果,测量误差小于%。 数字显示:显示分辨率:每档满量程的%;电容测量:电压可选择5V,25V,50V;为实现该设计,达到相应的设计要求,本次设计中考虑了三种设计方案,三种设计方案中主要区别在于硬件电路和软件设计的不同,对于本设计,三种方案均能够实现,最后根据设计要求、可行性和设计成本的考虑选择了基于STC89C52单片机和555芯片构

4、成的单稳态触发电路测量电容的方案。现在一一介绍论证如下。方案如果三角波输入给以被测电容器作为微分电容的微分电路,在电路参数选择适当的条件下,微分电路的输出幅度与Cx成正比,再经峰值检测电路或精密整流及滤波电路,可以得到与Cx成正比的直流电压Ux ,然后再进行A/D转换送给数字显示器,便可实现所要求的函数关系。(电路如图11所示)设三角波函数式为:UI=K(0 1) UI=K(2) 因为所以 (0 1) (2) 图1-1 方案电容测量框图方案根据积分电路原理可得C=Ui*dt/R*Uo,将经过RC充电电路后,输出的与电容对应的电压值输入到ADC0809中,经过处理后,将相应的数值传到单片机里,再

5、通过公式运算,求得相应的电容C值,在LCD上显示。图1-2 方案电容测量框图方案单稳态触发器接收单片机的窄脉冲触发信号Trig, 输出一个脉冲宽度与待测电容CX 的容量成正比的信号VO。单片机通过检测VO 高电平持续时间来计算电容大小,并将结果显示在液晶屏上。测量过程中, 通过控制单稳态触发器的充电电阻阻值, 实现10pF 500uF 范围内电容的测量。(电路如图1 - 3所示)图1-3 方案电容测量框图 三种方案作简单的比较比较上述三种方案可知,方案和采用了A/D转换器,价格比较昂贵;而且根据公式可知,再换算电压与电容值时,时间参数t起着至关重要的作用,对t的计算要精确,不然误差值会很大,所

6、以调试起来有一定难度;方案电路简单,原理清晰,易于实现,易于控制,本设计就是基于方案展开的。2 单元电路设计 工作原理系统测量的电路原理图如图2-1 所示。电路主要由单片机U1、NE555 定时芯片U2 和检测电容CX 组成。NE555 定时器芯片的6 脚与7 脚相连, 与电阻R和待测电容CX 组成单稳态触发电路。图2-1 系统测量原理图由图2-1可知, NE555 定时器内部主要由电阻分压器、电压比较器OP1 OP2 、与非门G1 G3、输出缓冲反相器G 4 和集电极开路的三极管T 组成。G1、G 2 构成基本RS 锁存器。电阻R1 和电容C1 构成NE555 定时器的上电自动复位电路。复位

7、之后, G3的输出为高电平, 三极管T 处于饱和状态, 待测电容CX 被短路。单片机P37 引脚在上电时的默认电平是高电平。可见, 上电复位后, 比较器OP1、OP2 的输出为高电平, R = S = 1, RS 触发器处于保持状态, 单稳态触发器输出稳态0。系统需要测量时, 单片机的P37 引脚上输出负向窄脉冲VTR 控制单稳态触发器进入暂态, 即可实现一次测量。工作时序图如图2-2 所示。VTR 电平变低后, 比较器OP 2 的输出为低电平。此时, S = 0, R =1, RS 触发器处于置1 状态, 单稳态触发器进入了暂态1。G3 输出的低电平使三极管T 截至, 电源通过电阻R 开始对

8、待测电容充电, 如图2-2 的VCX 波形所示。当VCX 上升到电源电压的三分之二后, 比较器OP1翻转, 使得R = 0。由于VTR 的脉冲宽度为T1 , 在VCX升到三分之二电源电压前已经拉高。此时, R = 0, S= 1, 单稳态触发器的暂态1 结束, 返回到稳态0, 暂态的持续时间为TW , 如图2-2 的VO 波形所示。在暂态期间, 如果VTR 的低电平宽度变为T2 , VCX 到达翻转点后还没有变高, 基本RS 触发器就会进入到R = 0,S = 0的禁止状态, 输出VO 的波形无法预测, 测量出错误结果。因此, 要保证T1 Tw ,导致测量错误。而利用中断,可以直接在中断函数中

9、产生一个固定时间的低脉冲,保证了测量条件,避免发生错误。图2-5 按键产生低脉冲电路2.2.4 键盘电路如图2-6所示键盘电路主要用于与用户进行交互,如用户需要选择量程时,就必须交互。键盘分为独立键盘和矩阵键盘,这里只需要实现量程的选择,共四个量程,故无需矩阵键盘,4个独立按键就完全够用了。图2-6 键盘电路2.2.5 指示灯电路如图2-7所示,指示灯主要用于给用户以提示,如当前量程提示,超量程提示等等。 D2用于超量程提示,D6用于电源提示。图2-7 指示灯电路2.2.6 量程选择电路在图2-4中可以看到,在RC充电回路中,R值是固定的,不可变的,那么量程也显然是不可变的,因此,需要在此加入

10、可调节充电回路电阻的电路部分,这里,利用继电器可以简单实现。具体电路如图2-8所示,利用继电器时需特别注意,由于单片机输出电流是很小的,不足以驱动继电器吸合,因此要加驱动电路,在这里,选择ULN2003芯片来实现。当然,也可以利用典型的三极管驱动来实现,虽然选择的是芯片实现驱动,在这里也将典型的三极管驱动电路列于此。如图2-9所示。图2-8 实现量程选择电路图2-9 利用三极管的驱动电路2.2.7 液晶显示电路 如图2-10所示,lcd接与P1口,用于显示电容值以及一些相应的测量信息。图2-10 lcd显示电路至此,整个电容测量仪的硬件设计部分就设计好了,接下来,需要的就是与之相匹配的软件支持

11、了。 软件设计软件编程平台选择最常用的keil软件。由于该程序并未涉及到底层的驱动问题,因此选择方便快捷的C语言编程。在编程中,将该程序分为三个模块:延时模块,1602显示模块及主函数模块。方便调试与理解。具体程序见附录二。总体程序较长,但并不复杂,可根据需要重点看主函数,与硬件电路结合起来,注重程序后紧跟的注释,理解起来是比较容易的,在此就不再一一详细分析。 量程范围设置由于量程的选择是非常重要的一个环节,在这里单独讨论量程的选择。系统采用单片机片内16 位的定时器测量TW 的宽度, 标准计数脉冲的周期为1 微秒时, 为确保计数器不发生溢出, 要求TW 1 微秒。当TW 100 微秒以上时,

12、 可忽略量化误差的影响。为满足10pF 500uF 的测量范围, 可通过设置不同充电电阻R 的阻值来实现。理论计算的电阻R 阻值、理论量程范围以及系统选择的量程范围如表2-1 所示。系统分为四个量程, 可测量10pF 500uF 的电容。表2-1 R值与量程范围的关系R值(欧姆)理论量程范围选择的范围10M9pF 5. 9nF10pF 5nF100K900pF 590nF5nF 500nF1K90nF 59uF0. 5uF 50uF100900nF 590uFF 50uF 500uF altium designer 原理图设计及PCB制作2.4.1 原理图设计图2-11 原理图设计2.4.2

13、PCB制作图2-12 PCB设计在此并没有布双层板,红色的线仅仅只是为了标志出跳线。2.4.3 设计结果图2-13 设计结果实物图各个按键功能如图中文字说明。3系统测试由于该作品需实现的功能仅为测电容,在此不列出其他的测试。 测量100pf的电容在此以100pf电容测试为例,演示整个测试过程。测试标称值为101的电容,即测量电容值为100pf的电容。104的电容实物如图2-14所示。测试结果如图2-15所示。若量程选择错误,测试结果如图2-16所示。图2-14 100nf的电容实物图2-15 2nf电容正常测试图2-16 量程错误情况下的测试 测量的电容再以测试电容为例,测试结果如图2-18所

14、示。图2-18 测试的电容 测试结果将测量的一系列电容的电容值与标准值比较。比较结果如表3-1。表3-1 测量值与标准值比较标准值测量值误差100pf1%2nf2nf0%0%100uf1%由表3-1中数据可知,平均误差是%,低于设计扩展要求的%,测量范围是10pf500uf,基本满足设计要求的10pf10000uf。测量结果由液晶直观显示。综合以上分析,该设计满足整体设计要求。 误差分析由于产生的%左右的误差,在这里简要分析一下误差产生的原因。电容测量的误差主要由NE555 定时器构成的单稳态触发电路的非线性误差T 、计数器的量化误差?N 和标准计数脉冲的频率偏移TC 产生2 3 。因此有:系

15、统采用的标准计数脉冲来自单片机内核时钟, 由片外的高精度晶振与片内电路自激振荡产生,频率非常稳定, 可以忽略其频偏对测量结果的影响。量化误差?N 是数字电路的特有误差, 最坏的情况下等于 1。如采用12M 的晶振, 可获得1MHz 的标准计数脉冲, 量化产生的最大误差为1 微秒。通过设置充电电阻R 的阻值, 使TW 达到毫秒级时, 量化误差的影响非常小, 可以忽略。非线性误差是由器件的非线性特性产生的, 可通过硬件参数修正和软件算法补偿来减小。4 结论与心得体会 经过本次历经4周的实习,使得我又进一步对单片机系统,尤其测量电容的电路系统有了深一步认识。在做前期准备工作时,老师不希望我们用555

16、芯片做这个实验,因为如果是555芯片震荡电路来测量的话,虽然制作原理简单,但测量值会很不稳定,测范围也不够广。可出于坚信化繁为简的信念,在没做过实物的情况下,我们还是硬着头皮还是想验证下事实是不是如此(如果不成功再改换方案)。 起初查阅了很多资料,比如伏安法中的自由轴法制作测量电容电路,LC震荡侧电容电路等,老师也推荐了方案二中的积分法测量电路,但因为在进行理论计算时,因为积分测容法中C=Ui*dt/Uo*R,而我们无法精确确定ADC在输出口的传输时间(哪怕是几十us),所以有种无法掌控误差的感觉,再加上出于成本考虑,所以没有首选这种方法。而对于利用555芯片单稳态触发这种法案的分析,我则很相

17、信,这个电路是可以实现测量功能的,并且只要输出稳定,我就可以做相应补偿。 在经过一系列的仿真,实物制造和调整后,最初做出来的板子并不能运行的,后面反复彻查后,才发现原来自己的设计出现了差漏,少连或错连了一些关键线路,于是又重新修整过。经过修正后的电路中终于可以开始进行测量了,起初的测量只有在nf档和10uf以下档位下,测量值是基本满足要求的,而PF裆和100uf以上的档位并不满足已要求的,甚至不够稳定,所以我开始将挡位缩小,将10pf10000uf的要求,缩减为100Pf500uf,果然修正后的电路,测量稳定了。再经过软件补偿后,最终获得了在精度上可以满足要求的方案。(Ps:因为最初设计的时候

18、只选择了4个挡位,而手上电容最大才470uf,出于“最稳定测量”的考虑,所以才改的100pf500uf挡位。即:本方案也可能可以测量500uf以上的电容,只要将其中的100欧姆电阻改小即可。)5 参考文献【1】 单片机基础第三版 李广弟 朱月秀 冷祖祁 编着 北京航天大学出版社,2007【2】 数字式电容测量仪设计 张玉芹, 洪远泉 廊坊师范学院学报(自然科学版) 2011 年6 月 第11 卷第3 期【3】梁艳霞,基于单片机控制的电容测试仪设计,总裁,2009.【4】徐思成,一种基于单品啊及只能电容测试仪的设计与实现,现代电子技术,2010【5】陶春明,单片机使用技术,北京:人民邮电出版社,

19、2008【6】何立民,单片机应用程序设计,北京:北京航空航天大学出版社。【7】陈世良,吴凌燕,丁国臣,基于AT89C2051单片机的数字电容表设计,2009【8】童诗白,华成英,模拟电子技术基础第三版,北京,高等教育出版社,2007【9】熊筱芳,郭学提,基本89C51单片机的数字电容表设计,自动化应用技术,2008【10】何光明,杨健宇,C语言程序设计与应用开发, 北京:清华大学出版社,2006.6 附录 附录1 元器件清单(1)晶振12M一个(2)stc89c52芯片一片(3)30pf 2个;10uf 1个;470uf 1个; 2个; 1个;1nf 1个(4)40脚活动底座一个(5)lcd液

20、晶一个(6)按键6个(7)发光二极管6个(8)9引脚排阻 1个(9)680 6个;10k 1个;1k 2个;1k滑动变阻器 1个;10M 1个;100k 1个;100 1个;2k 1个;200 1个;(10) 开关1个(11) 整流桥1个(12)7805稳压芯片1片(13) 继电器 3个(14) ULN2003 1片(10)排针若干,杜邦线若干附录2 程序清单分5个文件:, ,(a) 程序清单:#ifndef _delay_h_#define _delay_h_#define uchar unsigned char#define uint unsigned intvoid delay_us(u

21、int cnt);void delay_ms(uint cnt);#endif(b) 程序清单:#include void delay_us(uint cnt) uchar i; for(;cnt0;cnt-) for(i=0;i0;cnt-) for(i=0;i125;i+) ; (c) 程序清单:#ifndef _1602_h_#define _1602_h_#include sbit RS = P22; 免tw的值被更/改 即不需要测量时,一直保持 EX1 = 1; / 开外部中断1 else / 反之,证明没有计数,无电容,默认值tw置0 tw = 0; ftemp = tw / ;

22、/ 计算电容值 根据公式 tw = * R * C c = (unsigned long int)(ftemp )*100; /扩大了一百倍 便于后续程序/取两位小数点 process(c); / 调用数据处理函数,根据不同的R值进行处理 if(flag = 1 ) / 数据处理结束 每次处理结束,证明需要更新显示的数据 if(tw=50000 | ledclc = 0) / 量程超出 dispchar3(zimu1); / 量程太高 ledclc = 0; else if(tw=100 & ledclc = 1) /量程太低 dispchar3(zimu5); ledclc = 0; els

23、e dispchar1(zimu2); disp(temp); flag = 0; keyscan(); void timer0() interrupt 1 / 定时器0中断 用于超量程提示 ledclc = 0;void exint1 () interrupt 2 / 外部中断0 用于产生低脉冲,启动555定时器 unsigned char a; tr = 1; / tr端一个负脉冲 a = 1; while(-a); tr = 0; a = 20; while(-a); tr = 1; / tr端负脉冲结束 大约40us的负脉冲 need = 1; / 表示需要测量 ledclc = 1;

24、 / 关闭先前的超量程提示 EX1 = 0; / 暂时关闭外部中断,一次测量结束,再开放外部中断void process(unsigned long int c) if(R = 1) / 10M 的电阻 量程10pf 5000pf c = c /10; lcd_pos(0x4a); LCD_write_Data( ); LCD_write_Data(p); LCD_write_Data(f); LCD_write_Data( ); LCD_write_Data( ); if(R = 2) / 100k 的电阻 量程5nf 500nf c = c /100; lcd_pos(0x4a); LCD

25、_write_Data( ); LCD_write_Data(n); LCD_write_Data(f); LCD_write_Data( ); LCD_write_Data( ); if(R = 3) /1k欧姆 的电阻 量程 50uf c = c /1000; / 扩大了一百倍 单位 c = tw/500 uf lcd_pos(0x4a); LCD_write_Data( ); LCD_write_Data(u); LCD_write_Data(f); LCD_write_Data( ); LCD_write_Data( ); if(R = 4) /100欧姆 的电阻 量程50uf 500

26、uf c = c /100; / 扩大了一百倍 单位 c = tw/500 uf lcd_pos(0x4a); LCD_write_Data( ); LCD_write_Data(u); LCD_write_Data(f); LCD_write_Data( ); LCD_write_Data( ); temp0 = c / 100000; / 千位 temp1 = c / 10000 % 10; / 百位 temp2 = c / 1000 % 10; / 十位 temp3 = c / 100 %10; / 个位 temp4 = c / 10 % 10; temp5 = c % 10; flag = 1;void keyscan() if(key1 = 0) delay_ms(10); if(key1 = 0) / b3按下 while(key1=0); R = 1; / 10M 的电阻 量程10pf 5000pf(5nf) con1 = 1; con3 = 1; con2 = 0; ledclc = 1; dispchar1(zimu3); dispchar2(zimu4); if(key2 = 0) / b4按下 delay_ms(10); if(key2 = 0) while(key2=0); R = 2; / 100k 的电阻 量程5nf 500nf

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1