datasqrl.examples.sensors
source

0.5.5.beta·default·Published 9/30/2024

Sensors Package

This example demonstrates DataSQRL?s capabilities by building a sensor metrics data pipeline. It serves as an ideal use case for real-time data aggregation, showcasing how sensor readings can be processed to monitor environmental changes such as temperature and humidity. In this example, we will compute the maximum temperature from sensors in just a few SQL queries. All of this is achieved in less than 15 lines of code, including imports!

How to run this example

We are going to build a data pipeline that aggregates sensor metrics using DataSQRL. With DataSQRL, you can implement the entire data pipeline in a single SQL script.

  1. Create a new folder for the data pipeline:
mkdir metrics; cd metrics
  1. Create a new file called metrics.sqrl and copy-paste the following SQL code:
IMPORT datasqrl.examples.sensors.SensorReading; -- Import sensor readings
IMPORT time.endOfSecond;  -- Import time function

/* Aggregate sensor readings per second */
SecReading := SELECT sensorid, endOfSecond(time) as timeSec,
                     avg(temperature) as temp
              FROM SensorReading
              GROUP BY sensorid, timeSec;

/* Get max temperature in the last minute for each sensor */
SensorMaxTemp := SELECT sensorid, max(temp) as maxTemp
                 FROM SecReading
                 WHERE timeSec >= now() - INTERVAL 1 MINUTE
                 GROUP BY sensorid;
  1. Compile the SQL script to an integrated data pipeline:
docker run -it --rm -v $PWD:/build datasqrl/cmd:v0.5.5 compile metrics.sqrl
  1. By default, DataSQRL uses Docker to run data pipelines locally. Start the pipeline with Docker Compose:
(cd build/deploy; docker compose up --build)
  1. Once you are done, hit CTRL-C and take down the pipeline containers with:
docker compose down -v 

Exploring the Pipeline

Once the pipeline is up and running, you can explore it by querying the data through a GraphQL API.

How to check the maximum temperature for a sensor?

Navigate to http://localhost:8888/graphiql/ and execute GraphQL queries to interact with the pipeline.

Query Example: Maximum Temperature for a Sensor

The following GraphQL query retrieves the maximum temperature recorded in the last minute for sensor id: 1:

{
  SensorMaxTemp(sensorid: 1) {
    maxTemp
  }
}
Expected Response
{
  "data": {
    "SensorMaxTemp": [
      {
        "maxTemp": 28.17
      }
    ]
  }
}
Query Example: Sensor Readings Aggregated by Time

To fetch the average temperature for sensor readings aggregated by second:

{
  SecReading(limit: 5) {
    sensorid,
    timeSec,
    temp
  }
}
Expected Response

The response will provide a list of sensor readings aggregated by time:

{
    "data": {
        "SecReading": [
            {
                "sensorid": 1,
                "timeSec": "2024-04-04T00:00:00Z",
                "temp": 28.1723170944317
            },
            {
                "sensorid": 2,
                "timeSec": "2024-04-04T00:00:00Z",
                "temp": 7.9208043131776975
            }
        ]
    }
}

Understanding the Input Data

The data used in this example represents sensor readings and is provided in CSV format. Each record contains a sensorid, a timestamp (time), and corresponding temperature and humidity readings. Here is a sample of the input data:

sensoridtimetemperaturehumidity
02024-04-04 00:00:00.000Z21.79201224672860393.0
12024-04-04 00:00:00.000Z28.172317094431742.0
22024-04-04 00:00:00.000Z7.920804313177697532.0
32024-04-04 00:00:00.000Z20.977746508799990.0
42024-04-04 00:00:00.000Z10.53127757904529871.0

Additional Resources

For further details on how DataSQRL works and additional tutorials, check out the official Sensor Data Tutorial.

Install

Add the following to the dependencies of your package.json:

License

ASFv2

Description

This example demonstrates DataSQRL?s capabilities by building a sensor metrics data pipeline. It serves as an ideal use case for real-time data aggregation, showcasing how sensor readings can be processed to monitor environmental changes such as temperature and humidity. In this example, we will compute the maximum temperature from sensors in just a few SQL queries. All of this is achieved in less than 15 lines of code, including imports!