找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 3120|回復(fù): 8
打印 上一主題 下一主題
收起左側(cè)

關(guān)于DS18B20仿真問題求助。

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
本帖最后由 素還真 于 2017-9-11 12:06 編輯

#include<reg51.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
sbit DS=P1^6;
uint temp;

unsigned char code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf};
unsigned char code table1[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};

void delay(uint count)     
{
  uint i;
  while(count)
  {
    i=200;
    while(i>0)
            i--;
    count--;
  }
}

void delayms(uchar x)
{
        uint i,j;
        for(i=x;i>0;i--)
                for(j=120;j>0;j--);
}

void delay10us(uchar t)
{
        do
        {
                _nop_();_nop_();_nop_();_nop_();
                _nop_();_nop_();_nop_();_nop_();
        }
        while(--t);
}

void Init_Com(void)
{
     TMOD = 0x20;
     PCON = 0x00;
     SCON = 0x50;
     TH1 = 0xFd;
     TL1 = 0xFd;
     TR1 = 1;
}

bit drst(void)
{
        bit ask;
        EA=0;
        DS=0;
        delay10us(65);
        DS=1;
        delay10us(6);
        ask=DS;
        while(!DS);
        return ask;
        EA=1;
}

bit readbit(void)
{
        bit dat;
        EA=0;
        DS=0;_nop_();        
        DS=1;_nop_();_nop_();
        dat=DS;
        delay10us(6);
        return (dat);
        EA=1;
}
uchar read(void)
{
        uchar i,j,dat;
        dat=0;
        EA=0;
        for(i=1;i<=8;i++)
        {
                j=readbit();
                dat=(j<<7)|(dat>>1);   //讀出的數(shù)據(jù)最低位在最前面,這樣剛好一個(gè)字節(jié)在DAT里
        }
        return(dat);
        EA=1;
}

void write(uchar dat)
{  
  uchar j;
  bit testb;
  EA=0;
  for(j=1;j<=8;j++)
  {
        testb=dat&0x01;
        dat=dat>>1;
        if(testb)   
        {
                DS=0;
                _nop_();_nop_();
                DS=1;
                delay10us(6);
        }
        else
        {
                DS=0;       //write 0
                delay10us(6);
                DS=1;
                _nop_();_nop_();
        }

  }EA=1;
}

void DSrun(void)
{
        bit ask;
        EA=0;
        drst();
        delay(1);
        if(ask==0)
        {
                write(0xcc);
                write(0x44);
        }
        EA=1;
}

uint tmp()
{
        float tt;
        uchar a,b;
        EA=0;
        DSrun();
        a=read();
        b=read();
        temp=b;
        temp<<=8;
        temp=temp|a;
        tt=temp*0.0625;
        temp=tt*10+0.5;
        return temp;
        EA=1;
}

void display(uint temp)
{
        uchar A1,A2,A3,A4,A2s,A3s,ser;
        ser=temp/10;
        ser=SBUF;
        A1=temp/1000;            //這里是為了顯示正負(fù),目前沒有實(shí)現(xiàn)。
        A2s=temp%1000;
        A2=A2s/100;
        A3s=A2s%100;
        A3=A3s/10;
        A4=A3s%10;
       
        P0=table[A1];
        P2=0x01;
        delayms(1);
       
        P0=table[A2];
        P2=0x02;
        delayms(1);
       
        P0=table1[A3];
        P2=0x04;
        delayms(1);
       
        P0=table[A4];
        P2=0x08;
        delayms(1);
       
}

void main()
{
uchar a;
  do
  {
    DSrun();
    //delay(200);

for(a=100;a>0;a--)
  {   display(tmp());
  }
  }                while(1);
}
這個(gè)程序仿真結(jié)果是這樣的:

求大神指點(diǎn)一下是哪里出錯(cuò)了。

QQ圖片2.png (21.05 KB, 下載次數(shù): 69)

一段時(shí)間后結(jié)果

一段時(shí)間后結(jié)果

QQ圖片1.png (28.61 KB, 下載次數(shù): 89)

開始仿真

開始仿真

xxx.png (209.57 KB, 下載次數(shù): 71)

電路圖

電路圖
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:82765 發(fā)表于 2017-9-11 14:17 | 只看該作者
提示: 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽
回復(fù)

使用道具 舉報(bào)

板凳
ID:89515 發(fā)表于 2017-9-11 15:02 | 只看該作者
#include<reg51.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
sbit DS=P1^6;
uint temp;

unsigned char code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf};
unsigned char code table1[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};

void delay(uint count)     
{
   uint i;
   while(count)
   {
     i=200;
     while(i>0)
             i--;
     count--;
   }
}

void delayms(uchar x)
{
         uint i,j;
         for(i=x;i>0;i--)
                 for(j=120;j>0;j--);
}

void delay10us(uchar t)
{
         do
         {
                 _nop_();_nop_();_nop_();_nop_();
                 _nop_();_nop_();_nop_();_nop_();
         }
         while(--t);
}

void Init_Com(void)
{
      TMOD = 0x20;
      PCON = 0x00;
      SCON = 0x50;
      TH1 = 0xFd;
      TL1 = 0xFd;
      TR1 = 1;
}

bit drst(void)
{
         bit ask;
         EA=0;
         DS=0;
         delay10us(65);
         DS=1;
         delay10us(6);
         ask=DS;
         while(!DS);
         return ask;
         EA=1;
}

bit readbit(void)
{
         bit dat;
         EA=0;
         DS=0;_nop_();        
         DS=1;_nop_();_nop_();
         dat=DS;
         delay10us(6);
         return (dat);
         EA=1;
}
uchar read(void)
{
         uchar i,j,dat;
         dat=0;
         EA=0;
         for(i=1;i<=8;i++)
         {
                 j=readbit();
                 dat=(j<<7)|(dat>>1);   //讀出的數(shù)據(jù)最低位在最前面,這樣剛好一個(gè)字節(jié)在DAT里
        }
         return(dat);
         EA=1;
}

void write(uchar dat)
{  
   uchar j;
   bit testb;
   EA=0;
   for(j=1;j<=8;j++)
   {
         testb=dat&0x01;
         dat=dat>>1;
         if(testb)   
         {
                 DS=0;
                 _nop_();_nop_();
                 DS=1;
                 delay10us(6);
         }
         else
         {
                 DS=0;       //write 0
                 delay10us(6);
                 DS=1;
                 _nop_();_nop_();
         }

   }EA=1;
}

void DSrun(void)
{
         bit ask;
         EA=0;
         drst();
         delay(1);
         if(ask==0)
         {
                 write(0xcc);
                 write(0x44);
         }
         EA=1;
}

uint tmp()
{
         float tt;
         uchar a,b;
         EA=0;
         DSrun();
         a=read();
         b=read();
         temp=b;
         temp<<=8;
         temp=temp|a;
         tt=temp*0.0625;
         temp=tt*10+0.5;
         return temp;
        EA=1;
}

void display(uint temp)
{
         uchar A1,A2,A3,A4,A2s,A3s,ser;
         ser=temp/10;
         ser=SBUF;
         A1=temp/1000;            //這里是為了顯示正負(fù),目前沒有實(shí)現(xiàn)。
        A2s=temp%1000;
         A2=A2s/100;
         A3s=A2s%100;
         A3=A3s/10;
         A4=A3s%10;
         
         P0=table[A1];
         P2=0x01;
         delayms(1);
         
         P0=table[A2];
         P2=0x02;
         delayms(1);
         
         P0=table1[A3];
         P2=0x04;
         delayms(1);
         
         P0=table[A4];
         P2=0x08;
         delayms(1);
         
}

void main()
{
          Init_Com();
   while(1)
   {   
                   display(tmp());
   }            
}

評(píng)分

參與人數(shù) 1黑幣 +10 收起 理由
素還真 + 10 回帖助人的獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

地板
ID:89515 發(fā)表于 2017-9-11 15:06 | 只看該作者
如果還是不行,你可以先把數(shù)碼管程序搞定,再調(diào)試18b20.仿真和硬件在時(shí)間上還是有很大差別的
回復(fù)

使用道具 舉報(bào)

5#
ID:209584 發(fā)表于 2017-9-11 19:27 | 只看該作者
        我下午仔細(xì)研究了一下,主要是兩個(gè)問題。
void DSrun(void)
{
        bit ask;
        EA=0;
        drst();
        delay(1);
        if(ask==0)
        {
                write(0xcc);
                write(0x44);
        }
        EA=1;
}
進(jìn)行溫度轉(zhuǎn)換之后還要讀取RAM中存儲(chǔ)的數(shù)據(jù)。就是在write(0x04)后再進(jìn)行一次初始化,然后用0xbe指令讀取數(shù)據(jù)。

P0=table[A1];
         P2=0x01;
         delayms(1);
         
         P0=table[A2];
         P2=0x02;
         delayms(1);
這個(gè)數(shù)碼管顯示程序中P2口位選使能寫錯(cuò)了,因?yàn)椴皇炀毞傅玫图?jí)錯(cuò)誤。
回復(fù)

使用道具 舉報(bào)

6#
ID:209584 發(fā)表于 2017-9-11 19:29 | 只看該作者
另外代碼要寫在return前,不過這個(gè)仿真其實(shí)沒有用到中斷,所以沒什么影響。謝謝大家的幫助。
回復(fù)

使用道具 舉報(bào)

7#
ID:111634 發(fā)表于 2017-9-11 21:32 | 只看該作者
本帖最后由 zl2168 于 2017-9-11 21:33 編輯

給你介紹一個(gè)18b20的案例,自己對(duì)照查錯(cuò)吧!
Proteus仿真一下,確認(rèn)有效。
實(shí)例97 DS18B20測(cè)溫.rar (51.78 KB, 下載次數(shù): 8)

以上摘自張志良編著《80C51單片機(jī)仿真設(shè)計(jì)實(shí)例教程——基于Keil CProteus》清華大學(xué)出版社ISBN 978-7-302-41682-1內(nèi)有常用的單片機(jī)應(yīng)用100案例,用于仿真實(shí)驗(yàn)操作,電路與程序真實(shí)可靠可信可行。仿真電路和Hex文件能在清華出版社網(wǎng)站免費(fèi)下載,程序源代碼只能到書上看了。到圖書館借,或到新華書店翻閱,或到網(wǎng)上書店打折購(gòu)買。
回復(fù)

使用道具 舉報(bào)

8#
ID:232612 發(fā)表于 2017-9-12 12:34 | 只看該作者
你好,這個(gè)應(yīng)該是程序出了問題,看數(shù)碼管的代碼有沒問題
回復(fù)

使用道具 舉報(bào)

9#
ID:194451 發(fā)表于 2017-9-12 16:42 | 只看該作者
DS18B20采集溫度的時(shí)候不能有中斷程序
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表