51单片机DS1302可调电子时钟proteus仿真一直显示85.85.85.

程序如下:

#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define unit unsigned int
#define anod_combit P2
#define seg7 P1
sbit DS1302_CLK = P3^2;
sbit DS1302_IO = P3^3;
sbit DS1302_RST = P3^4;
sbit ACC0 = ACC^0;
sbit ACC7 = ACC^7;
sbit Tiaoshi=P3^7;
sbit Inck=P3^6;
unit count;
uchar temp,readdata;
bit Inck_flag=0x20;


typedef struct
{
    uchar Second;
    uchar Minute;
    uchar Hour;
    uchar TimeStr[6];
}SYSTEMTIME;
SYSTEMTIME CurrentTime;
#define DS1302_SECOND 0x80
#define DS1302_MINUTE 0x82
#define DS1302_HOUR 0x84

void mdelay(unit count)
{
     uchar i,j;
     for(i=0;i<count;i++)
     {   
         for(j=0;j<106;j++);
     }

}

void DS1302InputByte(uchar d)
{
      uchar i;
      ACC = d;
      for(i=8;i>0;i--)
        {   DS1302_IO = ACC0;
          DS1302_CLK = 1;
          DS1302_CLK = 0;
          ACC = ACC >>1;
          }

}

uchar DS1302OutputByte(void)
{
       uchar i;
       ACC=0;
       for(i=8;i>0;i--)
       {  ACC = ACC >>1;
          ACC7 = DS1302_IO;
          DS1302_CLK = 1;
          DS1302_CLK = 0;
       }
       return(ACC);
}

void Write1302(uchar ucAddr,uchar ucDa)
{      DS1302_RST = 0;
       DS1302_CLK = 0;
       DS1302_RST = 1;
       DS1302InputByte(ucAddr);
       DS1302InputByte(ucDa);
       DS1302_CLK = 1;
       DS1302_RST = 0;
}

uchar Read1302(uchar ucAddr)
{      uchar ucData;
       DS1302_RST = 0;
       DS1302_CLK = 0;
       DS1302_RST = 1;
       DS1302InputByte(ucAddr|0x01);
       ucData = DS1302OutputByte();
       DS1302_CLK = 1;
       DS1302_RST = 0;
       return(ucData);
}

void DS1302_GetTime(SYSTEMTIME *Time)
{      uchar ReadValue;
       ReadValue = Read1302(DS1302_SECOND);
       Time->Second = ((ReadValue&0x70)>>4)*10 + (ReadValue&0x0F);
       ReadValue = Read1302(DS1302_MINUTE);
       Time->Minute = ((ReadValue&0x70)>>4)*10 + (ReadValue&0x0F);
       ReadValue = Read1302(DS1302_HOUR);
       Time->Hour = ((ReadValue&0x70)>>4)*10 + (ReadValue&0x0F);
}

void TimeToStr(SYSTEMTIME *Time)
{     
       Time->TimeStr[0] = Time->Hour/10;
       Time->TimeStr[1] = Time->Hour%10;
       
       Time->TimeStr[2] = Time->Minute/10;
       Time->TimeStr[3] = Time->Minute%10;
       
       Time->TimeStr[4] = Time->Second/10;
       Time->TimeStr[5] = Time->Second%10;
}

void Dis( SYSTEMTIME *Time )
{      uchar disbit,shitfb;
       DS1302_GetTime(Time);
       TimeToStr(Time);
       disbit=1;
switch(count)
{      case 0:
       for(shitfb=0;shitfb<6;shitfb++)
       {     _nop_(); _nop_();
             seg7=Time->TimeStr[shitfb];
             anod_combit=_crol_(disbit,shitfb);
             mdelay(6);
             anod_combit =0;
       }
             break;
        case 1:
        for(shitfb=0;shitfb<2;shitfb++)
        {     _nop_(); _nop_();
             seg7=Time->TimeStr[shitfb];
             anod_combit=_crol_(disbit,shitfb);
             mdelay(6);
             anod_combit =0;
       }break;
       case 2:
        for(shitfb=2;shitfb<4;shitfb++)
        {     _nop_(); _nop_();
             seg7=Time->TimeStr[shitfb];
             anod_combit=_crol_(disbit,shitfb);
             mdelay(6);
             anod_combit =0;
       }break;
        case 3:
        for(shitfb=4;shitfb<6;shitfb++)
        {     _nop_(); _nop_();
             seg7=Time->TimeStr[shitfb];
             anod_combit=_crol_(disbit,shitfb);
             mdelay(6);
             anod_combit =0;
       }break;
    default:break;   
   }
}

void Setkey()
{       if(Tiaoshi==0)
           {  mdelay(8);
               if(Tiaoshi==0)
               {  count=count+1;
                  if (count==4)
                  {   count=0;
                      readdata=(Read1302(0x80))&0X7F;
                      Write1302(0x80,readdata);
                      Write1302(0x8e,0x80);
                  }
                  while(Tiaoshi==0);
                }
           }
}

void Inckey()
{  if(Inck==0)
   { mdelay(8);
      switch(count)
      { case 1:
           temp=Read1302(DS1302_HOUR);
           temp=((temp&0x70)>>4)*10+(temp&0x0f);
           temp=temp+1;
           if(temp>=24)
               temp=0;
           Inck_flag=1;
           break;
        case 2:
           temp=Read1302(DS1302_MINUTE);
           temp=((temp&0x70)>>4)*10+(temp&0x0f);
           temp=temp+1;
           Inck_flag=1;
           if(temp>=60)
               temp=0;
           break;
        case 3:
           temp=Read1302(DS1302_SECOND);
           temp=((temp&0x70)>>4)*10+(temp&0x0f);
           temp=temp+1;
           Inck_flag=1;
           if(temp>=60)
               temp=0;  
           break;
        default:       Inck_flag=0; break;
}
     while(Inck==0);
}
}

void Keydone()
{    Write1302(0x8e,0x00);
     readdata=Read1302(0x80);
     Write1302(0x80,readdata|0x80);
switch(count)
     {case 1:do
         {   Inckey();
             if(Inck_flag==1)
             {   temp=(temp/10)<<4|temp%10;
                 Write1302(0x84,temp);
                 Inck_flag=0;
             }    
          Dis(&CurrentTime);             
     }while(count==2);break;
     case 2:do
         {   Inckey();
             if(Inck_flag==1)
             {   temp=(temp/10)<<4|temp%10;
                 Write1302(0x82,temp);
                 Inck_flag=0;
             }    
            Dis(&CurrentTime);
     }while(count==3);break;
     case 3:do
         {   Inckey();
             if(Inck_flag==1)
             {   temp=(temp/10)<<4|temp%10;
                 Write1302(0x80,temp|0x80);
                 Inck_flag=0;
             }    
            Dis(&CurrentTime);
     }while(count==4);break;
  default:break;
  }
}
main()
{    Inck_flag=0;
     mdelay(100);
     readdata=Read1302(0x80);
     Write1302(0x80,readdata&0x7f);
     while(1)
     {   DS1302_GetTime(&CurrentTime);
              TimeToStr(&CurrentTime);
         Dis(&CurrentTime);
         Setkey();
         if(count!=0)
         Keydone();
     }
     
}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 基于51单片机的数控可调稳压电源是一种能够根据负载的电压需求调整输出电压的电源系统。Proteus是一种电子电路仿真软件,可以帮助我们进行电路的设计和仿真。 在Proteus中,我们可以使用51单片机的模型来设计数控可调稳压电源的电路。首先,我们需要绘制一个适合的电路图,包括51单片机、电源电路和稳压电路。 在电源电路中,我们可以选择使用变压器、整流电路和滤波电路来将交流电转换为直流电。然后,将直流电输入稳压电路中,稳压电路可以采用反馈控制的方式来控制输出电压的稳定性。在稳压电路中,我们可以使用稳压芯片或者自己设计的反馈电路。 51单片机作为主控制器,可以通过检测输出电压和负载电流来动态地调整稳压电源的输出电压。通过编程,我们可以实现根据负载的电压需求进行动态调整。例如,当负载电压下降时,51单片机可以检测到并通过反馈信号调整稳压电流的输出,使其恢复到设定的目标电压。 除了电路设计,Proteus还可以进行电路的仿真,我们可以通过添加合适的信号源、示波器等元件来模拟电路的输入和输出情况。通过仿真,我们可以验证电路的性能和稳定性,优化电路设计。 总之,基于51单片机的数控可调稳压电源可以通过Proteus进行电路设计和仿真。通过设计合适的电路图和使用51单片机进行动态控制,我们可以实现电源输出电压的稳定调节,并通过Proteus进行仿真验证电路的性能。 ### 回答2: 基于51单片机的数控可调稳压电源proteus仿真,主要是通过使用Proteus软件来模拟51单片机及其外围电路,实现数控可调稳压电源的功能。 首先,在Proteus中创建一个新的项目,选择适合的51单片机型号并添加到项目中。然后,通过连线连接所需的电路元件,包括电源输入、电路滤波、稳压电路、AD转换器和显示装置等。 其次,根据设计要求,编写51单片机的程序代码,其中包含了控制稳压电源输出电压的关键算法。代码中通过AD转换获取输入电压,并通过调节PWM信号来控制稳压电路的输出电压,从而实现可调稳压的功能。 接着,在Proteus中进行仿真。利用Proteus仿真功能,可以模拟稳压电源输出电压的变化、数码显示装置的显示效果等。可以设置输入电压的变化曲线,观察稳压电源在不同输入情况下的输出电压是否符合要求。 最后,分析仿真结果。根据仿真结果评估电路设计的稳定性和可靠性。如果稳压电源输出电压在设定范围内,且能够随输入变化而调整,则说明设计成功;反之则需要进行修改和优化。 总结来说,通过Proteus仿真,可以帮助我们验证基于51单片机的数控可调稳压电源的设计方案,减少不必要的实验和调试,节约时间和成本。同时,也能够提供电路稳定性和可靠性方面的信息,为后续的实际制作和使用提供参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值