Difference between revisions of "Soil Solutions"

From ESE205 Wiki
Jump to navigation Jump to search
Line 56: Line 56:
  
 
==Design and Solutions==
 
==Design and Solutions==
We started this project by looking at different sensors we could use for the system. We ended up ordering a moisture sensor, water level sensor, 12V relay, and a peristaltic pump. All of our purchases for the project can be found on the budget page. For the website part of this project we used Amazon Web Services to host our website. The first thing to do is make an AWS account. Once that has been done you should navigate to the services tab in the top right of the menu and find Elastic Beanstalk under the tab Compute. Click create environment and make sure you select web server environment. You can name your environment whatever you like. Under Platform, choose preconfigured platform and select Python as the platform you wish to use; also select sample application as the application code (this can be changed from the console menu). Once you environment is created and you are the console menu, you now need to upload and deploy a zip file for your website to be run on. This zip file will contain your python code, html code, css code, and anything else you need to make your website. The code i used is on GitHub ([https://github.com/mattgwilson/soilsolutions Soilsolutions Repository]) The codes that were zipped together were application.py, requirements.txt, soilsolutions205.db, splash.html, dataview.html, and soilsolutions.css. Once you zip those files together, you can upload and deploy that zip file to the AWS server and once it has finished upload, you can click on the URL at the top of the console and access your website. If you would like to make the homepage of the website look different, you can edit our splash.html code and upload a new zipfile with a new splash.html. At this point nothing is being updated, but you can check that the table is there by entering your URL with the following "/get?id=test" this will show the data points in a table with all there values as test. This is because of the application.py code that defines test and what the values will be when id = test. Because the pi has not been involved, we need to implement a way to update the pi. This is done by adding the code input_data.py into our application.py code(we have already done this). This basically sets the pis ID value to whatever ID you make it and updates the data values based on the results of your sensors. We set our pis ID to 1 (see application.py) so when we type in the browser URL + /get?id=1 it will return the values for our pi. This is the end of the steps for the website. It is secure in a sense that nothing but your pi can affect the data but not secure because anyone can input your ID number and see your data.
+
We started this project by looking at different sensors we could use for the system. We ended up ordering a moisture sensor, water level sensor, 12V relay, and a peristaltic pump. All of our purchases for the project can be found on the budget page. For the website part of this project we used Amazon Web Services to host our website. [[File:Soil Solutions Circuit Diagram bb.png]]The first thing to do is make an AWS account. Once that has been done you should navigate to the services tab in the top right of the menu and find Elastic Beanstalk under the tab Compute. Click create environment and make sure you select web server environment. You can name your environment whatever you like. Under Platform, choose preconfigured platform and select Python as the platform you wish to use; also select sample application as the application code (this can be changed from the console menu). Once you environment is created and you are the console menu, you now need to upload and deploy a zip file for your website to be run on. This zip file will contain your python code, html code, css code, and anything else you need to make your website. The code i used is on GitHub ([https://github.com/mattgwilson/soilsolutions Soilsolutions Repository]) The codes that were zipped together were application.py, requirements.txt, soilsolutions205.db, splash.html, dataview.html, and soilsolutions.css. Once you zip those files together, you can upload and deploy that zip file to the AWS server and once it has finished upload, you can click on the URL at the top of the console and access your website. If you would like to make the homepage of the website look different, you can edit our splash.html code and upload a new zipfile with a new splash.html. At this point nothing is being updated, but you can check that the table is there by entering your URL with the following "/get?id=test" this will show the data points in a table with all there values as test. This is because of the application.py code that defines test and what the values will be when id = test. Because the pi has not been involved, we need to implement a way to update the pi. This is done by adding the code input_data.py into our application.py code(we have already done this). This basically sets the pis ID value to whatever ID you make it and updates the data values based on the results of your sensors. We set our pis ID to 1 (see application.py) so when we type in the browser URL + /get?id=1 it will return the values for our pi. This is the end of the steps for the website. It is secure in a sense that nothing but your pi can affect the data but not secure because anyone can input your ID number and see your data.

Revision as of 19:54, 11 December 2017

Overview

  • For our project, we will be designing a method of watering various plants autonomously. We will do this by using a raspberry pi to monitor the moisture level in the soil and determine how much water should be added to the different types of plants. This will be done with a moisture level sensor designed for the arduino but that should work with the pi as well (we will need an analog to digital convertor for this). If water must be added, a solenoid also controlled by the pi will be opened and water will flow from the the water source to the plant until a sufficient level of moisture is detected by our moisture sensor in the soil. In order to water various plants and respect the differing needs of water for each plant we will 3D print a spigot for the water source that splits the water path into two directions. Each path will have its own solenoid that will open and close based on the specific plants needs. connected to the solenoids and the spigot will be drip irrigation tubing with button drippers attached to the sides of the tubing. We will also be using the raspberry pi to create a web based application (using Amazon AWS and PyCharm) for our system that will record logs of amount of water used, when water was used and moisture level in the soil. This application will solely be used for viewing results that will be updated every time the plant is watered. It will also be updated when the water level is critically low.

SoilSolutions Log

Team Members

  • Matt Wilson
  • Sean Rogers
  • Natalie Ng (TA)

Objectives

  1. We would like to make a system that is both cost and water efficient.
  2. We would like to build on our understanding of coding and learn new techniques that will be useful to us as engineers.
  3. We want this system be compact enough so that it would be easy to install.
  4. Overall make everything run smoothly and give ourselves plenty of time to test out our project.
  5. Allow for the system to detect the water level in the water source.

Challenges

  • Learning how to design a web based app with the raspberry pi.
  • Learning how to code in python and interfacing with the pi.
  • Designing a mechanical component that does not take up too much space.
  • Using the time we have efficiently and not digging ourselves into a hole.

Gantt Chart

SGC4.jpg

Budget

  • FC-28-D Soil Moisture Sensor - $5.00
  • ADC for Raspberry Pi (MCP3008 - 8 Channel 10-Bit ADC with SPI interface) - $3.75
  • Drip Irrigation Tubing (50ft) - $7.66
  • 1.25 Gallon Plastic Water Bottle - $7.26
    • (Bought at Walmart)
  • Drip Irrigation Button Dripper - $7.37
  • Potting Mix - $4.89
    • (Bought at Home Depot)
  • One Pot - $1.26
    • (Bought at Home Depot)
  • Water Level Sensors - $39.95
  • Peristaltic Pump - $24.95
  • 12V Power Source - $7.48
  • Hosting Service - $7.67
  • Raspberry Pi - Provided
  • Breadboard - Provided
  • Power Source - Provided
  • Home Depot Sales Tax - $0.75
  • Adafruit Shipping - $7.17
  • Amazon Shipping - Free
  • Total - $125.16

Design and Solutions

We started this project by looking at different sensors we could use for the system. We ended up ordering a moisture sensor, water level sensor, 12V relay, and a peristaltic pump. All of our purchases for the project can be found on the budget page. For the website part of this project we used Amazon Web Services to host our website. Soil Solutions Circuit Diagram bb.pngThe first thing to do is make an AWS account. Once that has been done you should navigate to the services tab in the top right of the menu and find Elastic Beanstalk under the tab Compute. Click create environment and make sure you select web server environment. You can name your environment whatever you like. Under Platform, choose preconfigured platform and select Python as the platform you wish to use; also select sample application as the application code (this can be changed from the console menu). Once you environment is created and you are the console menu, you now need to upload and deploy a zip file for your website to be run on. This zip file will contain your python code, html code, css code, and anything else you need to make your website. The code i used is on GitHub (Soilsolutions Repository) The codes that were zipped together were application.py, requirements.txt, soilsolutions205.db, splash.html, dataview.html, and soilsolutions.css. Once you zip those files together, you can upload and deploy that zip file to the AWS server and once it has finished upload, you can click on the URL at the top of the console and access your website. If you would like to make the homepage of the website look different, you can edit our splash.html code and upload a new zipfile with a new splash.html. At this point nothing is being updated, but you can check that the table is there by entering your URL with the following "/get?id=test" this will show the data points in a table with all there values as test. This is because of the application.py code that defines test and what the values will be when id = test. Because the pi has not been involved, we need to implement a way to update the pi. This is done by adding the code input_data.py into our application.py code(we have already done this). This basically sets the pis ID value to whatever ID you make it and updates the data values based on the results of your sensors. We set our pis ID to 1 (see application.py) so when we type in the browser URL + /get?id=1 it will return the values for our pi. This is the end of the steps for the website. It is secure in a sense that nothing but your pi can affect the data but not secure because anyone can input your ID number and see your data.