找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机负载平衡监控系统程序+Proteus仿真

[复制链接]
ID:517871 发表于 2019-5-9 17:10 | 显示全部楼层 |阅读模式
基于51单片机的负载平衡监控系统仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
负载平衡.png

负载平衡监控系统单片机源程序如下:
#include <AT89X52.h>

unsigned char code SEGtable[]=
{
        0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x00
};

sbit sw7 = P0 ^ 7;
sbit sw6 = P0 ^ 6;
sbit sw5 = P0 ^ 5;
sbit sw4 = P0 ^ 4;
sbit sw3 = P0 ^ 3;
sbit sw2 = P0 ^ 2;
sbit sw1 = P0 ^ 1;
sbit sw0 = P0 ^ 0;

sbit FMQ = P1 ^ 7;
bit alarmflg = 0;
unsigned RxByte = 0x00;
unsigned char counter = 0;
unsigned char Scounter,Lcounter;  //分别存放自己的水位状态和远方的水位状态
unsigned char FMcounter = 0x02;   //报警状态参数

void DelayFM(unsigned int x)  
{
         unsigned char t;
        while(x--)
        {
                 for(t=0;t<120;t++);
        }
}
//蜂鸣器驱动函数,参数为发声声调
void FM(unsigned char x)
{
         unsigned char i;
        for(i=0;i<100;i++)
        {
                 FMQ = ~FMQ;
                DelayFM(x);
        }
        FMQ = 0;
}

void Delayms(unsigned int MS)                     //延时ms函数            
{
        unsigned int i,j;
        for( i=0;i<MS;i++)
                for(j=0;j<1141;j++);                                
}
void InitUART(void)
{
    TMOD = 0x20;     //9600bps
    SCON = 0x50;
    TH1 = 0xFD;
    TL1 = TH1;
    PCON = 0x00;
    EA = 1;
    ES = 1;
    TR1 = 1;
}
void Send(unsigned char x)
{
  SBUF = x;
  while(TI == 0);
  TI = 0;
}
void Serial(void) interrupt 4 using 1
{
        unsigned char RxByte;
        if(RI == 1)
        {
                RxByte = SBUF;
                RI = 0;
    P2 = RxByte;
    switch(RxByte)
    {
      case 0x00: Lcounter = 0;break;
      case 0xf9: Lcounter = 1;break;
      case 0xa4: Lcounter = 2;break;
      case 0xb0: Lcounter = 3;break;
      case 0x99: Lcounter = 4;break;
      case 0x92: Lcounter = 5;break;
      case 0x82: Lcounter = 6;break;
      case 0xF8: Lcounter = 7;break;
      case 0x80: Lcounter = 8;break;
      default:{};
    }
    if(Scounter > Lcounter)
    {
      if((Scounter - Lcounter) > 2)       //如果超过2%
      {
        FMcounter = Scounter - Lcounter;
        alarmflg = 1;              //报警标志位
      }
      else
      {
        alarmflg = 0;
      }
    }
    else
    {
      alarmflg = 0;     //清除
    }
        }        
}
main(void)
{
   InitUART();
   while(1)
   {
     Delayms(100);  
     P0 = 0xFF;
     counter = 0;
     counter = counter + (unsigned char)sw7;
     counter = counter + (unsigned char)sw6;
     counter = counter + (unsigned char)sw5;
     counter = counter + (unsigned char)sw4;
     counter = counter + (unsigned char)sw3;
     counter = counter + (unsigned char)sw2;
     counter = counter + (unsigned char)sw1;
     counter = counter + (unsigned char)sw0;  //计算当前的负载
     Scounter = counter;
     Send(SEGtable[counter]);
     if(alarmflg == 1)
     {
      FM(FMcounter);
     }
   }
}

0.png

全部资料51hei下载地址:
基于51单片机和Proteus仿真的负载平衡监控系统.zip (66.79 KB, 下载次数: 9)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:704825 发表于 2020-3-10 17:47 | 显示全部楼层
老哥还在不
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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