找回密码
 立即注册

QQ登录

只需一步,快速开始

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

proteus SMT32 DS18B20仿真,检测不到DS18B20,引脚貌似没有波形

[复制链接]
ID:1113739 发表于 2025-5-9 09:17 | 显示全部楼层 |阅读模式
50黑币
1.png

这个是protues仿真的电路,单片机为STM32F103C8;


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


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


//复位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的回应
//返回1:未检测到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读取一个位
//返回值: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读取一个字节
//返回值:读到的数据
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;
}
//写一个字节到DS18B20
//dat:要写入的字节
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);                          
        }
    }
}
//开始温度转换
void DS18B20_Start(void)
{                                                                  
    DS18B20_Rst();           
        DS18B20_Check();         
    DS18B20_Write_Byte(0xcc);        // skip rom
    DS18B20_Write_Byte(0x44);        // convert
}

//初始化DS18B20的IO口 DQ 同时检测DS的存在
//返回1:不存在
//返回0:存在            
u8 DS18B20_Init(void)
{
         GPIO_InitTypeDef  GPIO_InitStructure;         
         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);         //使能PORTG口时钟         
         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;                                        //温度为负  
    }else temp=1;                                //温度为正                    
    tem=TH;                                         //获得高八位
    tem<<=8;   
    tem+=TL;                                        //获得底八位
    tem=(float)tem*0.625;                //转换     
        if(temp)return tem;                 //返回温度值
        else return -tem;   
}

回复

使用道具 举报

ID:1113739 发表于 2025-5-9 09:21 | 显示全部楼层
这个是仿真的
51hei图片_20250509092115.png

仿真

仿真
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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