Skip to content

Latest commit

 

History

History
213 lines (168 loc) · 9.52 KB

README.md

File metadata and controls

213 lines (168 loc) · 9.52 KB

If you're looking for a standard operating procedure, check out the quickstart.

Intro

This project wraps a python interface around the existing Duet 3 Socket Interface, turning Jubilee into a plate handling lab automation device for sonication.

Connecting to Jubilee

There are two ways to connect to Jubilee and execute code: (1) locally and (2) with a separate PC over a network connection.

They look like this:

Local Connection

In this mode, the Python protocol runs on the Raspberry Pi attached to the machine. It is recommended for production use.

Closed Network Connection

In this mode, the Python protocol runs on a separate pc with this software package installed. It is useful for testing but not recommended for production.

When running the machine in this mode, note that turning off your PC or losing the network connection will halt the machine mid-execution. Furthermore, a laggy network connection will cause the machine to lag. To avoid these issues in production, we recommended that running the protocol locally (on the Raspberry Pi) instead of using an arbitrary PC on the same network.

Installation

If you are running this code locally, clone this repository onto Jubilee's attached Raspberry Pi. If you are running it over a network connection, clone it onto your PC.

Then, from within this directory (the one with this README in it), install the project via pip with ....

pip3 install -e .

Now you can spin up a connection to Jubilee by importing the driver.

Conventions

Looking top-down at the plate, plates are indexed as follows:

Starting Machine State

When Jubilee is first powered up, it will need to first home all axes. You must issue this command yourself. To home, the deck must be clear of all labware. After homing, you may populate the deck and execute protocols can be run. You only need to home once when Jubilee is first turned on, or once after any situation where the machine has lost it's position (from an event like a crash).

Machine Pre-Protocol Setup

Once the machine is homed, you can then load labware into the machine. You will need to configure the machine with the labware you add. This can be done interactively in prompt mode with the setup_plate command. After configuring, the deck configuration can be saved to a file. If the same labware is used for a different protocol, you can reuse this file instead of reconfiguring the deck.

Ending Machine State

All tools must be put away before Jubilee is powered off. This is the default behavior if you run the code inside a with statement. In any situation where the Jubilee was powered off in an emergency, you must remove any active tools on Jubilee's carriage before powering it back on.

API

There are 3 ways of interacting with the machine: (1) directly through a python script, (2) interactively through a command prompt, and (3) procedurally with predefined protocol.

Python Script Mode

After installing this package with pip, you should be able to simply import it in python:

If you are running the code locally, the code will look like this:

from sonication_station.sonication_station import SonicationStation
with SonicationStation() as jubilee:
    jubilee.sonicate_well(0, 'A', 0, 3, 10, False)

If you are running the code over a network from a separate PC, the code may look like this:

from sonication_station.sonication_station import SonicationStation
with SonicationStation(address="192.168.1.2") as jubilee:
    jubilee.sonicate_well(0, 'A', 0, 3, 10, False)

Here the above address argument is the ip address of Jubilee as it appears on your network.

Prompt (Maintenance) Mode

You can interactively control Jubilee through a custom prompt. To interact with the prompt, spin it up from the python shell with:

from sonication_station.sonication_station import SonicationStation
with SonicationStation() as jubilee:
    jubilee.cmdloop()

or, from the command line:

sudo path/to/sonication_station/sonication_station.py

This will drop you into an interactive prompt that looks like this:


  ____              _           _   _               ____  _        _   _             
 / ___|  ___  _ __ (_) ___ __ _| |_(_) ___  _ __   / ___|| |_ __ _| |_(_) ___  _ __  
 \___ \ / _ \| '_ \| |/ __/ _` | __| |/ _ \| '_ \  \___ \| __/ _` | __| |/ _ \| '_ \ 
  ___) | (_) | | | | | (_| (_| | |_| | (_) | | | |  ___) | || (_| | |_| | (_) | | | |
 |____/ \___/|_| |_|_|\___\__,_|\__|_|\___/|_| |_| |____/ \__\__,_|\__|_|\___/|_| |_|
                                                                                     

>>> 

This mode lets you input commands one at a time.

In this mode you can:

  • home the machine
  • execute movement commands
  • execute sonication commands
  • pickup and park tools
  • interactively set the location/type of a new well plate
  • control the machine with the keyboard arrow keys setup the machine and execute commands serially. This interface is useful for adding to the plate inventory.

To see the list of supported commands, press TAB twice. This mode also supports TAB completion, that is, if you start typing a command and press TAB twice, the prompt will either attempt to auto-complete any possibilities or show you a list of possible completions. To get help on any command, simply type:

>>> help command_name_here

Protocol Mode

This method is for invoking predefined protocol. Protocol mode may be useful for generating a series of plate operations programmatically from another program and then simply executing them on the Sonication Station. Protocols consist of a series of sonication commands executed sequentially.

Running the machine in protocol mode is simply a matter of telling the machine to read a predefined protocol file.

# Assume that Jubilee is both homed and populated with the correct labware for this protocol.
from sonication_station.sonication_station import SonicationStation
with SonicationStation() as jubilee:
    jubilee.execute_protocol_from_file("/path/to/protocol_file.json")

Protocol API

Under the hood, a protocol file is a json file. A sample protocol looks like this:

{
   "protocol": [
       {
           "operation": "sonicate_well",
           "specs": {
               "deck_index": 5,
               "row_letter": "A",
               "column_index": 1,
               "plunge_depth": 10.0,
               "seconds": 3.0,
               "autoclean": false
           }
       },
       {
           "operation": "sonicate_well",
           "specs": {
               "deck_index": 5,
               "row_letter": "A",
               "column_index": 2,
               "plunge_depth": 10.0,
               "seconds": 3.0,
               "autoclean": false
           }
       }
   ]
}

Here, the protocol contains one important field protocol, which is a list of operations that will be executed sequentially. So far, only one operation sonicate_well, is implemented. the options are as follows:

  • deck_index: the deck index of the plate
  • row_letter: the row index on the plate, indicated by letter
  • column_index: the column indicated by integer
  • plunge_depth: the depth to plunge the sonicator into the glassware as measured from the top of the glassware
  • seconds: time in seconds to run the sonicator
  • autoclean: (boolean), whether or not to run a predefined cleaning protocol.

Note that if autoclean is set to true, a cleaning protocol must be defined in the machine configuration. Cleanin protocols can also be defined in prompt mode.

Deck Configuration

Before running a protocol, Jubilee's deck must be configured with the labware that the protocol needs. Specifically, Jubilee needs to know:

  • for each piece of labware
    • the well count (12 [scintillation vile holder], 48, 96, etc)
    • the XY location of the labware
    • the deck slot number
    • the height of the labware
  • a minimum height at which all tools can safely travel over all labware currently loaded on the deck (the safe_z height).

This configuration must be done in prompt mode.

Safe Z Height

The safe_z height is the height at which the tip of any tool can safely clear the tallest labware without crashing into it. It is defined in mm as the distance of the active tool tip and the deck plate surface.

If the machine is homed, you can measure the current tool tip height by issuing the position command.

>>> position
[150.0, 150.0, 65.0]
>>> 

Here the XYZ coordinates are 150, 150, 65mm respectively.

You set the safe_z height in prompt mode like so:

>>> safe_z z=65

You can read back the safe_z by simply entering safe_z without arguments

>>> safe_z
65
>>>

Plate Setup

You can add a piece of labware into Jubilee's configuration by running the setup_plate command. This will drop you into an interactive session where the machine will walk you through the setup.

When the machine is configured, you can save your configuration to a file with save_deck_configuration. That way, you can run the same protocol again without having to redo this (somewhat tedious) setup.

Acknowledgements

This work was partially supported by the University of Washington (UW) Molecular Engineering Materials Center (MEM-C)