/plant_tech_ams

Plants, Arduino boards, moisture sensors and watering systems

Primary LanguageC++

Plant Tech

🌱 Table of Contents 🌱

Before the event

We're excited to have you join this course, where you'll be working with plants, Arduino boards, moisture sensors and watering systems. The aim of Make Days is to explore and learn new things. You don't need to achieve specific goals. The structure caters for varying levels of experience; different Makers will learn different things by playing with the same tools!

Preparing for the Make Event

👉 Before the event, complete the Make Preparation Manual to get your LED blinking and ensure you are setup for the event.

Please see Troubleshooting if you run into issues.

At the event

Bring your own

  • Tall glass or container with water to test the sensor and water pump
  • Laptop/PC with USB-A port or adaptor

What will be available for you on the evening

complete

In the diagram

  1. ESP8266 module - how it works
  2. Dupont f-f wires (x10)
  3. Moisture sensor
  4. Watering pump
  5. TIP31C Transistor

Additionally

  • Micro usb to usb A cable
  • PVC tube + cable tie
  • Connector

Part 1 - Set up your plant 🌱

🇳🇱 Netherlands Teams

Add 300 ml water to the bag with pressed soil, forming ~1 liter of compost. Make a few small (1cm deep) holes in the soil and place the basil seeds in them, covering with a bit of loose soil.

🇿🇦 South African Teams

  • Fill your pot most of the way with soil
  • Sprinkle your seeds on top
  • Cover with ±1 cm soil

Part 2 - Moisture Sensor 💦

Connect the moisture sensor with the LM393 chip that comes in the same pack. The sensor has both an analog (0 for wet and 1023 for dry) and a digital (LOW for wet and HIGH for dry) output. Check the pinout for the sensor above and see where it would connect to the ESP8266 board (tip: it has an analog, digital, GND, and needs a voltage).

moisture

Connect the ESP8266 with your PC and start up the Arduino IDE. Sometimes the ESP8266 does not show in your IDE. If so, look for the right USB-port (Tools > Port).

ESP8266

Try writing a little programme to print the sensor's moisture values (analog is more interesting here as it gives you a value from a wetness-range). If coding isn't your strong suit, you can use the code provided in this repo for the Moisture Sensor.

Upload your code to your system, wait untill the upload is done - the terminal should read: "Leaving... Hard resetting via RTS pin..." - and open the monitor (Tools > Serial Monitor) to see your printed values. Make sure that the Baud rate in the program and your serial monitor window are the same. If you used the code from the repo above, select the 115200 BAUD option for upload speed, otherwise your readings are not printed.

Put your sensor (only the two large exposed pads) in the compost of your plant, or simply put it in a glass of water, to do some readings!

Part 3 - Mini Water Pump ⛽️

The pump is water submersible, sucks in water from the hole on the opposite end of the wires, and pumps it through the little outlet. In order to switch the pump on and off, it needs to be connected to the ESP8266 with the TIP31C Transistor. Use the connector (white block with four inlets) to do so. The two wires of the pump go in one side, the other side takes your Dupont wires. By gently pulling off the plastic bit of one side of the Dupont wire, exposing the metal, you can put it in the other side of the connector.

pump tip31c

The pump has a GND output to be connected to the ESP8266 and receives power from the emitter pin of the transistor. The transistor gets its power through its collector pin from the ESP8266's 3V3 pin. Finally, connect the base to the D6 pin to be able to control the pump.

Write some code (or check the code from the complete watering system in this repo) to get the pump up and running. Before uploading the code, make sure to submerse the pump in your tall glass/container filled with water, as you do not want to overheat its motor - and please watch out for water spills ;)

Part 4 - Time to play! 🥳

Now that the basics of your system are up and running, it's time to play around a bit! You can put your moisture sensor in your plant and attach the PVC tubing to the water pump (potentially use the cable tie to prevent leaking) with one end, and lay the other end in the plant.

See what analog value would be a good threshhold of dryness. Implement this in your code to start activating your pump as soon as this threshold is reached. Also try to implement some delays in your code to stop the pump after a few seconds, as it takes some time for the soil to get moist and the sensor to pick this up.

If you are confident that your very own automated watering system is fully working, you can check out the repos below for some inspiration on how to communicate with your system via your phone :)

unbox

After the event

NB! Giving feedback

After the event we only ask one further thing: please help us keep these going and growing by giving us feedback and inviting friends using the forms below 🙏

🎁 We want to give you the gift of giving! please refer people that you think would love to attend one of our next sessions and get the Make @ Home Box delivered to their door. You can do so via the same form! 🎁

Project extensions

You can find extensions for the project here.

Connect to the WiFi

Connect your ESP8266 with your Wi-Fi

Build a chatbot

Let your system update you, and feed it commands, via text/slack/whatsapp with the MessageBird API

Send messages on slack or telegram.

Telling your plant to water itself - by speech! Blogpost + code

Set up a web server

Example https://randomnerdtutorials.com/esp8266-dht11dht22-temperature-and-humidity-web-server-with-arduino-ide/

Important: if you want to use the ESP8266 WEB Server in this example you will need to downloand the following two libraries. These libraries are not available in the library manager.

Installing the ESPAsyncWebServer library

The ESPAsyncWebServer library is not available to install in the Arduino IDE Library Manager. So, you need to install it manually.

Follow the next steps to install the ESPAsyncWebServer library:

https://github.com/me-no-dev/ESPAsyncWebServer/archive/master.zip

Unzip the .zip folder and you should get ESPAsyncWebServer-master folder Rename your folder from ESPAsyncWebServer-master to ESPAsyncWebServer Move the ESPAsyncWebServer folder to your Arduino IDE installation libraries folder

Installing the ESPAsync TCP Library

The ESPAsyncWebServer library requires the ESPAsyncTCP library to work. Follow the next steps to install that library:

https://github.com/me-no-dev/ESPAsyncTCP/archive/master.zip

Unzip the .zip folder and you should get ESPAsyncTCP-master folder Rename your folder from ESPAsyncTCP-master to ESPAsyncTCP Move the ESPAsyncTCP folder to your Arduino IDE installation libraries folder Finally, re-open your Arduino IDE

RGB LED

Extend you project with an RGB LED to indicate moisture levels with colors.

3D printed enclosure

3dprintedencls 3dprintedencls

Community Project Repos

You can find code and projects and advice submitted by the community here. Please submit your code for inclusion :)

Repo Description Author
Automatic pid water portion control This project uses 2 humidity levels one for the night/morning and one for the afternoon/midday. You can set your timezone-offset and humidity levels in the web interface. I'm in the process of testing it on a live plant though so I won't take any blame for drowned plants. It does have a watchdog timer for safety. by @ikilledmypc.
Playing withb Arduino setup First attempt playing with the arduino enviroment working with embedded c++ by @ronaldf2000.
OfferZen Plantfeeder Has a web interface for MQTT configuration as well as WIFI configuration. by @ries.
Self watering plant Code for Connecting to local wifi, Creating a web server, Managing MQTT connection, Managing sensors. by @semih çokçeken

Useful resources

Micropython submitted by Michiel Erasmus

  • Ditch the Arduino IDE.
  • 😊 Micropython = Python 3.4. No need to recompile your code. Run your code by pressing F5 (in Thonny) to run.
  • Runs on ESP8266, ESP32-platforms. Has a filesystem so you can copy files to it from Mac/Win/Linux.
  • Interfaces with a huuuuuuge number of sensors.
  • CircuitPython is a fork of Micropython. Go check out Micropython.
  • Lotsa tutorials online available, otherwise let me know if/how I can help (@MIchiel Erasmus on OfferZen Community Slack).
  • Use https://thonny.org as editor.

Other

Additional equipment

To shop for equipment see suppliers lists in your country:

Here's a list of equipment that has come up as ideas for extending the project further.

Item Description
I2C Soil Moisture Sensor add description...
Capacitive analog moisture sensor No metal parts touching the water so no corrosion problems causing inaccuracy in the long run
Linear Voltage Regulator add description...
JOY-IT DPS 5005 DPS This programmable module for controlling voltage with a constant voltage and constant current.
Adafruit STEMMA Soil Sensor - I2C Capacitive Moisture Sensor Alternative moisture sensor, multiple can be connected if using ESP2866.
ELEGOO Elektronische Fun Kit An electronics starter kit for exploring further.
Raspberry Pi 4B – Ultimate starter kit Starter kit for expanding further.
AZDelivery 16 in 1 Kit Expanded sensors kit

Troubleshooting

USB port not showing in Tools > Port

  • If your USB port does not show up in Tools > Port, you may need the driver.
    • If your board has a square chip next to the USB port then use this driver for the usb-uart. (CP2102 Chipset)
    • If your board has a rectangular chip next to the USB port then use this driver for the usb-uart. (CH340 Chipset)
    • When that doesn't solve the problem, (this seems to happen when using a MacBook with an USB-C adapter) check this forum.
    • If you're still stuck, let us know in the Slack Channel so we can help you get it to work!

"Fatal Error Failed to connect"

If you see a Fatal Error Failed to connect to ESP8266: Timed out waiting for packet header (this might not happen on the first time but in subsequent uploads): disconnect the external board and upload again, connecting the wires after this. Reference.

  • For some people this does not work, as an alternative, you need to force the label (D4) to a low state, or maybe use a different label. To do this follow these steps:

Booting into program mode

  1. press and hold the "RST" button
  2. press and hold the "FLASH" button
  3. release the "RST" button, the ESP will boot in program mode
  4. release the program button
  5. upload the sketch

Struggling to connect to Wifi

The Arduino's Wifi antenna is very small and not very strong, so you might need to move it closer to the Wifi.

You can use this program to find SSID's and check signal strength.

Mac users unable to get your Hello World up and running

Solution submitted by Alex Siega

  1. Under Tools > Board, make sure to select "Generic ESP8266 Module." Mine defaults to "Arduino Uno" without actively selecting the right board.
  2. Install the drivers from the OfferZen Prep page. Make sure to give the drivers the correct permissions in the Security & Privacy area in System Preferences; it's at the end of the "General" tab.
  3. In Tools > Port, select /dev/cu.usbserial-1420 at the port. (No mention of "right" USB port, but hey, it works! 😄)
  4. Last step -- when you go to upload blinkESP.ino, you may get a 'D4' was not declared in this scope error. Change D4 to 2 , making the first line # define LED 2

This results in a blue light flashing every second, which I believe is the "hello world" described in the prep document!

Paolo Brizzolari > @Alex Siega it’s cool that you got it working. Just a couple of points:

Using the generic 8266 doesn’t guarantee that all the pins will have the right numbers so I’d advise choosing the NodeMCU board once you’ve added the json url to the boards manager The alias D4 that disappeared was because of the above. For each board there is an import happening in the background If you check the esp8266 libraries you can go into variants/nodemcu/pins_arduino.h and see the following.

Mac OSX: Big Sur upload errors

If when trying to upload a sketch to your board you get the following error, then try the steps below.

**pyserial or esptool directories not found next to this upload.py tool.

  1. Open ~/Library/Arduino15/packages/esp8266/hardware/esp8266/2.7.4/tools/pyserial/serial/tools/list_ports_osx.py
  2. Comment out lines 29 and 30 and append these lines:
iokit = ctypes.cdll.LoadLibrary('/System/Library/Frameworks/IOKit.framework/IOKit')
cf = ctypes.cdll.LoadLibrary('/System/Library/Frameworks/CoreFoundation.framework/CoreFoundation')

If the error is still occurring.

  1. Edit ~/Library/Arduino15/packages/esp8266/hardware/esp8266/2.7.4/tools/esptool/esptool.py
  2. Find the block of code below and comment it out by adding # to the start of each line:
#try:
#    import serial.tools.list_ports as list_ports
#except ImportError:
#    print("The installed version (%s) of pyserial appears to be too old for esptool.py (Python interpreter %s). "
#          "Check the README for installation instructions." % (sys.VERSION, sys.executable))
#    raise

Windows: USB Driver issues

Problem Can’t seem to find any that work for me. The ones recommended on the guide don’t help and the “port” option stays grayed out in the arduino ide.

Solution - Adam Hillier I had the same issue. I installed the driver from here: https://sparks.gogo.co.nz/ch340.html. It worked for me.

My pump isn't working

Try connect it to a 3V+ battery to test it.