The MicroLab is an open-source, DIY, automated controlled lab reactor (CLR) that people can assemble with parts available online. We hope this will do for chemistry what the 3D printer did for manufacturing: provide a DIY, hackable, low-cost method to design and produce certain needful things that otherwise would be out of reach.
For the MicroLab to be accessible to the most people, it was developed as part of a hardware/software stack called the MicroLab Suite. The different software programs help take the information about a compound you want to make and translate it into a recipe (code) that the MicroLab runs to create the compound.
You can find an introduction to the project, what the heck is a CLR, what's in the MicroLab Suite, and why we are doing this at all on the About the MicroLab and MicroLab Suite page.
This section is for you if you want to build a MicroLab and start using it. We tried to make building the MicroLab friendly for folks newer to electronics, but you will need some knowledge and skills with electronics (or the patience to learn a few things).
- Learn About the MicroLab and MicroLab Suite so you have an understanding of what you are building.
- Start here for How to build & use the MicroLab and MicroLab Suite
This section is for you if you want to help develop the MicroLab and will need to tinker with the code base. If you're thinking about doing this, be sure to check out the development wiki and the current issues planned for development.
You will need to get a copy of the MicroLab software, set up your development environment either with a Docker container, on a Pi, or locally on your computer.
Use the instructions below for a fresh install of the MicroLab software (backend and GUI) on your development machine.
If you intend to construct a full MicroLab, we recommend using our pre-made disk images. There are two:
- A "production" image that runs all software on startup and includes the drivers for a goodtft-compatible 3.5 inch mini-display. This is the software you need if you have assembled a MicroLab and you want to use it to run reactions.
- A "development" image designed to be used with an external HDMI monitor and a USB mouse and keyboard. This would be the software to run on a computer where the MicroLab hardware can be emulated.
If you are using the development image and running it on a computer with emulated hardware turn on, follow the instructions below.
For ease of setup/experimentation we added docker containers for both the GUI and the API. If you don't have docker-compose installed on your system you can install docker desktop following these docs
git clone https://github.com/FourThievesVinegar/solderless-microlab.git
cd solderless-microlab
## To run API & GUI
docker-compose up --build gui
## Alternatively
## To run just the API
docker-compose up --build api
If you're running docker with a hardware setup you'll need to edit docker-compose.yml and uncomment the lines specified in the file.
Docker-compose mounts docker/microlab-docker.ini
local file as /etc/microlab/microlab.ini
in the container. To modify microlab config
just edit docker/microlab-docker.ini
file and restart the container in docker-compose.
For making local development simpler - backend/
directory is also mounted as container's /app
directory. Any local file change is automatically reflected in the container but in most cases you would also need to restart container anyway so the python processes load from updated files.
Clone the repo:
git clone https://github.com/FourThievesVinegar/solderless-microlab.git
cd solderless-microlab
(for Debian / Ubuntu)
sudo apt update
sudo apt install python3 python3-pip python-virtualenv python3-virtualenv
The backend is tested against CPython 3.9 to 3.13.
Note: some versions of Linux have dropped support for Python2 and python-virtualenv
.
(for macOS)
brew update
brew install python3
pip3 install virtualenv
Set up a Python virtual environment: virtualenv -p python3 --system-site-packages env
cd backend
virtualenv -p python3 --system-site-packages env
source env/bin/activate
(env) $ pip install -r requirements.txt
(on the Pi)
sudo apt -y install screen git python3-flask python3-pip python3-serial python3-libgpiod
(env) $ python main.py
(for Debian / Ubuntu)
Follow a guide to install yarn for Debian:
https://classic.yarnpkg.com/en/docs/install/#debian-stable
In summary:
curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list
sudo apt update
sudo apt install yarn
(for macOS)
brew update
brew install yarn
cd gui
yarn install
yarn start
The GUI will now be listening on port 3000.
To run the software without a functioning hardware environment, go to the settings menu and change the "MicroLab Controller" setting to "simulation-pi" and "Lab Hardware Config" to "ftv_simulation_microlabv0.5.0"
If you have a MicroLab to run the software on, you may want to enable SSH on the Pi. This makes remote development easier. Instructions for doing so can be found here: https://itsfoss.com/ssh-into-raspberry/
Once your environment is setup, head on over to the Backend README