为什么要将原始数据除以 16



http://datasheets.maximintegrated.com/en/ds/DS18B20.pdf

阅读第 3 页,操作 – 测量温度。 以下代码用于获取温度。 我都明白,除了为什么他们把数字除以 16。

local raw = (data[1] << 8) | data[0];
    local SignBit = raw & 0x8000;  // test most significant bit
    if (SignBit) {raw = (raw ^ 0xffff) + 1;} // negative, 2's compliment
    local celsius = raw / 16.0;
    if (SignBit) {celsius *= -1;}

我有另一种情况 http://dlnmh9ip6v2uc.cloudfront.net/datasheets/Sensors/Pressure/MPL3115A2.pdf 第 23 页,第 7.1.3 节,温度数据。 它只有 12 位,所以上面的代码也适用于它(只需将左移更改为 4 而不是 8),但同样,最终结果需要/16。 我不明白这是从哪里来的。

原始温度数据以十六分之一度为单位,因此必须将该值除以 16 才能将其转换为度数。

相关内容

  • 没有找到相关文章

最新更新