Software Setup
Note
Page under development. This page is missing:
- Basic tests on the software, to check that everything is working at each stage.
Software Setup Guide¶
Required skills and resources:
- A working local WiFi network, with internet access.
- Basic proficiency with computers and IP networks.
- Raspberry Pi and 32GB+ micro SD card.
Depending on your background, the Network setup may be the most challenging part of the guide, which depends on your LAN settings and the operating system on your computer - which we do not control.
Hang in there!
Overall steps in this guide:
- Load the Pi ISO to an SD card.
- Configure a network connection.
- Set or find the Pi's IP address on your local network.
- Install all software components.
Operating Systems¶
To get started with the software setup on a Raspbery Pi, you need to write an OS to a micro SD card.
Pipettin OS¶
Pipettin OS is a full system image of a configured OS for the Raspberry Pi, based on either Raspberri Pi OS or Ubuntu for Raspberry Pi.
If you use Pipettin OS, you may then move on to the Electronics Setup Guide, and skip the rest of this one.
Tip
This is the recommended way of installing pipettin's software.
To install Pipettin OS follow the OS flashing guide.
Raspberry Pi OS¶
Follow this guide to start loading Raspberry Pi OS to an SD card.
Then continue with the software setup below.
Connect to the RPi¶
To install the software components, you need access a terminal on the Pi. This also involves finding it's IP address on the local network, which is also required to use the robot.
There are two access methods:
- For network connections, you can follow the headless setup instructions.
- This option is recommended to operate the robot through the network (i.e. from a different computer).
- Its great if you do not have a spare display and keyboard.
- Connect a keyboard and monitor to the Pi, as described in the desktop Pi setup guide.
- This is great if you don't feel comfortable with networking.
- If your Pi is powerful enough to handle everything, you won't need a second computer to use the robot.
Software setup on a Raspberry Pi¶
This section holds instructions to install all software components to a Raspberry Pi, working from a Linux computer.
Instructions for regular PCs running other operating systems in the Software setup on a PC section below.
Requirements:
- Raspberry Pi running an OS and connected to the internet.
- Access to the Pi's terminal.
Note
This guide is only recommended for advanced Linux users.
Update system packages¶
Run these commands to update the Pi's software:
sudo apt update
sudo apt upgrade # This can take a while...
sudo apt install git -y
Note
The update command can fail with an error similar to the following:
The following signatures were invalid: EXPKEYSIG 656408E390CFB1F5 MongoDB 4.4 Release Signing Key <packaging@mongodb.com>
This is due expired GPG keys from Mongo. The issue can be solved by re-importing the key, as shown below.
Install Klipper¶
Here we will install only the "software" side of Klipper. The Firmware will be installed in another guide (the electronics setup guide) later on.
Note
Instructions adapted from here.
Install KIAUH:
cd ~ && git clone https://github.com/dw-0/kiauh.git
We’ll need our Klipper fork to be able to use an endstop for the extruder’s axis, and to synchronize the tool-changer stepper motor,
To set this up, use the following command to copy klipper_repos.txt.example
to klipper_repos.txt
:
cp kiauh/klipper_repos.txt.example kiauh/klipper_repos.txt
Edit the kiauh/klipper_repos.txt
file to append naikymen/klipper-for-cnc,pipetting
after the last line. For this, you can use the echo
command:
echo "naikymen/klipper-for-cnc,pipetting" >> kiauh/klipper_repos.txt
Finally, to start KIAUH, use the command:
./kiauh/kiauh.sh
When KIAUH is running, you should see something like this:
Use the following options to select our Klipper fork for installation:
- Choose option "
6- [Settings]
". - Choose option "
1- Set custom Klipper repository
". - Choose the option corresponding to "
naikymen/klipper-for-cnc -> pipetting
"
Now you'll use KIAUH's interface to install Klipper, Moonraker, and Mainsail.
Info
If any warning window appears, select OK.
-
Go to the main menu, and select option "
1- [Install]
". Once on the general installation menu, use the available options to install Klipper, Moonraker, and Mainsail.- Press
2
to select Klipper. - Press
1
to select the recommended python version. - Press
1
to select the number of Klipper instances (just one).
- Press
-
Install Mainsail.
- Press
b
to go back to the main menu of KIAUH. - Press
1
to Install. - Press
3
to select Mainsail. - Press
y
to accept installing Mainsail.
- Press
-
Install Moonraker.
- Press
b
to go back to the main menu of KIAUH. - Press
1
to install . - Press
4
to select Moonraker.
- Press
Info
Klipper is "a 3D-printer firmware", but it is actually several programs.
These programs are:
- Klipper: the actual firmware, which runs on micro-controllers only.
- Klippy: the "host firmware", which runs on a PC, and is responsible for motion planning.
- Moonraker: a websocket-based "API" for Klippy. It connects to Klippy and manages the PC's operating system.
- Mainsail (or Fluidd, etc.): front-end user interfaces, used from a web browser.
How to avoid Klipper
At the moment the controller (piper) only streams commands to Moonraker, and thus only works with Klipper.
It would require some coding effort to support, for example, the RepRap firmware (RRF) on the Duet, or Marlin firmware on other boards, with their native firmware. Originally this project worked with GRBL, which was replaced because it could only drive 3 axes (and we needed at least 5).
The changes mostly involve creating a new controller class in piper
, mimicking KlipperCommander
in all ways, and replacing KlipperCommander
with it in the Controller
class.
Here are the main files:
Install MongoDB¶
Install MongoDB version 4.4.15
in the Raspberry Pi. This requires a 64-bit Raspberry Pi (e.g. 3 or greater).
Adapted from here
- Install the MongoDB 4.4 GPG key.
Note: Warnings may appear around apt-key
, but if an error occurs try this alternative instead: https://itsfoss.com/apt-key-deprecated/
wget -qO - https://www.mongodb.org/static/pgp/server-4.4.asc | sudo apt-key add -
- Add the source location for the MongoDB packages.
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/4.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.4.list
- Download the package details for the MongoDB packages.
sudo apt update
- Install the correct version (4.4.15).
sudo apt install -y mongodb-org=4.4.15 mongodb-org-server=4.4.15 mongodb-org-shell=4.4.15 mongodb-org-mongos=4.4.15 mongodb-org-tools=4.4.15
Tip
If you have installed a more recent version of Mongo, it may not work. To downgrade, add the --allow-downgrades
flag to the command above.
A more recent version of MongoDB may be installed inadvertedly when running apt upgrade
, to update system packages.
- Check the installed version.
mongod --version # Should print 4.4.15
Tip
If you get an error saying Illegal instruction (core dumped)
, then your MongoDB version is incompatible with your OS.
Make sure that the version you installed is at most 4.4.15
, and downgrade if needed (i.e. add --allow-downgrades
to the command above and run it again).
- Start and enable the MongoDB service at boot.
sudo systemctl daemon-reload
sudo systemctl start mongod.service
sudo systemctl enable mongod.service
sudo systemctl status mongod.service
Note
Without further configuration, MongoDB accepts connections from the same host only (e.g. localhost
and 127.0.0.1
addreses), and uses port 27017
by default.
If you need to change this, you can edit Mongo's configuration file (e.g. at /etc/mongodb.conf
, though your mileage may vary), and tweak the network settings.
Install node and npm¶
- Install Node.
sudo apt install npm
Info
This may result, for example, in the installation of node
and nodejs
version v18.19.0, and npm
version 9.2.0.
These are quite old and won't work as intended. The main incompatibility comes from the libraries needed to connect with mongo 4.15
.
You can check the installed version by running node --version
and npm --version
.
- Install LTS NodeJS with the
n
tool.
sudo npm install -g n # Install the "n" tool globally.
sudo n lts # Install and default to LTS node globally.
- You now need to log out, and then log in again. Then
node --version
andnpm --version
to check that the updated versions have been installed.
Info
After logging in again the version numbers printed by those commands should be higher. For example, node
v20.11.1 with npm
10.2.4.
Install Pipettin¶
The main repository tracks all the required repositories of pipettin as git "submodules", and uses git LFS for tracking CAD files, models, and other large files. You may need to install git lfs on your system to use them.
Tip
Our repos are public, and submodules use HTTP/S connections. However, if you will be using encrypted SSH keys to push, we recommend setting up the ssh agent.
You can download all modules using git
:
# Change to the home directory.
cd
# Download the repo and its submodules. Note that this leaves submodules in a detached state.
git clone --recurse-submodules https://gitlab.com/pipettin-bot/pipettin-bot.git
Writer UI¶
- Enter the GUI's GitLab repository (or clone it).
# Switch to the GUI's submodule in the main repo.
cd ~/pipettin-bot/code/pipettin-gui
# To clone it separately run:
# cd && git clone https://gitlab.com/pipettin-bot/pipettin-gui.git
# cd pipettin-gui
- Install the app's package dependencies using
npm
.
# This will take a while...
npm install
- Edit the
config.json
file, replacing the IP address inHOST
(e.g.127.0.0.1
) with the current local network IP of the Raspberr Pi (otherwise the website may not be accessible). You can use thenano
text editor to make these changes.
Tip
Use the following command to show the Pi's current IP address. At least one the printed addresses will be useful to connect to the GUI from another machine.
ip -4 addr | grep -oP '(?<=inet\s)\d+(\.\d+){3}'
# You can edit the file with the "nano" editor.
# Press Ctrl+X to exit the editor, and "Y" + "Enter" to save changes.
nano config.json
Example
The config.json
file may show the following content initially:
{
"PORT": 3333,
"HOST": "127.0.0.1"
}
Adjust the HOST
parameter. You can leave the PORT
as it is, or change it to your favourite number.
-
Write down the IP address from the previous step. You will need it to configure the robot's controller later on.
-
If you have an external MongoDB instance, or have changed its default address above, you will need to edit the
.env
file as well.
Example
The .env
file may show the following content initially:
DATABASE_NAME=pipettin
DATABASE_URI=127.0.0.1:27017
Adjust the DATABASE_URI
parameter only if needed. You can leave the DATABASE_NAME
as it is, or change it to your favourite DB name.
# You can edit the file with the "nano" editor.
# Press Ctrl+X to exit the editor, and "Y" + "Enter" to save changes.
nano .env
- Launch the GUI's development version.
npm run dev
Info
A pre-built version is updated every stable release, and is faster. It can be launched by running npm start
instead. This is what the systemd
unit uses to launch the app.
- Visit
http://<<yourpisip>>:3000
on your web browser to open the app.
Info
If you want to run the UI on a different port, edit the client/vite.config.js
file. Replace the value in the port
key to the value you want the UI to use. Port 80
will conflict with Mainsail's UI unless reconfigured, and requires elevated privileges to be used.
// ...
server: {
host: true,
port: 3000, // <-- Change only this number.
},
// ...
Tip
You might also try connecting through an mDNS/Zeroconf address, such as http://raspberrypi.local:3000
or http://pipettin.local:3000
using your browser. It looks nicer and is simpler to remember, but it may not work on your particular LAN or PC without extra configuration (not covered here).
For this to work, the HOST
address in the config.json
file might need to be updated.
- Go back to the terminal, and press
Ctrl+C
to stop the server.
Piper controller¶
Run the commands below to install piper and its dependencies.
Python version 3.9 (or greater) is required. Check which version you are running with python --version
, and update if needed.
You may need to install the venv
module first:
# Install "python venv" if not already (python3.11-venv on Debian Bookworm).
sudo apt install python3-venv
Create and activate an environment:
# Create and activate the virtual environment on the home directory.
cd
python -m venv venv-piper
source ~/venv-piper/bin/activate
Note
The systemd unit for piper will need piper to be installed in a virtual environment at ~/venv-piper
.
Switch to the controllers's directory:
# Switch to the piper submodule in the main repo.
cd ~/pipettin-bot/code/piper
Edit the config.yml
file, and change any values you need to update (e.g. database name, socket address, etc.).
Important
By default, the configuration file will make the controller operate in "dry mode". this means that the robot will not be commanded to move, and is meant as a debugging feature.
Make sure that dry
is set to False
in the configuration file if you want the robot to move.
# You can edit the file with the "nano" editor (press Ctrl+X to exit the editor).
nano config.yml
Install all pipettin modules and dependencies in the virtual environment:
# Installs the package in editable mode, and its dependencies. It will take a while.
pip install -e .
Test that it starts correctly:
# Note that this will not connect to Klipper/Moonraker or the UI.
# It only tests that piper loads correctly.
python3 -m piper dry verbose ws_address='' sio_address=''
Ctrl+C
when you're comfortable.
Quick and dirty
You can also install Piper into a virtual environment directly from the git repo.
The catch is that you'll need to download an modify the config.yml
file separately. You will also need to edit and reload the controller's systemd unit file, such that it uses the python executable from the virtual environment (e.g. to ~/piper_from_pip/bin/python
) and to the configuration file you downloaded.
cd
python3 -m venv venv-piper
source ~/venv-piper/bin/activate
wget https://gitlab.com/pipettin-bot/pipettin-piper/-/raw/master/piper/config/config.yml
nano config.yml # Edit the config. Press Ctrl+X to close the editor.
pip install git+https://gitlab.com/pipettin-bot/pipettin-piper.git
# Test that it starts:
python3 -m piper config_file='config.yml' ws_address='' sio_address=''
Systemd units¶
"Systemd units" are small configuration files that tell the system to handle the startup of the GUI's Node.js server, of the Python driver module, and other services at boot.
Most of the units should be already installed and enabled at boot (i.e. Mongo, Klipper, Moonraker and Mainsail). You now need to install and enable units for the controller (piper) and the GUI (pipettin writer).
Tip
We will setup units as system units. If instead you want to manage them as system units, first enable systemd lingering, at least once as the pi
user:
sudo loginctl enable-linger pi
Then, in the commands above, omit using sudo
, use sytemctl --user
and journalctl --user-unit
instead, and install units to ~/.config/systemd/user/
.
Note
You may need to edit the piper.service
and nodegui.service
files, to adjust the paths where the controller and nodegui are installed.
The systemd files and commands below are meant to work with the setup as detailed in this guide. They can be easily adapted to other setups with minor edits.
You can now install the units:
# Link service files.
ln -s /home/pi/pipettin-bot/code/systemd.units/piper.service /etc/systemd/system
ln -s /home/pi/pipettin-bot/code/systemd.units/nodegui.service /etc/systemd/system
# For the mini OLED display enable these.
ln -s /home/pi/pipettin-bot/code/systemd.units/mini_display.service /etc/systemd/system
ln -s /home/pi/pipettin-bot/code/systemd.units/mini_display_prepare.service /etc/systemd/system
# Copy all.
# ln -s /home/pi/pipettin-bot/systemd.units/*.service /etc/systemd/system
# Check that the units are detected and are not in a "bad" state.
# sudo systemctl list-unit-files
You should observe something similar to this:
Now reload the units, such that systemd finds the changes:
# Reload the units.
sudo systemctl daemon-reload
Start and enable the GUI's unit:
# Note that you need a proper npm package installation for Writer to work.
sudo systemctl enable nodegui.service
sudo systemctl start nodegui.service
sudo systemctl status nodegui.service
Start and enable the controllers's unit:
# Note that you need a proper virtual environment setup for Piper to work.
sudo systemctl enable piper.service
sudo systemctl start piper.service
sudo systemctl status piper.service
Tip
Handy bash aliases to restart the units can be added to ~/.bashrc
by appending the following to it:
# Restart units and follow logs.
alias gui_restart='sudo systemctl restart nodegui.service; sudo journalctl nodegui -f'
alias piper_restart='sudo systemctl restart piper.service; sudo journalctl piper -f'
# To follow piper's logs.
tail -f /tmp/piper.log
Updates¶
To update to the latest versions of the submodules, run the following commands.
Tip
If you installed "Pipetting OS" you can (and should) update most modules through Mainsail instead.
This will also properly install the updated modules, which the commands below don't do.
# Enter the repo's directory.
cd ~/pipettin-bot
# Optionally, configure git to auto-update submodules on every git pull.
git config submodule.recurse true
# Pull the latest commit of the main repo and submodules.
git pull
Note
These commands will have no effect if you just ran the commands above.
Warning
Any changes to the configuration files may cause version control conflicts, and prevent you from updating through git pull
.
In this case, you can try backing up the files, then use git restore someconfig.yml
to checkout the original versions, then git pull
, and manually migrate the modified values from your backup.
To update the submodules beyond the commited versions of the submodules, run the following.
Warning
The latest versions may contain untested features, or be incompatible with your current setup. Excercise caution.
# Fetch latest submodules (optionally).
git submodule foreach --recursive git checkout -
git submodule foreach --recursive git pull
Finally, reload the systemd user units, as the may have changed, and restart everything:
# Reload the user's units.
sudo systemctl daemon-reload
# Restart components.
sudo systemctl restart nodegui.service
sudo systemctl restart piper.service
# ...or just reboot.
Configuration¶
While the defaults should work out of the box, it is worth clarifying which configuration values must match.
- Server address: The URL and PORT of the Pipettin Writer backend and frontend must match, as explained here. No action is needed on your part under normal circumstances.
- The database IP address and PORT used by the UI must match the ones from your MongoDB instance. The defaults used in this guide already match each other.
- Database name: The backend uses a default database named
pipettin
. The controller must use this database as well. The defaults will match each other. This can be changed by updating thedatabase_name
option (example below) in the controller'sconfig.yml
file.
Tip
You can set piper's config parameters by editing piper-yml
using Mainsail's config editor.
Example
In this example the initial value of database_name
in the config.yml
file was commented out, and another one added below to replace it.
database:
mongo_url: 'mongodb://localhost:27017/'
#database_name: 'pipettin'
database_name: '2024-03-19-test'
The database name must match the initial value in the .env
file. Look for the examples shown above.
Extras¶
A few extra applications can be installed on the RPi, and be really useful.
For example:
- Controlling the machine through Jupyter Lab: https://jupyter.org/ (served at port
8000
) - A web frontend for system management: Cockpit (server at port
9090
) - Locally serving this documentation, and/or the BOM.
Setup instructions can be found over here.
Final checks¶
TO DO
- MCU connection.
- compatibility of node/mongo versions.
- Starting the GUI.
Software setup on a PC¶
You can run Pipettin on the three major operating systems.
Info
There are no system images for this setup.
Choose your poison:
- Linux: rather simpler instructions for Arch Linux and Ubuntu.
- Windows: achievable but rather complicated, specially the Klipper parts.
- Mac OS: should be possible, good luck!
Guides:
- To learn how to install the project's software on a Desktop PC (which replaces the Raspberry Pi entirely) visit here.
- The development guide might also be useful.
Next steps¶
Congrats! You've setup the software for your robot. That was tough!
You may continue with the Electronics Setup Guide, to install and configure the CNC firmware.