/plantuino

An Arduino shield and code that measures moisture, light and temperature in a garden and display it on network, via pachube or Thingspeak and can control it's own irrigation system

Primary LanguageJavaBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Plantuino

This project was inspired heavily by a makezine article that looked at building a garden automation system to grow a plant including switching lights on and off etc. This version of it is more around the idea of an outdoor garden already that the user wants to have some interactions with.

In this current iteration it is mostly oriented towards simply building a sensor array for moisture, temperature and light and logging that whether to a serial connection or making it available over the network.

Examples also include pushing data to Pachube and Thingspeak in order to capture and display the data using a web service.

There is also capacity for the system to control an irrigation system to allow it to water.

Most up to date version of this project can be found at: https://github.com/ajfisher/plantuino

Roadmap

The long term plan for this project is to encompass the following:

  • Using ZigBee to communicate to a base station to allow for non-wired comms
  • Developing a reporting API to submit the data to various applications (this will probably be related to Pachube somehow)
  • Hook up to a weather feed in order to determine if the plants will need water

Dependencies and usage

All

  • The AnalogMuxDeMux library available from github.com/ajfisher/arduino-analog-multiplexer/
  • An Arduino (will work with Duemilanove or Uno or similar) fitted with a shield with schematic in this folder connect up to 8 probes, a temperature sensor and a light senor.

Serial Plantuino

An arduino connected to a serial port of the computer you want to log the data to. This is a good test to see that the shield it all working correctly and you are getting the right data. Also useful to ensure calibration of your thermistor.

Usage

  • Plug the shield (or attach the components via a breadboard) to the arduino and connect the arduino to your computer.
  • Connect your various sensors
  • Download the plantuino_serial.pde sketch and upload it to the arduino.
  • Open up your serial monitor (in Arduino IDE or using a serial application such as screen from a Linux terminal)
  • You should now see all the details coming from your various sensors.

Networked Plantuino Simple

An Arduino connected to a network connection that you want to see the data it is reporting just like the serial version above. A good starting point to ensure your sensor can network appropriately.

Dependencies

Get an Arduino Ethernet Shield such as the official one or any other, I personally prefer to use the EtherTen from FreeTronics as it gives you an Arduino and Ethernet on the same board which saves vertical height (http://www.freetronics.com/products/etherten)

Arduino networking is out of the scope of this doc, see the Arduino Playground for a good primer and also play with the Arduino IDE Ethernet examples to ensure your board is working. See http://www.arduino.cc/playground/Main/InterfacingWithHardware#ethernet for more.

Usage

  • Plug the plantuino circuit into the ethernet / arduino combination - ensure your ethernet shield has worked on your network first so as to reduce possible bugs.
  • Open up plantuino_networked_simple.pde and set a MAC address that is unique on your network as well as setting the IP, subnet and gateway bytes as per your LAN
  • Save and upload the code to your arduino.
  • Open a web browser and go to the IP address that you specified in your code. You should get a page that displays the current state of your code. Note that there is a reference in there to a style sheet on my server so you don't need to serve it from your arduino...

Thingspeak Plantuino

An Arduino connected to the Internet that pushes data up to Thingpseak for display or other usage.

Dependencies

  • A Plantuino set up that functions as per the Networked Simple Plantuino set up above.
  • A user account on Thingspeak (http://www.thingspeak.com)
  • Your write key from Thingspeak

Usage

  • Plug the plantuino circuit into the ethernet / arduino combination - ensure your ethernet shield has worked on your network first so as to reduce possible bugs.
  • Open up plantuino_thingspeak.pde and set a MAC address that is unique on your network as well as setting the IP, subnet and gateway bytes as per your LAN
  • Set your API write key as per instructions in the code.
  • Save and upload the code to your arduino.
  • You should now be able to go to your feed on Thingspeak and see your data flowing in.

Pachube plantuino

An Arduino connected to the Internet that pushes data up to Pachube for display or other usage such as setting triggers for events etc.

Dependencies

  • A plantuino set up that functions as per the Networked Simple Plantuino set up above.
  • A user account on Pachube (http://www.pachube.com). Note a free account is sufficient but you can only have 5 data streams.
  • Your Pachube API key
  • Your Pachube Feed ID
  • Download and install the Pachube library ERxPachube (http://code.google.com/p/pachubelibrary/) This abstracts a lot of the details of pushing up the data - makes it nice and quick and easy to use.

Usage

  • Open up ERxPachube.h in the ERxPachube library folder and modify the line that says:

    #define MAX_DATASTREAM_NUM 4
    
    to be:
    
    #define MAX_DATASTREAM_NUM 10
    
  • Plug the plantuino circuit into the ethernet / arduino combination - ensure your ethernet shield has worked on your network first so as to reduce possible bugs.

  • Copy the config.h.sample file to config.h and change the following::
    • set a MAC address that is unique on your network as well as setting the IP, subnet and gateway bytes as per your LAN
    • Set your API key as per instructions in the code.
    • Set your Feed ID as per instructions in the code
  • Save and upload the code to your arduino.

  • You should now be able to go to your feed on Pachube and see your data flow in

Watering System

The watering system is designed to turn a drip feed irrigation system on and off in order to water the plants. This is controlled via a second arduino that is connected to the network and uses a relay shield to turn a remote control on and off.

Details on how to do the wireless plug socket hack can be found here: http://www.practicalarduino.com/projects/appliance-remote-control

Setting up an irrigation system is an exercise for the implementer however all this is doing is simply switching a pump on and off as required.

Each relay is bound to a digital IO pin on the Arduino, in this case 2 & 3. Pulling 2 high will switch the pump on, pulling pin 3 high will switch the pump off.

Using a sketch adapted from https://gist.github.com/1290670 a restful interface is created by defining the channels you want and then making HTTP calls to them.

Usage:

  • Set up your irrigation system and make sure it works with the standard wireless remote
  • Set up your arduino with a relay shield per the link above. Use a simple controller sketch to make sure you can switch the pump on and off via the arduino and your relay shield works properly.
  • Copy network.sample to network.h and fill in the relevant details for your network.
  • Define your channels, assigning a pin in order to each channel.
  • Compile and load the sketch onto your arduino

You should be able to ping your Arduino's IP address if it's working correctly. From there direct your browser to:

http://your-ip/channel-no

Where channel-no is the relay channel you want to control.

EG: In my network to turn on my pump I use this URL:

http://10.0.1.57/0

And to turn it off:

http://10.0.1.57/1

You can increase this to however many channels and pins you want to connect so if you had 8 relays you could use all the digital pins available if you wanted.