Go outdoors. Equipped with random homemade IoT gizmos. 'Cause we wanna.
The official repository for Taking a Peak: Xtreme² Edition
Here are the major components of the project:
Trackers are ESP32 development boards running MicroPython that are attached to:
- U-blox Neo-6 GPS receiver (UART interface)
- Semtech SX127X LoRa transceiver (SPI)
- Nordic Semiconductor nRF24L01+ transceiver (SPI)
In short, trackers periodically take GPS readings and broadcast these out via LoRa (LoRaWAN) and 2.4 GHz radio (nRF). For the remainder of the time, they will remain in deep sleep.
Trackers need to be small, lightweight and last over a day (ideally multiple) on a single battery charge. They also need to have zero dependencies on the remainder of the project.
Multiple trackers will send their GPS data to a single brick. The brick will also take its own GPS readings, but also have other sensors attached as well.
The brick also runs a sqlite3 database to buffer payloads (both for itself and the trackers) and uploads them to AWS IOT via REST API when internet connetion is detected.
A nRF receiver application runs on the brick to receive payloads from the trackers using a nRF24L01+ receiver.
Brick is a Raspberry Pi Zero running Raspbian OS. It has been tested to run 48+ hours with a beefy 20,000mAh 2A battery pack.
A single application is configured in The Things Network, with our trackers registered. Any data received by an open, public LoRaWAN gateway for our application is dispatched to our AWS IoT Core instance using the TTN->AWS IoT integration.
The tracker devices are only expected to perform an unconfirmed data upload operation.
AWS services - specifically AWS IoT - are being used to provide the following functionalities:
- AWS IoT Core is used to ingest data from the trackers. Data is stored locally in a sqlite3 database, and further forwarded onto AWS IoT Events and AWS Elasticsearch Service. For more information, see post Gold Filling.
- AWS Elasticsearch Service is used to store all data being received from the field. Kibana provides the data visualisation. For more information, see post Hard Grapht.
- AWS IoT Events operates a detector model that monitors for non-responsive trackers. AWS Simple Email Service is used to dispatch notification emails relating to tracker state changes. For more information, see post Pear Force One.
There are AWS Lambda functions deployed to perform integration between the services, such as for:
- Making shadow document updates for a device in AWS IoT Core.
- Sending notification emails to recipients using AWS Simple Email Service.
- AWS DynamoDB is used to store meta-data, for example interesting locations. For more information, see post Castle Track-a-lot.
A static website is built using AWS S3 (for web site static file storage) and AWS Cognito (user authentication and authorisation). Unreal TV.
There is a number of directories storing files required by different aspects of the project. These are described below:
- /tracker - Contains MicroPython code that runs on the ESP32-based GPS tracker devices.
- /ttn - Contains code specific to The Things Network, such as the payload format decoder.
- /aws-lambda - Contains AWS Lambda functions in Python 3.X.
- /brick - Contains Python code running on the Raspberry Pi.
- /docs - Random glossy literature that would make a salesperson proud.
- /web - HTML, JavaScript and other static files for the web site. Currently empty.
The Semtech SX1276 LoRA transceiver datasheet can be found here:
The LoRaWAN specification can be found here: