Skip to content

Latest commit

 

History

History
99 lines (61 loc) · 6.53 KB

File metadata and controls

99 lines (61 loc) · 6.53 KB

Thermometer

Turn a BLE capable microprocessor into a wireless HomeKit thermometer. Temperature reading can be displayed in the Home app on your Apple device.

This example uses Arduino 101 or Bluefruit Micro LE and Raspberry Pi 3. Generally, any programmable BLE peripheral and a box capable of running Node.js with Noble will work.

BLE Peripheral (Arduino 101, Bluefruit Micro LE or Other BLE Board)

Download and install the latest version of the Arduino IDE. If you're totally new to microcontrollers take some time to go through an introductory tutorial and learn how to make a LED blink. This will help you to understand how to use the IDE, how to upload a sketch and what is the code actually doing.

Wiring

No wiring is needed, since we use the internal thermometer attached to the IMU or a thermometer inside of the nRF51 chip die in case of the Bluefruit Micro LE.

Note Alternatively, you can use any of the many BLE boards available on the market (BlueBean, RedBearLabs BLE Nano, ...) as long as you keep UUIDs of the services and characteristics in sync with your config.json file, everything will work just fine.

Running the Sketch

Compile, run and upload the arduino101.ino or bluefruit.ino sketch using the Arduino IDE. The sketch creates a BLE service with a readable and notifiable characteristic for the current temperature float value.

BLEService thermometerService("1D8A68E0-E68E-4FED-943E-369099F5B499");
BLEFloatCharacteristic temperatureCharacteristic("1D8A68E1-E68E-4FED-943E-369099F5B499", BLERead | BLENotify);

Take a look into this file to see the full definition of the CurrentTemperature characteristic used in the TemperatureSensor service. Once the BLE central device is setup, it connects to this characteristic and exposes it via Homebridge as a HomeKit accessory of type TemperatureSensor.

The code also calculates (pseudo-moving) average to prevent noise in the temperature measurement to trigger frequent mew value notifications. Duration of the averaging window is about 30 s. Once the moving average accumulates change above a certain threshold a new value of the characteristic is set which triggers the notify mechanism and propagates the measurement to HomeKit. The threshold is approximately half of the thermometer accuracy (±1°C).

The built-ine sensor in fact measures is the temperature if the silicon die, which might be different from the room temperature (usually higher). The die temperature also depends on the load of the processor and might change even when the outside room temperature is stable.

Leave the device powered on and the sketch running while you setup the Homebridge server. The sketch has some built-in logging, so keeping the Serial monitor open may be helpful for debugging.

BLE Central & Homebridge Server (Raspberry Pi 3 or Other Compatible Box)

For help installing an operating system on your new Pi, the official documentation contains a couple of nice videos.

Wiring

No wiring except for the micro-USB cable providing power is needed. The Pi needs to be connected to the same router (subnet) as the Apple device you plan to use. It doesn't matter whether via Wifi or Ethernet. Otherwise, you won't be able discover and connect to the Homebridge server running on the Pi.

Note Alternatively, you can use a Raspberry Pi 2 with a supported USB BLE dongle instead of the Pi 3.

Running Homebridge

Running Homebridge on a Raspberry Pi is straightforward. Follow this guide to install Homebridge server and then run the following command to install the homebridge-bluetooth plugin:

[sudo] npm install -g homebridge-bluetooth

Edit the ~/.homebridge/config.json, name your Homebridge server and add a new accessory to allow the plugin to connect to the BLE service running on the Arduino:

"name": "Arduino",
"address": "01:23:45:67:89:AB",
"services": [
    "name": "Thermometer",
    "type": "TemperatureSensor",
    "UUID": "1D8A68E0-E68E-4FED-943E-369099F5B499",
    "characteristics": [ {
        "type": "CurrentTemperature",
        "UUID": "1D8A68E1-E68E-4FED-943E-369099F5B499"
      } ]
} ]

Finally, start the Homebridge server. If you use Linux you may need to run with higher privileges in order to have access to the BLE hardware layer. See this link for more details about running without sudo.

[sudo] homebridge -D

Note Running with -D turns on additional debugging output that is very helpful for getting addresses and UUIDs of your BLE devices that needs to match with the config.json file.

Note Homebridge server doesn't run only on Linux. MacOS and Windows machines are also supported given they have a built-in BLE adapter or an USB dongle. For more details see supported platforms of Homebridge and Noble.

Apple Device (iOS 10 or newer)

Pairing

Open Home app and tap the '+' button to add new accessory. When you attempt to add the 'Raspberry Pi 3' bridge, it will ask for a "PIN" from the config.json file. Once you are paired with your new Rapsberry, Homebridge server all the connected BLE accesories can be added the same way as the bridge.

Interacting

Once your BLE accessory has been added to HomeKit database, besides using the Home app or Control Center at the bottom of the screen, you should be able to tell Siri to get the reading from any HomeKit accessory. Try "Hey Siri, what's the temperature of the Arduino?". However, Siri is a cloud service and iOS may need some time to synchronize your HomeKit database to iCloud.