Environmental Regulation System
Latest version: 8.15.9
Mycodo is open source software for the Raspberry Pi that couples inputs and outputs in interesting ways to sense and manipulate the environment.
Table of Contents
Prerequisites: Debian-based Linux operating system (apt).
Recommended: Single board computer (SBC) with General-Purpose Input-Output (GPIO) pins.
Install Command:
curl -L https://kizniche.github.io/Mycodo/install | bash
See the Install Mycodo section for more details.
Mycodo API (Version: v1)
Mycodo Custom Module Repository
Mycodo Issues (Bug Reports/Feature Requests)
If you believe there is a bug in the Mycodo software, first search through the github Issues and see if your issue has already recently been discussed or resolved. If your issue is novel or significantly more recent than a similar one, you should create a New Issue. When creating a new issue, make sure to read all information in the issue template and follow the instructions. Replace the template text with the information being requested (e.g. "step 1" under "Steps to Reproduce the issue" should be replaced with the actual steps to reproduce the issue). The more information you provide, the easier it is to reproduce and diagnose the issue. If the issue is not able to reproduced because not enough information is provided, it may delay or prevent solving the issue.
I have always made Mycodo free and I don't intend on changing that. However, if you find Mycodo useful and would like to support its continued development, please consider becoming a sponsor at github.com/sponsors/kizniche or donate at kylegabriel.com/donate.
- Inputs that record measurements from sensors, GPIO pin states, analog-to-digital converters, and more (or create your own Custom Inputs). See all Supported Inputs.
- Outputs that perform actions such as switching GPIO pins high/low, generating PWM signals, executing shell scripts and Python code, and more (or create your own Custom Outputs). See all Supported Outputs.
- Functions that perform tasks, such as coupling Inputs and Outputs in interesting ways, such as PID, Conditional, Trigger, to name a few (or create your own Custom Functions). See all Supported Functions.
- Web Interface for securely accessing Mycodo using a web browser on your local network or anywhere in the world with an internet connection, to view and configure the system, which includes several light and dark themes.
- Dashboards that display configurable widgets, including interactive live and historical graphs, gauges, output state indicators, measurements, and more (or create your own Custom Widgets). See all Supported Widgets.
- Alert Notifications to send emails when measurements reach or exceed user-specified thresholds, important for knowing immediately when issues arise.
- Setpoint Tracking for changing a PID controller setpoint over time, for use with things like terrariums, reflow ovens, thermal cyclers, sous-vide cooking, and more.
- Notes to record events, alerts, and other important points in time, which can be overlaid on graphs to visualize events with your measurement data.
- Cameras for remote live streaming, image capture, and time-lapse photography.
- Energy Usage Measurement for calculating and tracking power consumption and cost over time.
- Upgrade System to easily upgrade the Mycodo system to the latest release to get the newest features or restore to a previously-backed up version.
- Translations that enable the web interface to be presented in different Languages.
Figure: Automated Hydroponic System Build
Originally developed to cultivate edible mushrooms, Mycodo has evolved to do much more. Here are a few things that have been done with Mycodo:
- Mushroom Cultivation Automation (Archive)
- Hydroponic System Automation (Archive)
- Mushroom cultivation (Archive)
- Ground-based plant cultivation
- Maintaining honey bee apiary homeostasis (Archive)
- Maintaining humidity in an underground artificial bat cave (Archive)
- Remote radiation monitoring and mapping (Archive)
- Cooking sous-vide (Archive)
- Maintaining a light schedule and regulating humidity, ramping from 90 % to 50 % over a 4 week period to acclimatize micropropagated American chestnut plantlets from laboratory to ambient outdoor conditions (Archive)
- Maintaining aquatic systems (e.g. fish, hydroponic, aquaponic)
- Maintaining terrarium, herpetarium, and vivarium environments
- Incubating young animals and eggs
- Aging cheese
- Dry-aging, curing, and smoking meat (Link 1 (Archive), Link 2 (Archive))
- Fermenting beer, food, and tobacco
- Controlling reflow ovens
- Culturing microorganisms
- Treating agricultural waste water (Archive, Publication)
- ...and more
Let me know how you use Mycodo and I may include it on this list.
Visit the Screenshots page of the Wiki.
Required:
- Debian-based operating system
- An active internet connection
Recommended:
- Raspberry Pi single-board computer (any version: Zero, 1, 2, 3, or 4)
- Raspberry Pi Operating System flashed to a micro SD card
Mycodo has been tested to work with Raspberry Pi OS Lite and Desktop, both 32-bit and 64-bit.
Once you have the Raspberry Pi booted, log in and run the following command in a terminal to initiate the Mycodo install:
curl -L https://kizniche.github.io/Mycodo/install | bash
Make sure the install script finishes without errors. A log of the output will be created at ~/Mycodo/install/setup.log
.
If the install is successful, the web user interface should be accessible by navigating a web browser to https://127.0.0.1/
, replacing 127.0.0.1
with the IP address of the computer you installed on. Upon your first visit, you will be prompted to create an admin user before being redirected to the login page. Once logged in, check that the time is correct at the top left of the page. Incorrect time can cause a number of issues with measurement storage and retrieval in a time-series database. Also ensure the host name and version number at the top left of the page is green, indicating the daemon is running. If it's red, it indicates the daemon is inactive or unresponsive. Last, ensure any java-blocking plugins of your browser are disabled for all parts of the web interface to function properly.
If you receive an error during the install that you believe is preventing your system from operating, please create an issue with the install log attached. If you would first like to attempt to diagnose the issue yourself, see Diagnosing Issues.
A minimal set of anonymous usage statistics are collected to help improve development. No identifying information is saved from the information that is collected and it is only used to improve Mycodo. No one other than the development team will have access to this information and it will never be sold. The data collected is mainly what and how many features are used, and other similar information. The data that's collected can be viewed from the 'View collected statistics' link in the Settings -> General
page. There is an opt out option on the General Settings page if you want to turn this functionality off.
Mycodo currently supports InfluxDB as the time-searies database used to store measurements. Both versions 1.x (for 32-bit systems) and 2.x (for 64-bit systems) are supported. During the install, you will be prompted to install 1.x, 2.x, or none (if you wish to set up your own, either locally or remotely). The settings for the database can be reconfigured after install.
Docker support is experimental, but if you want to try it, read the [DOCKER.md](https://github.com/kizniche/Mycodo/blob/master/DOCKER.md). There is also a Docker Issue (#637) on github for those that wish to help with development.
The latest API documentation can be found here: API Information and API Endpoint Documentation.
A proportional–integral–derivative (PID) controller is a control loop feedback mechanism used throughout industry for controlling systems. It efficiently brings a measurable condition, such as temperature, to a desired state (setpoint). A well-tuned PID controller can raise to a setpoint quickly, have minimal overshoot, and maintain the setpoint with little oscillation.
The top graph visualizes the regulation of temperature. The red line is the desired temperature (setpoint) that has been configured to change over the course of each day. The blue line is the actual recorded temperature. The green vertical bars represent how long a heater has been activated for every 20-second period. This regulation was achieved with minimal tuning, and already displays a very minimal deviation from the setpoint (±0.5° Celsius). Further tuning would reduce this variability further.
See the PID Controller and PID Tuning sections of the manual for more information.
All supported Inputs, Outputs, and other devices can be found under the Supported Devices section of the manual.
Mycodo supports importing custom Input, Output, Function, Action, and Widget modules. you can find more information about each in the manual under Custom Inputs, Custom Outputs, Custom Functions, Custom Actions, and Custom Widgets.
If you would like to add to the list of supported Inputs, Outputs, Functions, Actions, and Widgets, submit a pull request with the module you created or start a New Issue.
Additionally, I have another github repository devoted to custom Inputs, Outputs, Functions, Actions, and Widgets that do not necessarily fit with the built-in set and are not included by default with Mycodo, but can be imported. These can be found at kizniche/Mycodo-custom.
Thanks for using and supporting Mycodo, however depending where you found this documentation, you may not have the latest version or it may have been altered, if not obtained through an official distribution site. You should be able to find the latest version on github.
https://github.com/kizniche/Mycodo
See License.txt
Mycodo is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
Mycodo is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
A full copy of the GNU General Public License can be found at http://www.gnu.org/licenses/gpl-3.0.en.html
This software includes third party open source software components. Please see individual files for license information, if applicable.
Mycodo has been translated to several laguages. Weblate is now used so anyone can contribute to translations. However, due to an increasing number of new languages being added and not translated, only languages that are at least 50% complete will be included in Mycodo as a translation option.
- Native: English
- Dutch, German, French, Indonesian, Italian, Norwegian, Polish, Portuguese, Russian, Serbian, Spanish, Swedish, Turkish, Chinese.
The install script will prompt you to select a language. This will be the set language when you first open the web user interface. You may change this at a later time on the settings page at [Gear Icon] -> Configure -> General -> Language
.
If you would like to contribute to the translations, you can do so at http://translate.kylegabriel.com. Please read [How To Contribute to Language Translations in Mycodo](https://forum.radicaldiy.com/t/how-to-contribute-to-language-translations-in-mycodo/1162/2) for more information.
Mycodo is made possible, in part, by the many fine open source libraries, below.
- Alembic
- Argparse
- Bcrypt
- Bootstrap
- Daemonize
- Date Range Picker
- Distro
- Email_Validator
- Filelock
- Flask
- Flask_Accept
- Flask_Babel
- Flask_Compress
- Flask_Limiter
- Flask_Login
- Flask_Marshmallow
- Flask_Profiler
- Flask_RESTX
- Flask_Session
- Flask_SQLAlchemy
- Flask_Talisman
- Flask_WTF
- FontAwesome
- Geocoder
- gridstack.js
- Gunicorn
- Highcharts
- importlib_metadata
- InfluxDB
- influxdb
- influxdb_client
- jQuery
- Marshmallow_SQLAlchemy
- Pyro5
- SQLAlchemy
- SQLite
- toastr
- Werkzeug
- WTForms