Introduction: IOT BASED SMART WEATHER STATION

Picture of IOT BASED SMART WEATHER STATION

1.About the problem:
Before I get into the specifics, let’s take a moment to consider the key questions and caveats involved in a project like this:

● How can I create a weather station that it is neither valuable nor attractive to a thief?

● How can I keep hardware costs and development time to the minimum?

● How can I measure and access weather data in real time and display it in a useful way?

○ Required measurements: wind and wind gusts, wind direction, rain, atmospheric pressure, temperature, humidity ○ Connect station to Internet

○ Store and retrieve local weather data

○ Communicate between weather station and server

● How can I reduce maintenance to (almost) zero?

○ Manage hanging of software

○ Manage loss of connectivity

○ Manage loss of energy supply

  • 2 .Objective/Aim : The goal of this project is to make a temperature/humidity monitor that wirelessly logs the temperature and humidity to a remote server. We will use an Arduino Uno (or clone), a DHT11, an ESP8266, and ThingSpeak.com for this project. This is a great project to start using the ESP8266 for some basic data logging so let's get started! The ESP8266 based wifi breakout boards are becoming more popular with Makers due to a low cost and a powerful, programmable microcontroller on-board. The cost is a magnitude lower than solutions including Arduino+Wifi Shield or an Arduino UNO To quote Make publisher Brian Jepson : “This is inexpensive enough to be very much in the territory of ‘thousands of sensors-launched-out-of-a-cannon’-cheap.” Couple the ESP8266 with one of the inexpensive DHT series digital temperature and humidity sensors and we have a project that may literally be deployed anywhere to broadcast sensor data. The broadcasting used in this tutorial is using the ESP8266 webserver code and respond to web requests (like in a browser or a web client) to return temperature and humidity data (in a REST type format). This project demonstrates the programming of the ESP8266 ESP-01 module with the Arduino IDE and interfacing with a DHT temperature/humidity sensor. Using other sensors and their corresponding libraries, other electronics may be interfaced with the ESP8266 and monitored via wifi.

Step 1: Hardware Required:

Picture of Hardware Required:

This project is presented on a breadboard as it best demonstrates the connections and how the digital pins might connect to other types of sensors. A final project may only have power, a regulator, the ESP-01, and a sensor, which could fit in a very small container. For this project I used an Arduino Uno clone but any Arduino board or clone will work.

● Arduino Uno

● USB A to B cable and 5V USB power supply

● ESP8266 wireless transceiver . I used the Esp-01 but any version should work, just make sure you know the pins. ● DHT11 temperature/humidity sensor , I used a DHT11 but a DHT22 would also work

● Breadboard

● Jumper wires

● Resistors 4

Step 2: Create a ThingSpeak Channel

Picture of Create a ThingSpeak Channel

In order to log your temperature and humidity measurements online you need to have a website or webservice that can accept GET http commands. In this Instructable I am using ThingSpeak but there are other, similar services out there so feel free to use something else to log your data. If you use ThingSpeak you will need to make a channel with two fields, one for temperature and one for humidity. They have a number of options for displaying data in graphs so I encourage you to explore these options and see what you like best. I settled on two simple line graphs with a 10 point average to smooth out occasional blips in the data. ThingSpeak will give you a Key for your channel that you will need to put into the code so that your channel will accept your data.

Step 3: Wiring

Picture of Wiring

First we should cover some basics of the ESP8266 and the DHT11. Then we will move on to wiring them to the Uno. The image above shows the front of the ESP8266 with the 8 broken out pins labeled. The ESP8266 runs at 3.3 V so make sure you connect the Vcc pin to the 3.3 V pin on the Uno. This also means that you will need to use a logic level shifter or make a voltage divider for the serial connection from the arduino board to the ESP8266 or you risk ruining it. If you don't want to buy a logic level shifter then you will need to make a voltage divider which you can do using two resistors. Sparkfun has a great tutorial on this so you can see how they build theirs and calculate which value resistors you will need to use. I used a 220 Ohm resistor and a 470 Ohm resistor for mine which got me close enough to 3.3 V. Since the ESP8266 outputs 3.3 V and the Arduino boards can take that voltage there is no need to do anything to the serial line from the ESP8266 to the Arduino. The DHT11 spec is only +/- 5% humidity and 2 degrees Celsius so it is not a super accurate sensor. It's also only good for temperatures above freezing. The DHT22 is a bit 6 more accurate so if that's important to you opt for it instead. Both sensors work with voltages between 3.3 - 5 V. The signal pin will need to be connected to a pull-up resistor , which I used a 4.7 kohm resistor for. The Fritzing diagram above shows the wiring. For ease of use all connections to 5 V or 3.3 V are red and all connections to ground are blue.

The wiring connections are as follows:

● Uno | ESP8266

● RXD | TXD

● TXD | RXD (through voltage divider)

● 3.3 V | Vcc, CH_PD, Reset

● GND | GND

● Uno | DHT11

● 5 V | Vcc

● GND | GND

● D7 | Signal (connect to Vcc via pull-up resistor)

Step 4: Code

Step 5: Final Testing

Picture of Final Testing

With terminal app check output from ESP and you will see your IP address after reset
and then value of temperature every upload period... You can see your data in thingspeak like mine: https://thingspeak.com/channels/98397

Step 6: INNOVATIVENESS AND USEFULLNESS:

1.The ESP8266 module is an extremely cost effective board with a huge, and ever
growing, community.

2.Highly economical (costs around only Rs. 500 to build)

3.Easy to operate and maintain

4.The ESP8266 module has a powerful enough on-board processing and storage capability that allows it to be integrated with the sensors and other application specific devices through its GPIOs with minimal development up-front and minimal loading during runtime.

5.Real-time data collection and storage

6. MATLAB analytics and visualizations

7.Alerts

8.Scheduling

9.Device communication

10.Open API

11.Geolocation data

12.Available on GitHub

Step 7: References:


Reference ESP8266 Arduino IDE https://github.com/esp8266/Arduino ESP8266 Lua http://benlo.com/esp8266/ LUA based https://www.instructables.com/id/Low-cost-WIFI-tem... NodeMCU http://nodemcu.com/index_en.html NodeMCU v1.0 pin mapping https://github.com/esp8266/Arduino/blob/esp8266/h... NodeMCU v1.0 pin mapping https://github.com/esp8266/Arduino/issues/584 NodeMCU https://vegardpaulsen.wordpress.com/2015/07/18/so... http://shin-ajaran.blogspot.sg/2015/02/setting-up-... http://shin-ajaran.blogspot.sg/2015/01/iot-streami... http://shin-ajaran.blogspot.sg/2015/01/internet-co... http://shin-ajaran.blogspot.sg/2014/12/noobs-guide... https://www.instructables.com/id/noobs-guide-to-ESP... https://www.instructables.com/id/Use-ESP8266-to-Int... source code https://gist.github.com/teos0009/acad7d1e54b97f4b2...

Comments

Michal Choma (author)2017-09-14

what is current consumption?

Check group

https://www.facebook.com/groups/1829154687394948/

AsfiaE (author)2017-06-27

sir i am gettingg problem in uploading the program. please help me out. 'it is showing " avrdude: stk500_getsync() attempt 9 of 10: not in sync: resp=0x0a"

TomV85 (author)2016-11-23

Nice project ,

But i have one tip .. Keep you code clean and don't put any ' IF ' routines in it ..

nikil14 (author)TomV852017-03-06

Thank you Tomv85 for liking my project and also for your suggestion I'll try to keep my code neat from next time

About This Instructable

5,655views

22favorites

License:

More by nikil14:IOT BASED SMART WEATHER STATION
Add instructable to: