标题:
基于AT89C51单片机和555芯片构成的多谐振荡电路电容测量
[打印本页]
作者:
84533243
时间:
2015-3-14 19:51
标题:
基于AT89C51单片机和555芯片构成的多谐振荡电路电容测量
/*********************************************************************************************************</这种电容测量方法主要是通过一块555芯片来测量电容,让555芯片工作在直接反馈无稳态的状态下,555芯片输出一定频率的方波,其频率的大小跟被测量的电容之间的关系是:f=0.772/(R*Cx),我们固定R的大小,其公式就可以写为:f=k/Cx,只要我们能够测量出555芯片输出的频率,就可以计算出测量的电容。计算频率的方法可以利用单片机的计数器T0和中断INT0配合使用来测量,这种研究方法相当的简单。
*********************************************************************************************************/
#include "reg51.h"
#include"intrins.h
#define DATA P0
sbit RW=P2^1;//1602写数据
sbit RS=P2^0;//1602写地址
sbit EN=P2^2; //1602工作使能
sbit b_test=P3^7; //控制小灯的亮灭
sbit _reset=P3^5; //555时基芯片工作控制信号
unsigned int T_flag,N,C,i,Dis1,Dis0;
unsigned int b[6]={0X13,0X0D,0X00,0X00,0X40,0X16}; //显示C=00pF</FONT></P>
/***********延时1MS******************/
void Delay1ms(unsigned int mm)
{unsigned int i;
for(mm;mm>0;mm--)
for(i=100;i>0;i--);
}
/***************检查忙否*****************/
void Checkstates()
{
unsigned char dat;
RS=0;
RW=1;
do{EN=1;//下降沿
_nop_();//保持一定间隔
_nop_();
dat=DATA;
_nop_();
_nop_();
EN=0;
}while((dat&0x80)==1);
}
/**************LCD写命令函数*********/
void wcomd(unsigned char cmd)
{
Checkstates();
RS=0;
RW=0;
DATA=cmd;
EN=1;
_nop_();
_nop_();
_nop_();
_nop_();
EN=0;
}
/**********LCD写数据函数**************/
void wdata(unsigned char dat)
{
Checkstates();
RS=1;
RW=0;
DATA=dat;
EN=1;
_nop_();
_nop_();
_nop_();
_nop_();
EN=0;
}
/*****************初始化********************/
void LCDINIT()
{
Delay1ms(15);
wcomd(0x38);//功能设置
Delay1ms(5);
wcomd(0x38);//功能设置
Delay1ms(5);
wcomd(0x01);//清屏
Delay1ms(5);
wcomd(0x08);//关显示
Delay1ms(5);
wcomd(0x0c);//开显示,不开光标</FONT></P>
<P><FONT color=black>}</FONT></P>
<P><FONT color=black>/***********显示函数**************/
void Display(void) //显示函数
{
unsigned char i,j;
unsigned char a[12]={0X4D,0X45,0X41,0X53,0X55,0X52,0X45,0X4D,0X45,0X4E,0X54,0X53};//显示measurements
LCDINIT();
for(i=0;i<12;i++)//写显示第一行
{ wcomd(0x80+i);
Delay1ms(1);
wdata(a[i]);
Delay1ms(1);
}
for(j=0;j<6;j++)//写显示第二行
{
wcomd(0xc0+j);
Delay1ms(1);
wdata(0x30+b[j]);
Delay1ms(1);
}
Delay1ms(150);</FONT></P>
<P><FONT color=black>}
void main()
{
IE=0x81; //打开全部的中断控制,并开启外部中断允许
TMOD=0x09; //T0为16位计数工作方式1
IT0=1; //设置外部中断的触发的方式为脉冲触发
TH0=0x00;
TL0=0x00;
T_flag=0;
_reset=0;
b_test=1;
while(1)
{
//while(!b_test) //如果有测量按键输入就往下执行
//{
i=0;
_reset=1; //启动555时基芯片
EX0=1; //开启中断0
while(_reset) //超出等待时间,中断还没有过来,就退出
{
i++;
if(i>50000) //设置最长等待时间
{
_reset=0; //最长等待时间到还没有中断,停止555
}
}
if(N<100) //如果计数值小于100,显示SM,表示应换用小一点的量程
{
b[3]=0X1D;
b[2]=0X23;
}
if(N>50000) //如果计数值大于5000,显示LA,表示应换用大一点的量程
{
b[3]=0X11;
b[2]=0X1C;
}
if(N>=100 && N<=50000)
{
C=N/100; //计算电容的大小
b[2]=C/10; //计算电容值的十位
b[3]=C-b[2]*10; //计算电容值的各位
}
//}
Display(); //显示电容的大小
if(C>40)
b_test=0;
else
b_test=1;
}
}
void int0(void) interrupt 0 //第一次中断开始计数,第二个中断停止计数
{
T_flag=!T_flag;
if(T_flag==1)
{
TR0=1; //开始计时
}
if(T_flag==0)
{
TR0=0; //停止计时
EX0=0; //关闭中断
_reset=0; //停止发出方波
N=TH0*256+TL0; //计算计数器的值
N=N*5/3;
TH0=0x00; //恢复初值
TL0=0x00;
}
}[audio]http://play.baidu.com/?__m=mboxCtrl.playSong&__a=233111&__o=song/233111||playBtn&fr=altg3||www.baidu.com#[/audio]
复制代码
单片机电容测量.rar
2015-3-14 19:51 上传
点击文件名下载附件
下载积分: 黑币 -5
70.94 KB, 下载次数: 250, 下载积分: 黑币 -5
作者:
1617886226
时间:
2017-1-22 09:47
谢谢楼主的分享,现在正在研究这个,刚好能用到
作者:
泪水绽放笑容
时间:
2017-4-2 15:02
最近我也在做这个东西 好东西 值得收藏
作者:
guo6339419
时间:
2017-7-2 21:34
问一下为什么要N=N*5/3呢?
作者:
鱼唇的人类
时间:
2019-4-1 22:05
R1和R2应该多大?
作者:
无言。
时间:
2020-4-13 23:01
有仿真电路吗
作者:
行走的播放器
时间:
2020-10-3 09:35
可以,横清楚
作者:
JasonW
时间:
2020-10-9 11:49
为什么LCD没有显示
作者:
叶,起飞
时间:
2021-10-7 20:18
楼主,你这个测试方法得到的电容值误差咋样,我也是用这个方法测的,但是误差有时候大有时候小
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1