Kunal Mehta
Published © GPL3+

Temperature Monitoring System with Alerts and Prediction

Dispatch SMS alerts for temperature anomalies or if readings fall below the threshold, additionally forecasting future temperature values.

IntermediateFull instructions provided736
Temperature Monitoring System with Alerts and Prediction

Things used in this project

Hardware components

RCA Female to Female Coupler, 3 Way
RCA Female to Female Coupler, 3 Way
×1
Temperature Sensor
Temperature Sensor
×1
Bolt WiFi Module
Bolt IoT Bolt WiFi Module
×1

Software apps and online services

Bolt IoT Android App
Bolt IoT Android App
Snappy Ubuntu Core
Snappy Ubuntu Core
SMS Messaging API
Twilio SMS Messaging API

Story

Read more

Schematics

Circuit diagram

Connecting LM35 to bolt

Step 1: Hold the sensor in a manner such that you can read LM35 written on it.

Step 2: In this position, identify the pins of the sensor as VCC, Output and Gnd from your left to right.

VCC is connected to the red wire, Output is connected to the orange wire and Gnd is connected to the brown wire.

Step 3: Using male to female wire connect the 3 pins of the LM35 to the Bolt Wifi Module as follows:

VCC pin of the LM35 connects to 5v of the Bolt Wifi module.
Output pin of the LM35 connects to A0 (Analog input pin) of the Bolt Wifi module.
Gnd pin of the LM35 connects to the Gnd.

output

This is the screenshot of the console where the output of the code is shown.
Here we can see that as the frame value is 10 the console will show "Not enough data to compute Z-score. Need 10 more data points."
Now as soon as I switched on the AC and turned I-cool mode on, the temperature dropped from 352 to 344 cause of which an SMS was sent to my number informing "Someone switched on the I-cool mode in AC".
Now the minimum limit was set to 341, so, as soon as the temperature dropped beyond 341 an SMS was sent to my number informing "The current temperature sensor value is 340 and celcius33.203125"

Code

Complete code

Python
I have provided main file code which can compute and alert you if any anomaly detected and also alert you if temperature goes down beyond certain minimum limit
import json, time, math, statistics  
from boltiot import Sms, Bolt
#importing configuration file which holds the confidential data 
import conf   

#function to compute bounds or Z Score Analysis

def compute_bounds(history_data,frame_size,factor):
    if len(history_data)<frame_size :
        return None

    if len(history_data)>frame_size :
        del history_data[0:len(history_data)-frame_size]
    Mn=statistics.mean(history_data)
    Variance=0
    for data in history_data :
        Variance += math.pow((data-Mn),2)
    Zn = factor * math.sqrt(Variance / frame_size)
    High_bound = history_data[frame_size-1]+Zn
    Low_bound = history_data[frame_size-1]-Zn
    return [High_bound,Low_bound] 

mybolt = Bolt(conf.API_KEY, conf.DEVICE_ID)  #returns object of Bolt to mybolt and connects with the bolt device 
sms = Sms(conf.SSID, conf.AUTH_TOKEN, conf.TO_NUMBER, conf.FROM_NUMBER) #create a platform for the mobile networks and server to connect with each other
history_data=[] #list of the sensor values to be stored in

while True:
    response = mybolt.analogRead('A0') #reads the data from A0 pin
    data = json.loads(response) #converts the data in the python dictionary type
    if data['success'] != 1:
        print("There was an error while retriving the data.")
        print("This is the error:"+data['value'])
        time.sleep(10)
        continue

    print ("This is the value "+data['value'])
    sensor_value=0
    try:
        sensor_value = int(data['value'])
    except e:
        print("There was an error while parsing the response: ",e)
        continue

    try: 
        sensor_value = int(data['value'])
        minimum_limit = 341
        
        #alerts when the temperature goes below minimum limit-
        
        if sensor_value < minimum_limit: 
            print("Making request to Twilio to send a SMS")
            Temperature=(100*sensor_value)/1024 
            response = sms.send_sms("The Current temperature sensor value is " +str(sensor_value)+"and in celcius" +str(Temperature))
            print("Response received from Twilio is: " + str(response))
            print("Status of SMS at Twilio is :" + str(response.status))
    except Exception as e: 
        print ("Error occured: Below are the details")
        print (e)

    bound = compute_bounds(history_data,conf.FRAME_SIZE,conf.MUL_FACTOR) #calls the function and as a result it returns low and high bound 
    if not bound: #if the function returns none 
        required_data_count=conf.FRAME_SIZE-len(history_data) 
        print("Not enough data to compute Z-score. Need ",required_data_count," more data points")
        history_data.append(int(data['value']))
        time.sleep(10)
        continue
    
        #alerts when there is a sudden raise or drop in temperature-
    
    try:
        if sensor_value > bound[0] : #if value greater than high bound
            print ("The Temperature level increased suddenly. Sending an SMS.")
            response = sms.send_sms("Someone switched on the I-heat mode in Heater")
            print("This is the response ",response)
        elif sensor_value < bound[1]: #if value lower than low bound
            print ("The Temperature level decreased suddenly. Sending an SMS.")
            response = sms.send_sms("Someone switched on the I-cool mode in AC")
            print("This is the response ",response)
        history_data.append(sensor_value);
    except Exception as e:
        print ("Error",e)

    
    
    time.sleep(10)

Credits

Kunal Mehta
1 project • 1 follower

Comments