AquaTherm is a project that designed to revolutionize aquarium management by ensuring precise control over temperature and water levels. While offering both Desktop and Web GUIs, involves sensor readings, collecting sensor reading data, performing analysis, taking appropriate actions according to collected data and communicating with other systems for further processing, by utilizing and connecting multiple Arduino and Raspberry-related products to multiple devices through USB, Wi-Fi or Radio communication.
- Python
- Tkinter
- SQLAlchemy
- Flask
- Prometheus
- Grafana
- SQLite
- Docker
- cAdvisor
- Node exporter
- Arduino
- Raspberry Pi
- Digi
- jQuery
AquaTherm offers a range of features that make it a powerful tool for managing sensor data and automating actions:
-
Temperature and Humidity Reading, Displaying, and Management
-
Automated Actions for Specific Scenarios:
- Decreasing Temperature, Increasing Aquarium Water Level
-
DHT22 : A pre-calibrated, SWI digital sensor with fast response time used to measure temperature and humidity.
Measurement capabilities with a high degree of accuracy:
- Temperature with a range of -40°C to 80°C (-40°F to 176°F).
- Relative humidity within a range of 0% to 100% RH.
Operating voltage:
- Compatible with 3.3V or 5V power supplies.
-
SR04 AKA HC-SR04: An Ultrasonic Sensor used to measure distance.
Measurement capabilities:
- Used for measuring distances in the range of 2 cm (0.79 inches) to 400 cm (157.5 inches).
- Typical accuracy of about ±1 cm.
Operating voltage:
- Compatible with 3.3V or 5V power supplies.
- The Arduino Software (IDE) was used during the creation of the sensor controlling releated codes.
To upload the codes to the board('s) :
- Download and install the Arduino Software IDE.
- Connect your Arduino board to your device.
- Open the Arduino Software (IDE).
The Arduino Integrated Development Environment - or Arduino Software (IDE) - connects to the Arduino boards to upload programs and communicate with them. Programs written using Arduino Software (IDE) are called sketches. These sketches are written in the text editor and are saved with the file extension .ino.
- Select the right board & port. This is done from the toolbar. Make sure you select the board that you are using. If you cannot find your board, you can add it from the board manager in the sidebar.
- To upload the code to your board, simply click on the arrow in the top left corner. This process takes a few seconds, and it is important to not disconnect the board during this process. If the upload is successful, the message "Done uploading" will appear in the bottom output area.
- Once the upload is complete, you can use the board with the sensors specified in the Used Sensor section.
- For Raspberry Pi: To upload the codes to the board('s) :
- Download and install the Raspberry Pi Imager and follow the instructions provided on the official page.
- After the installation you can use the board with the sensors specified in the Used Sensor section.
In either cases both the pin in the sensor controller files and baud rate can be customized in both the sensor controller files and the python files in ./sensor/arduino directory and the ./sensor/raspberry directory if the values i used are not adequate. The pins(2 - temperature and humidity, 13 - distance, 3 - fan , 5 - tap) the baud rate 115200
- For Radio Communication :
- 2 Xbee Radios modell, to program the radios, a SparkFun USB Explorer needed and finally an Xbee Shield. The shield allows you to plug the Xbee radio into the Arduino.
- Download and install the XCTU software to program the radios. AES encryption can be created during the configuration of the connected radio.
- Set the port and the baud rate .
- To get started with AquaTherm, make sure you meet the following prerequisites:
- Python installed on your machine. Download Python from the official website and follow the installation instructions.
If you plan to deploy AquaTherm using Docker containers, follow these steps:
Install Docker:
- For Linux: Follow the instructions on the official Docker website.
- For Windows or macOS: Install Docker Desktop for an easy-to-use Docker environment.
After installing Docker, ensure it's running by opening a terminal or command prompt and running the command docker --version
.
Note: Docker is optional and recommended for deployment scenarios. If you're using Docker, it can help manage dependencies and ensure consistent environments.
1. Clone the repository:
Start by cloning the AquaTherm repository to your local machine. Open a terminal or command prompt and run the following command:
git clone https://github.com/RMNorbert/AquaTherm.git
install the required packages with the following command:
pip install -r requirements.txt
if raspberry sensors used install the the required package with the following command: bash
pip install adafruit-circuitpython-dht
C library for interacting with Linux GPIO device:
sudo apt-get install libgpiod2
2. A, Run the Desktop app with:
bash
python3 main.py
2. B, Run the Web app with:
python3 web_app.py
Access the application: Once the Web app is running, you can access it in your web browser at http://localhost:5000.
2. C, Run the dockerized version with:
- Navigate to the project directory containing the
docker-deploy.yml
file. - Run the command
docker-compose up --build
to build and start the project.
The docker-deploy.yml
file defines the services and configurations needed for running your application in a Docker container. It simplifies deployment and ensures consistent setups across environments.
Access the application:
Once the Web app is running, you can access it in your web browser at http://localhost:5000.
Access Prometheus at http://localhost:9090
Grafana at http://localhost:3000
This project is licensed under the MIT License - see the License file for details.
Then sensor controller files can be simulated on https://wokwi.com/ or with the VS code extension named : Wokwi Simulator