2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/DS18B20_INT/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-10-17 10:28:36 +02:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/DS18B20_INT/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/DS18B20_INT/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/DS18B20_INT/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/DS18B20_INT/actions/workflows/jsoncheck.yml)
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/DS18B20_INT/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/DS18B20_INT.svg?maxAge=3600)](https://github.com/RobTillaart/DS18B20_INT/releases)
|
|
|
|
|
2021-06-16 10:41:09 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
# DS18B20_INT
|
|
|
|
|
2021-06-16 10:41:09 +02:00
|
|
|
Minimalistic library for the DS18B20 temperature sensor - restricted to one sensor per pin.
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-06-16 10:41:09 +02:00
|
|
|
## Arduino Temperature Control Library (ATCL)
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
This DS18B20 library is a minimalistic library for a DS18B20 sensor.
|
|
|
|
It will give only temperatures in whole degrees C.
|
|
|
|
Goal is to minimize footprint.
|
|
|
|
|
|
|
|
If you need more functions or control over the DS18B20 family I refer to the library
|
|
|
|
of Miles Burton - https://github.com/milesburton/Arduino-Temperature-Control-Library
|
2021-06-16 10:41:09 +02:00
|
|
|
|
|
|
|
I'm a great fan of the above library however some time ago I needed to strip it down
|
|
|
|
to save a few dozen bytes. I reworked that minimalistic version into a library and I
|
|
|
|
added a number of Arduino examples to help you get started.
|
|
|
|
|
2022-06-24 17:29:55 +02:00
|
|
|
This library is also related to - https://github.com/RobTillaart/DS18B20_RT
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
|
|
|
This DS18B20_INT library supports only the DS18B20, only one sensor per pin, no parasite
|
|
|
|
mode, no Fahrenheit and no alarm functions. The only feature the class supports is
|
|
|
|
the asynchronous reading of the temperature by means of three core functions:
|
|
|
|
|
2021-12-17 11:26:25 +01:00
|
|
|
- **DS18B20_INT(OneWire *)** constructor needs a reference to OneWire object.
|
2021-06-16 10:41:09 +02:00
|
|
|
- **bool begin(uint8_t retries = 3)** resets oneWire and set resolution to 9 bit.
|
|
|
|
returns true if all is OK. there will be a number of retries to connect, default 3.
|
2021-12-17 11:26:25 +01:00
|
|
|
- **void requestTemperatures()** trigger temperature conversion.
|
|
|
|
- **bool isConversionComplete()** check if conversion is complete.
|
2021-06-16 10:41:09 +02:00
|
|
|
- **int16_t getTempC()** returns temperature in whole degrees only. -55..125
|
2022-06-24 17:29:55 +02:00
|
|
|
or -127 = DEVICE_DISCONNECTED
|
2021-12-17 11:26:25 +01:00
|
|
|
- **bool getAddress()** returns true if the sensor is configured (available).
|
2021-06-16 10:41:09 +02:00
|
|
|
|
|
|
|
|
2022-06-24 17:29:55 +02:00
|
|
|
### CentiC part
|
|
|
|
|
|
|
|
The following functions are experimental since 0.2.0
|
|
|
|
They allow to use a higher resolution while not using floats.
|
|
|
|
This keeps the library small.
|
|
|
|
|
|
|
|
- **void setResolution(uint8_t bits = 9)** sets the internal resolution to 9, 10, 11 or 12 bits.
|
|
|
|
Other numbers will be mapped on 9.
|
|
|
|
This will affect the conversion time for a measurement.
|
|
|
|
Internally it will call **begin()** to set the new resolution if needed.
|
|
|
|
- **void getResolution()** returns the bits set, default 9.
|
|
|
|
Convenience function.
|
|
|
|
- **getTempCentiC(void)** returns the measured temperature times 100. -5500..12500
|
|
|
|
So 10.62°C will be returned as 1062.
|
|
|
|
|
|
|
|
**Warning** The DEVICE_DISCONNECTED is not tested for, but is commented in the code.
|
|
|
|
Use at own risk.
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Operation
|
|
|
|
|
|
|
|
This library supports only one DS18B20 per Arduino/ MCU pin.
|
2021-06-16 10:41:09 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
```
|
|
|
|
// BOTTOM VIEW
|
|
|
|
//
|
|
|
|
// PIN MEANING
|
|
|
|
// /---+
|
|
|
|
// / o | 1 GND
|
|
|
|
// | o | 2 DATA
|
|
|
|
// \ o | 3 VCC
|
|
|
|
// \---+
|
2021-06-16 10:41:09 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Connect a pull-up resistor 4.7 KOhm between pin3 and pin2.
|
|
|
|
When the wires are longer this resistor needs to be smaller.
|
|
|
|
|
2021-06-16 10:41:09 +02:00
|
|
|
|
|
|
|
### Pull up resistor
|
|
|
|
|
|
|
|
An **indicative** table for pull up resistors, (E12 series), to get started.
|
|
|
|
|
|
|
|
Note: thicker wires require smaller resistors (typically 1 step in E12 series)
|
|
|
|
|
|
|
|
|
|
|
|
| Length | - 5.0 Volt | - 3.3 Volt |
|
2021-12-17 11:26:25 +01:00
|
|
|
|--------------:|------------:|-----------:|
|
|
|
|
| 10cm (4") | 10K0 | 6K8 |
|
|
|
|
| 20cm (8") | 8K2 | 4K7 |
|
|
|
|
| 50cm (20") | 4K7 | 3K3 |
|
|
|
|
| 100cm (3'4") | 3K3 | 2K2 |
|
|
|
|
| 200cm (6'8") | 2K2 | 1K0 |
|
|
|
|
| 500cm (16'8") | 1K0 | \* |
|
2022-06-24 17:29:55 +02:00
|
|
|
| longer | \* | \* |
|
2021-06-16 10:41:09 +02:00
|
|
|
|
|
|
|
\* = no info, smaller
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Credits
|
|
|
|
|
|
|
|
Miles Burton who originally developed the Arduino Temperature Control Library.
|
|
|
|
and all people who contributed to that lib.
|
|
|
|
|
2021-12-17 11:26:25 +01:00
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
- add examples
|
|
|
|
- a multi sensor == multiple pins, no bus
|
2022-06-24 17:29:55 +02:00
|
|
|
- add rounding for **getTempC()**.
|
|
|
|
- now it truncates, so it can be 0.5°C off.
|
|
|
|
- add "0.5" to raw and truncate
|
2021-12-17 11:26:25 +01:00
|
|
|
|