找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1885|回复: 1
收起左侧

关于测量脉冲占空比的C程序

[复制链接]
ID:294506 发表于 2018-3-20 14:50 | 显示全部楼层 |阅读模式
#include<reg51.h>
#include"lcd.h"
sbit P32=P3^2;                  
sbit P37=P3^7;
//unsigned char io;
void delay(uint x);
unsigned  int s0=0,s1=0,t0,t1,io1,io2,max=0,min=50000,k;


void timer0(void) interrupt 1    //定时器0服务程序
{
   s0++;
}

void timer1(void)interrupt 3    //定时器1服务程序

{
   s1++;
}


void main(void)
{ float io;
  LcdInit();
  TMOD=0xa2;       //定时器模式,1为2方式,但GATE为1
  EA=1;

  P32=1;           //p32,int0口先给低电平

  ET0=1;
  TH0=0x9c;
  TL0=0x9c;


  ET1=1;
  TH1=0x9c;
  TL1=0x9c;

    LcdWriteCom(0x80);
        LcdWriteData('B');
        LcdWriteData('-');
        LcdWriteData('-');
        LcdWriteData('M');
        LcdWriteData('A');
        LcdWriteData('X');
        LcdWriteData(':');

        LcdWriteCom(0x8f);
        LcdWriteData('%');

        LcdWriteCom(0x80+0x40);
        LcdWriteData('B');
        LcdWriteData('-');
        LcdWriteData('-');
        LcdWriteData('M');
        LcdWriteData('I');
        LcdWriteData('N');
        LcdWriteData(':');

        LcdWriteCom(0x80+0x4f);
        LcdWriteData('%');               
           while(P32);       //这两次是为了去除半沿
     while(!P32);
         delay(2000);
         P37=1;
  while(1)
  {         while(P37==1)
  {
     while(P32);       //这两次是为了去除半沿
     while(!P32);
     TR0=1;               //开始计时
     TR1=1;
     while(P32);
     TR0=0;               //T0停
     while(!P32);
     TR1=0;               //T1停
     if(s0>50&&s1>50)
      {
       t0=s0;
       t1=s1;
       }
    else
      {
        t0=s0*100+(TL0-0x9c);
        t1=s1*100+(TL1-0x9c);
       }

      io=(10*t1/t0);           //浮点数据提高精度
          
                   io1=10000/io;           //整型数据便于显示
         
                io2=io1*10;           //浮点数据提高精度
          
           if(io2<min)
           {
                   min=io2;
           }
           else if(io2>max&&50000>io2)
           {
                   max=io2;
           }
          
          
          
                LcdWriteCom(0x89);
                LcdWriteData('0'+max/1000);                       
                LcdWriteData('0'+max%1000/100);
                LcdWriteData('.');       
                LcdWriteData('0'+max%100/10);               
                LcdWriteData('0'+max%10);
       
        LcdWriteCom(0x80+0x49);
                LcdWriteData('0'+min/1000);                       
                LcdWriteData('0'+min%1000/100);
                LcdWriteData('.');       
                LcdWriteData('0'+min%100/10);               
                LcdWriteData('0'+min%10);
       
                 delay(3);
      t0=0,t1=0,s0=0,s1=0;       //清值
      TL0=0x9c;
      TL0=0x9c;
         }
         while(P37==0)
         {
                 LcdWriteCom(0x80);
        LcdWriteData('B');
        LcdWriteData('-');
        LcdWriteData('-');
        LcdWriteData('M');
        LcdWriteData('A');
        LcdWriteData('X');
        LcdWriteData(':');

        LcdWriteCom(0x8f);
        LcdWriteData('%');

        LcdWriteCom(0x80+0x40);
        LcdWriteData('B');
        LcdWriteData('-');
        LcdWriteData('-');
        LcdWriteData('M');
        LcdWriteData('I');
        LcdWriteData('N');
        LcdWriteData(':');

        LcdWriteCom(0x80+0x4f);
        LcdWriteData('%');       

          LcdWriteCom(0x89);
                LcdWriteData('0'+max/1000);                       
                LcdWriteData('0'+max%1000/100);
                LcdWriteData('.');       
                LcdWriteData('0'+max%100/10);               
                LcdWriteData('0'+max%10);
       
        LcdWriteCom(0x80+0x49);
                LcdWriteData('0'+min/1000);                       
                LcdWriteData('0'+min%1000/100);
                LcdWriteData('.');       
                LcdWriteData('0'+min%100/10);               
                LcdWriteData('0'+min%10);
                delay(3000);
                break;
         }  

   }

}
void delay(uint x)
{
uint y,z;
for(y=x;y>0;y--)
   {
   for(z=199;z>0;z--);
   }
}


回复

使用道具 举报

ID:1 发表于 2018-3-20 15:51 | 显示全部楼层
楼主能传个压缩包吗 缺少头文件
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表