We decided to design a greenhouse as subject for our electronic project. The goal was to regulate the temperature inside the greenhouse thanks a lamp, a servomotor to open a window and a PC fan. We wanted to maintain a quite constant level of soil moisture with a pump and to receive temperature, soil moisture and luminosity measurements. Finally, we designed a website to be able to control it remotely.
This project was made for our electronic course and we wanted to use a raspberry pi and an arduino board. We know that it can be improved in so many ways but we want to give you ideas to redo it and improve it.
Step 1: Presentation
This greenhouse has different sensors to measure the ambient temperature, the external temperature, the soil moisture and the luminosity.
The ambient temperature sensor allows us to start the fan and to drive a servomotor to open the window when the internal temperature is above the temperature setpoint. Conversely, if the temperature descends under the temperature setpoint, the fan is stopped and the window is closed. Furthermore, a lamp is switched on to warm the plant. The soil moisture sensor allows to drive a pump and an electrovalve for the watering system when the earth is too dry.
Thanks to a USB cable, the Arduino uno board is connected to the raspberry 3 board. This connection allows us to recover the measures and the states of actuators. These data are stored in a mysql database. A script in python allows us to communicate with arduino uno (master/slave communication) and save the data in the database or read the database and send new values in the arduino.
Next, an apache server is installed on the raspberry in order to host a website. With the help of php, we can make the bridge between the mysql database and the website.
On the website, we can define the temperature and moisture setpoints. It is also possible to control each actuator manually and to look their states.
Step 2: List of Components
We wanted to use as much as possible components stemming from the recycling
Step 3: Coding
For this part, we give you the different programs and code that we made for this project:
The new version is now available. The issue with the window is now fix and some little bugs.
We installed the MySQL server and the Python bindings for MySQL. For the web server we installed the Apache2 package
The CSS files are now available in the .rar folder.
For this script, we used the MySQLdb library. You need to use python 2.7 to be able to run the script.
The script is the bridge between the arduino and the raspberry pi. It allows us to save the data from the arduino bord into the database and send the new setpoint values defined by the user into the arduino program.
Step 4: Mounting
Step 5: Wiring
Step 6: The Website and Database
EDIT: The new version of the website is now available.
The website that we disgned is composed of three pages.
The first one is the main page. With this page, the user can see the states of the devices and the different measures.
The second page, Commands and parameters, the user can easily change the device’s mode and switch them on or off. The setpoint values and the parameters can be changed on this page too. For the parameters, we validate the new entered value to be sure that it is correct.
The last page is just about us.
Our database is made of three tables. The “mesures” table is dedicated to the collected data storage.
The “types” table contains the parameters of each measurement and the “commandes” table allows us to control the devices and to know their state.
Step 7: Time to Save Your Time and Your Plants
This is it! You have all the tools to make your own automated greenhouse !
You can take a look to the video to see the automated greenhouse in action.
Feel free to contact us if you have any questions !
Guillaume, Mathieu, Vincent and Kevin.
Engineers from Isicht Mons
Others cool projects ? Visit : https://electroniquehelha.wordpress.com/
Source: Automated Greenhouse
This Post / Project can also be found using search terms:
- https://duino4projects com/automated-greenhouse/