MagpiEM is a program for automating much of the cleaning process during sub-tomo averaging of proteins in regular lattices, such as membrane proteins or viral coats.
See the poster here.
The software is not suitable for proteins which do not form any kind of regular lattice, such as individual ribosomes in solution. Please note that the software is still very actively in development, and you may run into errors. Please report any issues here or by email.
MagpiEM is currently designed to be run locally on your desktop, rather than on a high-performance computation cluster.
Open a python terminal (e.g. anaconda), with python 3.10 or above, and run
pip install MagpiEM
This should install the software and all dependencies.
Note: to update the package in future, run
pip install MagpiEM --upgrade
MagpiEM is currently started in the terminal and will open a dash-based GUI in your default browser. After you’re finished, make sure to stop the script in the terminal (e.g. with Ctrl-C or by closing the terminal), do not just close the browser tab as the software may continue running and holding memory.
To start the software, type
magpiem
in your python terminal. This will open the GUI in your default browser.
Upload the file containing your particle data.
You may choose to read a small number of tomograms initially, to test the software on a small dataset and find good parameters.
Once you’re happy, choose "read tomograms". The software will read all tomograms within the file.
The parameters used for cleaning will vary based on the system. MagpiEM can calculate these parameters directly, for ease of use. Locate a good lattice within the uncleaned tomogram which appears in white. Click two adjacent particles, and the parameters between those will be printed above the diagram.
If your lattice has a large variance in curvatures, you may wish to repeat this for multiple particles, in order to get an idea of the overall range for the whole lattice. These parameters can then be entered into the cleaning form, using the tolerance option to account for variability. Typically, tolerances can be relatively large without much issue(10-20 in each case), but make sure to check on a small number of images first.
Parameter | Description |
---|---|
Distance | Distance in pixels between adjacent particles in lattice |
Orientation | Angle between adjacent particles in lattice (specifically, the z-components of their rotation matrices) |
Curvature | Triangulated curvature based on the angle between a particle's orientation and the surface of the lattice |
Min. Neighbours | Minimum number of adjacent particles in lattice for a particle to be considered valid. Suggested to keep at 2-3 |
CC Threshold | Minimum CC threshold for particles to be considered, as calculated during template matching within RELION/emClarity. NOTE: currently unreliable with RELION files. |
Min. Lattice Size | After formation of lattices, any containing less than this many particles will be discarded. |
Allow Flipped Particles | If enabled, particles with alternating, opposite orientations will be allowed, and count as correct |
After cleaning has been run, inspect the tomograms given. The option "Show removed particles" can be helpful to ensure no good particles have been removed.
Once you’re satisfied with the automated step, the last step is to remove any unwanted lattices if necessary. Typically these will be lattices with opposite orientations, which obey the lattice geometry but were picked erroneously during template matching.
Selecting "Cone plot" can be useful here, but due to some very unfortunate quirks of the graphing software, this can sometimes generate comically large cones (see "cone_fix_readme.txt" for more information). Simply clicking "Set" next to "Overall Cone Size" will fix this problem. I hope to one day find a more pleasing solution.
The final step is to select which lattices are correct in the results given. Chosen lattices are highlighted in white. There are two ways to do this, depending on how many correct lattices are present in each image:
- If only a small number of correct lattices are present in each image (for example, if the image has been divided into sub-regions for template matching), it is more convenient to select each correct lattice. In this case, ensure the toggle under "Save Result" is set to "Keep selected particles"
- If a large number of correct lattices are present (for example, a picking result of an entire undivided image at once), it may be impractical to select each correct lattice. Instead, select each incorrect lattice, and then change the setting under "Save Result" to "Keep unselected particles". This will save all lattices EXCEPT the ones chosen.
Buttons are available to select all concave or convex lattices i.e. lattices with curvature greater than or less than 90°. This can sometimes prove useful.
Clicking "Save Particles" will create a file identical to the uploaded file (.mat or .star), with the unwanted particles removed. This can go directly back into emClarity/RELION without any conversion.
If your dataset contains a large number of images, it may be preferable to inspect the lattices over multiple sessions. In this case, click "Save Current Progress" at any time to save a snapshot of your work. This will include all autocleaning steps (so you will not have to set parameters or run autocleaning again), as well as saving the lattices you’ve already selected (so you will not have to click lattices again that you’ve already clicked). This will create a file ending in "progress.yml", which contains all the work you've done so far in a human-readable format.
To load your previous progress, upload the same .mat/.star file as before, but click "Load previous session" instead of "Read tomograms". This may take a few seconds. Do NOT click "Read tomograms" at any point!
Note that because this feature stores the results of automated cleaning, it cannot be used if only a subset (1 or 5) of the tomograms were initially loaded - in this case, the software has no data for which particles to include in the rest of the tomograms.