標(biāo)題: proteus SMT32 DS18B20仿真,檢測(cè)不到DS18B20,引腳貌似沒(méi)有波形 [打印本頁(yè)]

作者: 你好-----    時(shí)間: 2025-5-9 09:17
標(biāo)題: proteus SMT32 DS18B20仿真,檢測(cè)不到DS18B20,引腳貌似沒(méi)有波形


這個(gè)是protues仿真的電路,單片機(jī)為STM32F103C8;


#include "ds18b20.h"
#include "delay.h"        


void Delay_DS18B20_1us(int num)
{
        num=num*10;
        while(num--) ;
}


//復(fù)位DS18B20
void DS18B20_Rst(void)           
{                 
        DS18B20_IO_OUT();         //SET PG11 OUTPUT
    DS18B20_DQ_OUT=0;         //拉低DQ
  Delay_DS18B20_1us(900);            //拉低750us
    DS18B20_DQ_OUT=1;         //DQ=1
Delay_DS18B20_1us(20);            //15US
}
//等待DS18B20的回應(yīng)
//返回1:未檢測(cè)到DS18B20的存在
//返回0:存在
u8 DS18B20_Check(void)            
{   
        u8 retry=0;
        DS18B20_IO_IN();        //SET PG11 INPUT         
    while (DS18B20_DQ_IN&&retry<200)
        {
                retry++;
                Delay_DS18B20_1us(1);
        };         
        if(retry>=200)return 1;
        else retry=0;
    while (!DS18B20_DQ_IN&&retry<240)
        {
                retry++;
                Delay_DS18B20_1us(1);
        };
        if(retry>=240)return 1;            
        return 0;
}


//從DS18B20讀取一個(gè)位
//返回值:1/0
u8 DS18B20_Read_Bit(void)         
{
    u8 data;
        DS18B20_IO_OUT();        //SET PG11 OUTPUT
    DS18B20_DQ_OUT=0;
        Delay_DS18B20_1us(8);
    DS18B20_DQ_OUT=1;
        DS18B20_IO_IN();        //SET PG11 INPUT
        Delay_DS18B20_1us(20);
        if(DS18B20_DQ_IN)data=1;
    else data=0;         
    Delay_DS18B20_1us(70);           
    return data;
}
//從DS18B20讀取一個(gè)字節(jié)
//返回值:讀到的數(shù)據(jù)
u8 DS18B20_Read_Byte(void)     
{        
    u8 i,j,dat;
    dat=0;
        for (i=1;i<=8;i++)
        {
        j=DS18B20_Read_Bit();
        dat=(j<<7)|(dat>>1);
    }                                                   
    return dat;
}
//寫(xiě)一個(gè)字節(jié)到DS18B20
//dat:要寫(xiě)入的字節(jié)
void DS18B20_Write_Byte(u8 dat)     
{            
    u8 j;
    u8 testb;
        DS18B20_IO_OUT();        //SET PG11 OUTPUT;
    for (j=1;j<=8;j++)
        {
        testb=dat&0x01;
        dat=dat>>1;
        if (testb)
        {
            DS18B20_DQ_OUT=0;        // Write 1
            Delay_DS18B20_1us(8);                           
            DS18B20_DQ_OUT=1;
            Delay_DS18B20_1us(80);            
        }
        else
        {
            DS18B20_DQ_OUT=0;        // Write 0
            Delay_DS18B20_1us(80);            
            DS18B20_DQ_OUT=1;
            Delay_DS18B20_1us(8);                          
        }
    }
}
//開(kāi)始溫度轉(zhuǎn)換
void DS18B20_Start(void)
{                                                                  
    DS18B20_Rst();           
        DS18B20_Check();         
    DS18B20_Write_Byte(0xcc);        // skip rom
    DS18B20_Write_Byte(0x44);        // convert
}

//初始化DS18B20的IO口 DQ 同時(shí)檢測(cè)DS的存在
//返回1:不存在
//返回0:存在            
u8 DS18B20_Init(void)
{
         GPIO_InitTypeDef  GPIO_InitStructure;         
         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);         //使能PORTG口時(shí)鐘         
         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;                                //PORTG.11 推挽輸出
         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  
         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
         GPIO_Init(GPIOB, &GPIO_InitStructure);
         GPIO_SetBits(GPIOB,GPIO_Pin_8);    //輸出1
        DS18B20_Rst();

        return DS18B20_Check();
}  
//從ds18b20得到溫度值
//精度:0.1C
//返回值:溫度值 (-550~1250)
short DS18B20_Get_Temp(void)
{
    u8 temp;
    u8 TL,TH;
        short tem;
    DS18B20_Start ();                          // ds1820 start convert
    DS18B20_Rst();
    DS18B20_Check();         
    DS18B20_Write_Byte(0xcc);        // skip rom
    DS18B20_Write_Byte(0xbe);        // convert            
    TL=DS18B20_Read_Byte();         // LSB   
    TH=DS18B20_Read_Byte();         // MSB  
                     
    if(TH>7)
    {
        TH=~TH;
        TL=~TL;
        temp=0;                                        //溫度為負(fù)  
    }else temp=1;                                //溫度為正                    
    tem=TH;                                         //獲得高八位
    tem<<=8;   
    tem+=TL;                                        //獲得底八位
    tem=(float)tem*0.625;                //轉(zhuǎn)換     
        if(temp)return tem;                 //返回溫度值
        else return -tem;   
}

作者: 你好-----    時(shí)間: 2025-5-9 09:21
這個(gè)是仿真的

51hei圖片_20250509092115.png (25.21 KB, 下載次數(shù): 0)

51hei圖片_20250509092115.png

51hei圖片_20250509092115.png (25.21 KB, 下載次數(shù): 0)

仿真

仿真





歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1