久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3112|回復: 8
打印 上一主題 下一主題
收起左側

關于DS18B20仿真問題求助。

[復制鏈接]
跳轉到指定樓層
樓主
本帖最后由 素還真 于 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);   //讀出的數據最低位在最前面,這樣剛好一個字節在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;            //這里是為了顯示正負,目前沒有實現。
        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);
}
這個程序仿真結果是這樣的:

求大神指點一下是哪里出錯了。

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

一段時間后結果

一段時間后結果

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

開始仿真

開始仿真

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

電路圖

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

使用道具 舉報

沙發
ID:82765 發表于 2017-9-11 14:17 | 只看該作者
提示: 作者被禁止或刪除 內容自動屏蔽
回復

使用道具 舉報

板凳
ID:89515 發表于 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);   //讀出的數據最低位在最前面,這樣剛好一個字節在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;            //這里是為了顯示正負,目前沒有實現。
        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());
   }            
}

評分

參與人數 1黑幣 +10 收起 理由
素還真 + 10 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

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

使用道具 舉報

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

P0=table[A1];
         P2=0x01;
         delayms(1);
         
         P0=table[A2];
         P2=0x02;
         delayms(1);
這個數碼管顯示程序中P2口位選使能寫錯了,因為不熟練犯得低級錯誤。
回復

使用道具 舉報

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

使用道具 舉報

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

給你介紹一個18b20的案例,自己對照查錯吧!
Proteus仿真一下,確認有效。
實例97 DS18B20測溫.rar (51.78 KB, 下載次數: 8)

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

使用道具 舉報

8#
ID:232612 發表于 2017-9-12 12:34 | 只看該作者
你好,這個應該是程序出了問題,看數碼管的代碼有沒問題
回復

使用道具 舉報

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

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 福利网址 | 伊人免费观看视频 | 国产成人自拍一区 | 精品亚洲一区二区三区四区五区 | 欧美日韩综合一区 | 亚洲国产中文字幕 | 久久精品一 | 色综久久| 国产麻豆一区二区三区 | 免费黄网站在线观看 | 成人在线免费电影 | 中文字幕av在线播放 | 久久精品91久久久久久再现 | 91黄色片免费看 | 欧美一区二区三区视频在线观看 | 国产高清在线 | 免费黄色av| 亚洲一区二区三区在线播放 | 日韩欧美在线观看一区 | 精品国产乱码久久久久久88av | 欧美日韩亚洲国产综合 | 中文久久 | 精品网站999| 亚洲在线一区二区三区 | 日本免费一区二区三区视频 | 一区日韩 | 久久久久久久av | 欧美爱爱视频 | 中文在线一区二区 | 可以免费观看的av | 性精品 | 中文字幕一区二区三区精彩视频 | 91九色婷婷 | 亚洲精品综合 | 国产片侵犯亲女视频播放 | 午夜影院在线观看 | 新疆少妇videos高潮 | 国产91久久精品一区二区 | 国产乱码精品一区二区三区忘忧草 | 国产精品一区二区不卡 | 日日骚网 |