找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2764|回复: 8
收起左侧

DS18B20的搜索rom序列号程序问题

[复制链接]
ID:837423 发表于 2020-12-6 00:09 | 显示全部楼层 |阅读模式
本帖最后由 LLQ2723 于 2020-12-6 11:06 编辑

屏幕截图 2020-12-06 11111.png 屏幕截图2222.png
看的懂得伙伴,看一下红线是怎么理解得
原码和反码是指啥,
为啥用uchar了k,用k=00,01,02,03来判断是怎么个原理


回复

使用道具 举报

ID:417092 发表于 2021-8-20 19:40 | 显示全部楼层
111.JPG
如果对照流程图看懂就可以了

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

ID:417092 发表于 2021-8-20 19:45 | 显示全部楼层
我也在学习,搜索ROM。
能不能把源代码文件分享一下呀!!!

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

回复

使用道具 举报

ID:584195 发表于 2021-8-21 07:44 | 显示全部楼层
我以前弄了N遍,也没弄出个结果!
回复

使用道具 举报

ID:748788 发表于 2021-8-21 08:38 | 显示全部楼层
ZMRGHY 发表于 2021-8-20 19:45
我也在学习,搜索ROM。
能不能把源代码文件分享一下呀!!!

你搜25例,其中“应用实例10  多点温度采集系统”有仿真有源码
回复

使用道具 举报

ID:417092 发表于 2021-9-6 01:21 | 显示全部楼层
  1. bit search_rom(uchar (*prom)[8])
  2. {
  3.         bit ask=0, end=0;
  4.         uchar i=0,j=0, k=0, buff[8]={0};
  5.         uchar _ROM_x=0, _00bit=0, high=0xff, low=0xff;

  6.         ask=init_18b20();
  7.         while(ask)
  8.         {
  9.                 ask=init_18b20();
  10.         }
  11.         write_18b20_byte(0xf0);
  12.         for(i=0; i<8; i++)
  13.         {
  14.                 for(j=0; j<8; j++)
  15.                 {
  16.                         loop:
  17.                         k=0;
  18.                   k|=read_bit();
  19.                         k<<=1;
  20.                         k|=read_bit();
  21.                   switch(k)
  22.                   {
  23.                                 case 0: if(8*i+j<low) low=8*i+j; _00bit=8*i+j; buff[i]>>=1; write_bit(0); break;
  24.                                 case 1:        buff[i]>>=1; write_bit(0); break;
  25.                                 case 2: buff[i]>>=1; buff[i]|=0x80; write_bit(1); break;
  26.                                 case 3: return 0;
  27.                   }
  28.                 }
  29.         }
  30.         for(i=0; i<8; i++)
  31.                 prom[_ROM_x][i]=buff[i];
  32.         _ROM_x++;
  33.         if(end && high==low)
  34.                 return 1;
  35.         if(high==0)
  36.                 end = 1;
  37.         high = _00bit;
  38.         //以下为修改后,添加部分
  39.         ask=init_18b20();
  40.         while(ask)
  41.         {
  42.                 ask=init_18b20();
  43.         }
  44.         write_18b20_byte(0xf0);
  45.         _00bit = 0;
  46.         for(i=0; i<8; i++)
  47.         {
  48.                 buff[i] = 0;
  49.                 for(j=0; j<8; j++)
  50.                 {
  51.                         if(8*i+j == high)  //抄写上一个ROM到最高00位。。。
  52.                         {
  53.                                 k=0;
  54.                                 k|=read_bit();
  55.                                 k<<=1;
  56.                                 k|=read_bit();
  57.                                 high = _00bit;
  58.                                 buff[i]>>=1;
  59.                                 buff[i]|=0x80;
  60.                                 if(j<7)
  61.                                         j++;
  62.                                 else
  63.                                 {
  64.                                         j=0;
  65.                                         i++;
  66.                                 }
  67.                                 write_bit(1);
  68.                                 goto loop;                //抄写完成返回读2写1循环中。。。。。。
  69.                         }
  70.                         k=0;
  71.                   k|=read_bit();
  72.                         k<<=1;
  73.                         k|=read_bit();
  74.                         if(k==0)
  75.                                 _00bit = 8*i+j;
  76.                         buff[i]>>=1;
  77.                         if((prom[_ROM_x-1][i])>>j&0x01)
  78.                         {
  79.                                 buff[i]|=0x80;
  80.                                 write_bit(1);
  81.                         }
  82.                         else
  83.                                 write_bit(0);
  84.                 }
  85.         }
  86.         return 0;
  87. }
复制代码


自己刚写成的。。。太长了。。。
你的程序不完整。。。。
网上找到一个。。。需要使用外部存储器。。。。
这个不用外部存储器。。。就是太长了。。。。
看一下,能不能精简。。。。。。。。
回复

使用道具 举报

ID:417092 发表于 2021-9-6 01:27 | 显示全部楼层
zyluglugl 发表于 2021-8-21 07:44
我以前弄了N遍,也没弄出个结果!

看5楼,刚写成的。功能实现了。。。就是太长了。。。
一起学习一下。。。
看能不能帮我精简一下。。。
回复

使用道具 举报

ID:417092 发表于 2021-9-6 23:52 | 显示全部楼层
  1. bit search_rom(uchar (*prom)[8])
  2. {
  3.         bit ask=0, end=0;
  4.         uchar i=0,j=0, k=0, buff[8]={0};
  5.         uchar _ROM_x=0, _00bit=0, high=0xff, low=0xff;
  6.         loop:
  7.         ask=init_18b20();
  8.         while(ask)
  9.         {
  10.                 ask=init_18b20();
  11.         }
  12.         write_18b20_byte(0xf0);
  13.         for(i=0; i<8; i++)
  14.         {
  15.                 for(j=0; j<8; j++)
  16.                 {
  17.                         k=0;
  18.                   k|=read_bit();
  19.                         k<<=1;
  20.                         k|=read_bit();
  21.                         if(k==0 && high!=8*i+j)
  22.                                 _00bit = 8*i+j;
  23.                         buff[i]>>=1;
  24.                         if(8*i+j>high || _ROM_x==0)
  25.                         {
  26.                                 switch(k)
  27.                                 {
  28.                                         case 0: if(8*i+j<low) low=8*i+j;  write_bit(0); break;
  29.                                         case 1:        write_bit(0); break;
  30.                                         case 2: buff[i]|=0x80; write_bit(1); break;
  31.                                         case 3: return 0;
  32.                                 }
  33.                         }
  34.                         else if(8*i+j == high)
  35.                         {
  36.                                 buff[i]|=0x80; write_bit(1);
  37.                                 high=_00bit;
  38.                         }
  39.                         else
  40.                         {
  41.                                         if((prom[_ROM_x-1][i])>>j&0x01)
  42.                                         {
  43.                                                 buff[i]|=0x80;
  44.                                                 write_bit(1);
  45.                                         }
  46.                                         else
  47.                                                 write_bit(0);
  48.                         }
  49.                 }
  50.         }
  51.         for(i=0; i<8; i++)
  52.                 prom[_ROM_x][i]=buff[i];
  53.         _ROM_x++;
  54.         if(end && high==low)
  55.                 return 1;
  56.         if(high==0)
  57.                 end = 1;
  58.         high = _00bit;
  59.         goto loop;
  60. }
复制代码


苦逼的自学过程,第一次精简从88行变成60行。。。。
回复

使用道具 举报

ID:71233 发表于 2022-1-24 13:27 | 显示全部楼层
ZMRGHY 发表于 2021-9-6 23:52
苦逼的自学过程,第一次精简从88行变成60行。。。。

我用了,总线只有两个18b20,却搜索出6个多一点,第三个开始都是与第二个相同的ROM。
ROM.png
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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