Skip to content

jonasoh/spiro

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SPIRO logo

SPIRO is an imaging platform designed for making highly reproducible, high temporal resolution timelapse sequences of biological samples grown on Petri dishes: plant seedlings, fungal mycelium, bacterial colonies, etc. SPIRO supports imaging of up to four plates at the same time. It is designed to be suitable for the two most poular Petri dish formats: round 9 cm plates and square 12 cm plates.

SPIRO is described in depth in Ohlsson et al. (2024).

The image below is a link to a YouTube video showing some of its design and features.

SPIRO intro

Table of Contents

Hardware

SPIRO is based around Raspberry Pi 3 B+, using 3D printed parts to hold everything together. It works with both the official camera module as well as with third-party cameras. N.B.! SPIRO doesn't currently support the Raspberry Pi camera module v3. We use the Arducam Auto Focus camera module, which allows focusing the images via the built-in live view web server.

It is also possible to use a Raspberry Pi 4B as the base of the system. Most likely, SPIRO can also be built around other Raspberry Pi models, although these have not been tested and modifications to the Borg's nest housing may be needed to accomodate such solutions.

The system basically consists of a camera, a green LED illuminator for imaging in the dark, and a motor-controlled imaging stage, as shown below.

SPIRO close-up

It is relatively cheap and easy to assemble multiple systems for running larger experiments.

Multiple SPIROs

Example images

Here are a couple of examples showcasing the image quality of day and night images. Click for full resolution.

Example day image

Example night image

3D printer models

Models for the 3D printed hardware components can be found at AlyonaMinina/SPIRO.Hardware.

Automated data analysis

Image data acquired using SPIRO is highly reproducible, and well suited for automated image analysis. We have so far developed pipelines for automated assessment of germination and root growth rates, which can be found at jiaxuanleong/SPIRO.Assays.

The video below demonstrates some of SPIRO's data acquisition and processing capabilities.

SPIRO.data.processing.mp4

Installation

First, prepare the SD card with a fresh release of Raspberry Pi OS Lite (Legacy) (follow the official instructions). NB! Due to a change in the camera stack, only "Legacy" Raspberry Pi OS versions are supported for now.

Note: If using the ArduCam drop-in replacement camera module, you need to add the following line to the file config.txt on the newly prepared SD card:

dtparam=i2c_vc=on

For convenience, you may also add the following line to config.txt in the SD card, which makes it possible to connect an external HDMI monoitor after boot. This can be useful for debugging the system:

hdmi_force_hotplug=1

Connect the Raspberry Pi to a screen and keyboard and start it up. Log in using the default credentials (username pi, password raspberry). Start the system configuration:

sudo raspi-config

In the raspi-config interface, make the following changes:

  • Change the password. The system will allow network access, and a weak password will compromise your network security and your experimental data.
  • After changing the password, connect the network cable (if you are using wired networking).
  • Under Interfacing, enable Camera, I2C, and SSH.
  • In Performance Options, set GPU Memory to 256.
  • Under Localisation Options, make sure to set the Timezone. Please note that a working network connection is required to maintain the correct date.
  • If needed, configure Network and Localization options here as well. Set a Hostname under Network if you plan on running several SPIROs.
  • Finally, select Finish, and choose to reboot the system when asked.
  • After reboot, the system shows a message on the screen showing its IP address ("My IP address is: a.b.c.d"). Make a note of this address as you will need it to access the system over the network. Make sure that your network allows access to ports 8080 on this IP address. (Alternatively, see Enabling the Wi-Fi hotspot)

Next, ensure the system is connected to the internet. Update the operating system and install the required tools:

sudo apt update
sudo apt upgrade -y
sudo apt install -y git zip i2c-tools libatlas-base-dev python3-pip python3-pil dnsmasq hostapd

Then, install the SPIRO software and its dependencies:

sudo pip3 install git+https://github.com/jonasoh/spiro#egg=spiro

If you are using the newer non-rotated camera house, disable camera rotation (this can also be done in the System settings pane in the Web UI):

spiro --disable-rotation

Finally, instruct the system to automatically run the SPIRO control software on boot:

spiro --install
systemctl enable --user spiro
sudo loginctl enable-linger `whoami`
systemctl --user start spiro

If you want to use the Wi-Fi hotspot, see the next section. Otherwise, you may now place the system in the setting in which you will be using it for your experiments.

Enabling the Wi-Fi hotspot

For situations where the web UI cannot be used via the network, e.g. if using the system is used where a network connection is not available or where firewall policies block access to the web UI or SSH, SPIRO can be configured to act as a Wi-Fi hotspot. In this mode, a Wi-Fi network with the name spiro-XXXXXX is provided, which provides access only to SPIRO.

Wi-Fi hotspot mode can be conveniently enabled in the System settings page in the web UI. To enable the hotspot when the web UI is not accessible (such as if the system is connected to a screen and keyboard during installation), run the following command from the terminal or via SSH:

sudo spiro --enable-hotspot

After installing and configuring the required services, the details for connecting to the hotspot are given:

Access point configured and enabled. Below are the details for connecting to it:

SSID:     spiro-abcdef
Password: 517824ee

Connect to the web interface using the address http://spiro.local:8080

To reach the web UI or SSH when connected to the hotspot, use the convenience address spiro.local and the normal ports (22 for SSH, 8080 for web UI). Please note that the hotspot only allows access to the SPIRO system, and otherwise provides no internet connectivity.

After enabling the hotspot, the hotspot can be enabled or disabled from the System Settings page in the web UI, where the connection details are also displayed.

Each SPIRO will use a unique SSID, allowing the use of multiple hotspot-enabled SPIROs in one location. If you operate several SPIROs in one location, you can create more user-friendly names for the different Wi-Fi networks by using this command:

sudo nano /etc/hostapd/hostapd.conf

Modify the content of the ssid= line to whatever you find more appropriate. You may also change the password by editing the wpa_passphrase= line.

Usage

Working with SPIRO

Initiating experiments and controlling imaging parameters is performed using a web-based UI which can be controlled using any web browser. The screenshot shows the main view of an idle system:

Web UI overview

The live view allows correcting the focus of the lens as well as placement of Petri plates and distance of the illuminator for optimal image quality. The UI also allows for calibration of the motor and setting up day and night imaging parameters (shutter speed and ISO) separately.

Experiment control

In the experiment control view, parameters such as the duration of the experiment and frequency of imaging are configured. The system dynamically estimates the required size of the images, given the configured parameters.

Running experiment

During a running experiment, most functions of the web UI are disabled. Browsing to the UI instead displays the status of the running experiment, and provides details on time remaining and the current image quality.

File manager

The file manager allows easy downloading of experimental data from within the web UI.

System settings

The system settings pane provides access to some common settings.

System administration

For administration of SPIRO (e.g., for updating the software and diagnosing problems), an SSH client is very useful. Below are a few choices:

Windows

  • MobaXterm is a popular SSH client that also supports file transfer. Recommended for beginners.
  • PuTTY is a lightweight and popular SSH client.

Mac/Linux

  • On Mac and Linux, an SSH client is built into the system. Using the Terminal, connect to SPIRO using the command ssh pi@1.2.3.4 (where 1.2.3.4 is the IP address of your system).

Connecting to the web interface

SPIRO is controlled via its web interface. To access the system, point your web browser to the address http://a.b.c.d:8080/, where a.b.c.d is the IP address you noted previously (the server always runs on port 8080). At the first access, you are asked to set a password for the system. Do not use the same password as you set previously! This password is for the web interface and should be regarded as a low-privilege password.

Setting up imaging

After logging in to the system, you are presented with the Live view. Here, you can adjust the image in real time, allowing you to make sure that the camera is at a proper distance from the plate, that the focus is set correctly, and that the LED illuminator is working and placed in a position where reflections are not an issue.

Under Day image settings and Night image settings, you can adjust the exposure time for day and night images in real time. For night images, make sure that representative conditions are used (i.e., turn off the lights in the growth chamber). When the image is captured according to your liking, choose Update and save.

For locating the initial imaging position, the system turns the cube until a positional switch is activated. It then turns the cube a predefined amount of steps (calibration value). The check that the calibration value is correct, go to the Start position calibration view. Here, you may try out the current value, as well as change it. Make sure to click Save value if you change it.

Starting an experiment

When imaging parameters are set up to your liking, you are ready to start your experiments. In the Experiment control view, choose a name for your experiment, as well as the duration and imaging frequency. After you choose Start experiment, the system will disable most of the functionality of the web interface, displaying a simple status window containing experiment parameters, as well as the last image captured.

Downloading images

Images can be downloaded from the web interface under File manager. The File manager also allows deleting files to free up space on the SD card.

Image data can also be downloaded using an SSH/SFTP client, such as MobaXterm. This allows easy inspection of single images.

Maintaining the system

Restarting the software

If for some reason the software ends up in an unusable state, you can often restart it from the web UI (System settings -> Restart web UI). The web UI can also be restarted via SSH, by issuing the following command:

systemctl --user restart spiro

It has happened that the camera has become unresponsive, due to bugs in the underlying library. In this case, rebooting the system is the only way of getting it back into a usable state. This can be done via the web UI (System settings -> Reboot system), or by issuing the following command via SSH:

sudo shutdown -r now

Shutting down the system

If you want to power down the system, always perform a clean shutdown to ensure that no damage is caused to the filsesystem. This can either be done via the web UI (System settings -> Power off system), or by issuing the following command over SSH:

sudo shutdown -h now

After a few seconds, when only the red LED on the Raspberry Pi is lit, you may pull the power.

Keeping software up to date

You should regularly update the underlying operating system to make sure that it has the latest security patches. To do so, log in using your SSH client (or connect a screen and keyboard), and issue the following commands, answering Y to any queries:

sudo apt update
sudo apt upgrade

When updating the SPIRO control software, first check the UPDATING.md file for notable changes. Normally, to update the software, issue the commands:

sudo pip3 install -U git+https://github.com/jonasoh/spiro#egg=spiro

After updating the SPIRO software, either use the web UI (System settings -> Restart web UI), or issue the following command in an SSH prompt:

systemctl --user restart spiro

Troubleshooting

Viewing the software log

To view the last 50 entries in the SPIRO log:

journalctl --user-unit=spiro -n 50

Or, to view the entire log:

journalctl --user-unit=spiro

Testing the LED and motor

To check whether the Raspberry Pi can control the LED illuminator, first set the LED control pin to output mode:

echo 17 > /sys/class/gpio/export
echo "out" > /sys/class/gpio/gpio17/direction

You may then toggle it on or off using the commands

echo 1 > /sys/class/gpio/gpio17/value  # Turn LED on
echo 0 > /sys/class/gpio/gpio17/value  # Turn LED off

If it doesn't respond to this command, this may indicate either miswiring, or that either the LED strip or the MOSFET is non-functional.

Similarly, you can turn on and off the motor, by substituting the value 23 for 17 in the above examples. When GPIO pin 23 is toggled on, the cube should be locked in position. If it is not, check that your wiring looks good, that the power supply is connected, and that the shaft coupler is firmly attached to both the cube and the motor.

If the motor is moving jerkily during normal operation, there is likely a problem with the wiring of the coil pins (Ain1&2 and Bin1&2).

Licensing

The code for SPIRO is licensed under a 2-clause BSD license, allowing redistribution and modification of the source code as long as the original license and copyright notice are retained. SPIRO includes the fonts Aldrich and Saira Condensed, and the CSS library Pure.css. The licenses for these resources can be found under the doc/licenses directory.