Difference between revisions of "Walkthrough on manual marker clicking"
| (48 intermediate revisions by 4 users not shown) | |||
| Line 1: | Line 1: | ||
| − | + | [[Category:Walkthroughs]] | |
| − | + | ||
| + | This walkthrough describes the tools to ''manually'' locate fiducial markers for tilt series alignment using different graphical tools. ''Automatic'' alignment is described in [[Walkthrough on GUI based tilt series alignment]] and [[Walkthrough on command line based tilt series alignment ]]. | ||
| = Data set = | = Data set = | ||
| + | We use a binned version of the first tilt series from the EMPIAR entry 10164, depicting a set of virus like particles (VLP). You can download it directly from EMPIAR, then bin it,   <!--[https://drive.google.com/file/d/1EsnKBvbFuWD1njk8dRVLc3SlhdsTHIpY/view?usp=drive_link or simply follow this link]-->[{{Template:DownloadLinkAWFHIV1TS}} or simply follow this link] to download a 600Mb file. You can also follow this tutorial using your own data. | ||
| − | + | <!--This tutorial uses the tilt series VPP_tomo4.mrc from the EMPIAR database entry 10064. You can download it directly from the website: https://www.ebi.ac.uk/pdbe/emdb/empiar/entry/10064/{{Template:DownloadLinkAWFmanualEMPIAR}} | |
| − | + | The tilt series has already been prepared and can be found by following the next steps.--> | |
| − | + | Note that this tilt series has the following tilt angles: <code>-57:3:60</code>. | |
| − | <tt> | + | = The <tt>dmarkers</tt> GUI = | 
| − | + | This GUI is the basic tool for exploring tilt series and annotating on it  using  ''Dynamo''. It allows to edit manually positions of markers, to fit them to a projection model, and to create an aligned data stack and a reconstruction based on this fitting. | |
| == Loading the data == | == Loading the data == | ||
| + | Opening the <tt>dmarkers</tt> GUI on a tilt series: | ||
| + | |||
| + | It is convenient to first read the tilt series: <br/> | ||
| + | |||
| + |  <tt>ts = dread('b001ts001.mrc');</tt> | ||
| − | Opening the <tt>dmarkers</tt> GUI on a tilt series: | + | and then pass the variable to the gui <tt>dmarkers</tt>: | 
| + | |||
| + |  <tt> gui = dmarkers(ts,'tiltAngles',-57:3:60);</tt> | ||
| + | |||
| + | here, <tt>gui</tt> is just a handle to the GUI. This handle can be used on a later point to operate on it. Note that we also need to pass the tilt angles, as they will be needed for fitting a projection model.  | ||
| + | |||
| + | [[File:manual_marker_HIV_TS.png|thumb|center|600px| <tt>dmarkers</tt> GUI ]] | ||
| + | |||
| + | |||
| + | <!--Opening the <tt>dmarkers</tt> GUI on a tilt series: | ||
| + | |||
| + | It is convenient to first read the tilt series: <br/> | ||
| − | + | In the '''local version''' that was distributed yesterday: <br/> | |
| + |  <tt>ts = dread('b001ts001.mrc');</tt> | ||
| − | <tt>ts = dread(' | + | In the remote version: <br/> | 
| + |  <tt>ts = dread('b001ts001_15_08_2023.mrc');</tt> | ||
| and then pass the variable to the gui <tt>dmarkers</tt>: | and then pass the variable to the gui <tt>dmarkers</tt>: | ||
| − | <tt>gui = dmarkers( | + |  <tt> gui = dmarkers(ts,'tiltAngles',-57:3:60);</tt> | 
| − | here, <tt>gui</tt> is just a handle to the GUI. This can be used on a later point to operate on it.  | + | here, <tt>gui</tt> is just a handle to the GUI. This handle can be used on a later point to operate on it. Note that we also need to pass the tilt angles, as they will be needed for fitting a projection model.  | 
| − | [[File:ManualAlignmentDmarkers.png  | + | [[File:ManualAlignmentDmarkers.png|thumb|center|600px| <tt>dmarkers</tt> GUI ]]--> | 
| == Basic visualization controls == | == Basic visualization controls == | ||
| Line 41: | Line 61: | ||
| * The tool with the four arrows pointing into the corners zooms out of the scene totally. | * The tool with the four arrows pointing into the corners zooms out of the scene totally. | ||
| − | [[File:ManualAlignmentControls.png  <tt>dmarkers</tt> GUI  | + | [[File:ManualAlignmentControls.png|thumb|center|400px|  Basic controls inn <tt>dmarkers</tt> GUI ]] | 
| === Dragging === | === Dragging === | ||
| − | The scene gets dragged by moving the mouse while keeping pressed the  | + | The scene gets dragged by moving the mouse while keeping pressed the right mouse button. | 
| === Elimination of defective tilts === | === Elimination of defective tilts === | ||
| − | Some micrographs may be defective because of errors during acquisition. They can be markers as invalid by the key   | + | Some micrographs may be defective because of errors during acquisition. They can be markers as invalid by the key  <tt>x</tt>. If you want to undo the marking of a micrograph as invalid, use <tt>shift+x</tt>. | 
| == Initiating a trace == | == Initiating a trace == | ||
| Line 56: | Line 76: | ||
| == Following a trace == | == Following a trace == | ||
| − | To select a gold bead, click on it with the mouse, a green box will appear on the observation corresponding to the selected markers  in the current micrograph. '''Important'''  to add observations into a trace that you have just created, you need to select it, otherwise your next clicks on the screen will be assigned to the trace that is currently under selection. | + | To select a gold bead, click on it with the mouse, a green box will appear on the observation corresponding to the selected markers  in the current micrograph. '''Important''':  to add observations into a trace that you have just created, you need to select it, otherwise your next clicks on the screen will be assigned to the trace that is currently under selection. | 
| Once you have selected a gold bead, you should switch off the tool for adding gold beads, and switch on the tool for adding observations to the gold bead currently under selection. The icon represents a point being tracked  across  several micrographs. | Once you have selected a gold bead, you should switch off the tool for adding gold beads, and switch on the tool for adding observations to the gold bead currently under selection. The icon represents a point being tracked  across  several micrographs. | ||
| Line 64: | Line 84: | ||
| Additionally, you can connect the ''click and right'' or ''click and left'' tools. When they are switched on, after a click on the screen, the GUI will automatically move to the next micrograph. | Additionally, you can connect the ''click and right'' or ''click and left'' tools. When they are switched on, after a click on the screen, the GUI will automatically move to the next micrograph. | ||
| − | [[  | + | [[File:ManualAlignmentSetGoldBead.png |thumb|center|400px|  The gold bead click tools sets new traces, the track tool allows adding new observations to the currently selected trace ]] | 
| === Key controls during clicking === | === Key controls during clicking === | ||
| Line 75: | Line 95: | ||
| There are two auxiliary GUIs that can be used to control the growth of the traces based as you click the points. The ''occupancy'' window updates as a new observation is added into a gold bead, showing the current content of each trace. And additional control shows the content of each trace as new points are clicked inside. | There are two auxiliary GUIs that can be used to control the growth of the traces based as you click the points. The ''occupancy'' window updates as a new observation is added into a gold bead, showing the current content of each trace. And additional control shows the content of each trace as new points are clicked inside. | ||
| − | [[File: | + | [[File:ManualAlignmentControlViewers.png |thumb|center|400px|  Tools to follow the traces across the micrographs ]] | 
| + | |||
| + | == Saving the marker set == | ||
| + | We want to save current set of markers into disk, by using the <tt>save to disk</tt> option in the <tt>Tracks</tt> menu. This will create the file <tt>Tracks.dms</tt> in disk. | ||
| = Fitting to an alignment model = | = Fitting to an alignment model = | ||
| − | When you have enough observations, you can proceed to fitting the location of your gold beads to a projection model. The tool with the icon Fit will compute a set of shifts and a single angle <tt>psi<tt> of rotation for the tilt axis.   | + | When you have enough observations, you can proceed to fitting the location of your gold beads to a projection model. The tool with the icon <tt>Fit</tt> will compute a set of shifts and a single angle <tt>psi</tt> of rotation for the tilt axis.   | 
| In the ''Fit'' menu on the GUI, you can find the current error, i.e., the mean residual between each observation and the projection estimated by the fitting model. | In the ''Fit'' menu on the GUI, you can find the current error, i.e., the mean residual between each observation and the projection estimated by the fitting model. | ||
| − | [[File:ManualAlignmentFitting.png |thumb|center| | + | [[File:ManualAlignmentFitting.png |thumb|center|400px| Fitting menu in <tt>dmarkers</tt>]] | 
| == Extended fitting models == | == Extended fitting models == | ||
| Line 90: | Line 113: | ||
| Although you will get a lower error value, this might be due to overfitting. Thus, richer parametric models should not be used if you don't have enough markers on each micrograph (in the order of the tens.) | Although you will get a lower error value, this might be due to overfitting. Thus, richer parametric models should not be used if you don't have enough markers on each micrograph (in the order of the tens.) | ||
| − | = The reconstruction  | + | = Reconstruction through the command line = | 
| − | + | ||
| + | Creating reconstructions through the command line is convenient when organizing the processing of  batches of tilt series. Automatic selection of markers is explored in a different walkthrough, here we describe the command line tools for creating reconstructions once a marker set is available. The steps are: | ||
| + | * Fitting of the available markers (using a ''fitter'' object). | ||
| + | * Extraction of alignment  parameters (using an ''aligner'' object). | ||
| + | * Creation of an aligned tilt series. | ||
| + | * Weighting the tilt series appropriately for a weighted-back-projection or Sirt-like reconstruction. | ||
| + | * Creation of the tomogram through back projecting the filtered aligned stack. | ||
| + | |||
| + | If you have a set of markers saved  in a file in disk, you can load it to memory through: | ||
| + | |||
| + |  <tt>markers = dread('Tracks.dms');</tt> | ||
| − | + | Then, you can create a fitter object: | |
| − | This  | + |  <tt>fitter = dfitter(markers);</tt> | 
| + | |||
| + | This object needs to know where to put the rotation center of the aligned tilt series.  | ||
| + |  <tt>fitter.setCenter(ts);</tt> | ||
| + | and prepare it to run with standard parameters: | ||
| − | =  | + |  <tt>fitter.physical.defaultInitialization();</tt> | 
| + | |||
| + | The command | ||
| + | |||
| + |  <tt>fitter.linearScan();</tt> | ||
| + | |||
| + | will then compute the best <tt>psi</tt> angle for the rotation of the tilt axis together with the shifts.  They can be gathered into an stack alignment object | ||
| + | |||
| + |  <tt>stackAligner = fitter.getStackAligner();</tt> | ||
| + | |||
| + | that gets then applied onto the original tilt series in the variable <tt>ts</tt>. | ||
| + | |||
| + |  <tt>tsAligned  = stackAligner.applyOnStack(ts);</tt>  | ||
| + | |||
| + | This aligned stack can be visualized through: | ||
| + | |||
| + |  <tt>dtmshow(tsAligned);</tt> | ||
| + | |||
| + | == Binned reconstruction  == | ||
| + | |||
| + | A reconstruction with a bigger pixel size can be computed by resizing both tilt series and markers. A marker object can be resized through: | ||
| + | |||
| + |  <tt>markersBinned = markers.math.bin(2);</tt> | ||
| + | |||
| + | Here, the factor 2 indicates that the coordinates of the markers get halved twice. This factor needs to be applied also to the tilt series: | ||
| + | |||
| + |  <tt>tsBinned = dpktilt.bin(ts,2);</tt> | ||
| + | |||
| + | Now, we can refit the binned markers, proceeding as above: | ||
| + | |||
| + |  <pre>binnedFitter = dfitter(markersBinned); | ||
| + | binnedFitter.setCenter(tsBinned); | ||
| + | binnedFitter.physical.defaultInitialization(); | ||
| + | binnedFitter.linearScan(); | ||
| + | binnedAligner = binnedFitter.getStackAligner(); | ||
| + | tsBinnedAligned = binnedAligner.applyOnStack(tsBinned);</pre> | ||
| + | |||
| + | To create a weighted back projection reconstruction, this stack needs to be weighted with a ramp function in the Fourier space. | ||
| + | |||
| + |  <tt> tsBinnedRamp = dpktomo.rec.applyRampFilter(tsBinnedAligned);</tt> | ||
| + | |||
| + | Then, we can use the command <tt>dpktilt.math.backproject</tt> to create a reconstruction. | ||
| + | |||
| + |   <tt>fbp = dpktilt.math.backproject([400,400,400],tsBinnedRamp,-57:3:60,'mw','*'); </tt> | ||
| + | |||
| + | Here, the flag <tt>'mw'</tt> is merely instructing ''Dynamo'' to use all available cores. | ||
| + | |||
| + | In case you did not mark a bead on every tilt you might get an error message at this point. Ideally you would go back and either mark at least one bead on the corresponding tilt or, if there are no good beads, you would exclude the tilt. Alternatively (but not recommended) you can use the following command to exclude the tilts without marked beads from the reconstruction: | ||
| + | |||
| + |   <tt>fbp = dpktilt.math.backproject([400,400,400],tsBinnedRamp,fitter.physical.thetas(fitter.physical.indicesActiveTilts),'mw','*'); </tt> | ||
| + | |||
| + | |||
| + | The reconstruction object <tt>fbp</tt> contains the reconstructed tomogram in its property <tt>.rec</tt>, which can be visualized through: | ||
| + | |||
| + |  <tt>dtmshow(fbp.rec);</tt> | ||
Latest revision as of 14:20, 3 December 2024
This walkthrough describes the tools to manually locate fiducial markers for tilt series alignment using different graphical tools. Automatic alignment is described in Walkthrough on GUI based tilt series alignment and Walkthrough on command line based tilt series alignment .
Contents
Data set
We use a binned version of the first tilt series from the EMPIAR entry 10164, depicting a set of virus like particles (VLP). You can download it directly from EMPIAR, then bin it, or simply follow this link to download a 600Mb file. You can also follow this tutorial using your own data.
Note that this tilt series has the following tilt angles: -57:3:60.
The dmarkers GUI
This GUI is the basic tool for exploring tilt series and annotating on it using Dynamo. It allows to edit manually positions of markers, to fit them to a projection model, and to create an aligned data stack and a reconstruction based on this fitting.
Loading the data
Opening the dmarkers GUI on a tilt series:
It is convenient to first read the tilt series: 
ts = dread('b001ts001.mrc');
and then pass the variable to the gui dmarkers:
gui = dmarkers(ts,'tiltAngles',-57:3:60);
here, gui is just a handle to the GUI. This handle can be used on a later point to operate on it. Note that we also need to pass the tilt angles, as they will be needed for fitting a projection model.
Basic visualization controls
Slide on micrographs
- Use the slide bar to view a transition of the micrographs (lower resolution images will be shown during the transition, full resolution images will be shown )
- left and right arrows move the previous or next micrograph in the tilt series.
Zoom
- You can zoom into a point by using the wheel.
- The small red window in the tool bar can be used as magnifying-glass to zoom in into a hand-draw a region.
- The tool with the four arrows pointing into the corners zooms out of the scene totally.
Dragging
The scene gets dragged by moving the mouse while keeping pressed the right mouse button.
Elimination of defective tilts
Some micrographs may be defective because of errors during acquisition. They can be markers as invalid by the key x. If you want to undo the marking of a micrograph as invalid, use shift+x.
Initiating a trace
A three-dimensional gold bead is represented by a trace. A trace is a set of observations, where we call observation to the location of the projection of a gold bead in a given micrograph.
The tool with a black point and a red edge starts the trace initiator. The cursor in the GUI becomes a cross; while this cursor is active, clicking on the screen will create a new gold bead.
Following a trace
To select a gold bead, click on it with the mouse, a green box will appear on the observation corresponding to the selected markers in the current micrograph. Important: to add observations into a trace that you have just created, you need to select it, otherwise your next clicks on the screen will be assigned to the trace that is currently under selection.
Once you have selected a gold bead, you should switch off the tool for adding gold beads, and switch on the tool for adding observations to the gold bead currently under selection. The icon represents a point being tracked across several micrographs.
You can use the arrows to move to the next or previous micrograph after clicking the gold bead.
Additionally, you can connect the click and right or click and left tools. When they are switched on, after a click on the screen, the GUI will automatically move to the next micrograph.
Key controls during clicking
- d will delete the closest observation (point in currently shown micrograph).
- shift + d will delete a full trace.
- m will move the observation of the currently selected shape to the location of the cursor.
Auxiliar views during clicking
There are two auxiliary GUIs that can be used to control the growth of the traces based as you click the points. The occupancy window updates as a new observation is added into a gold bead, showing the current content of each trace. And additional control shows the content of each trace as new points are clicked inside.
Saving the marker set
We want to save current set of markers into disk, by using the save to disk option in the Tracks menu. This will create the file Tracks.dms in disk.
Fitting to an alignment model
When you have enough observations, you can proceed to fitting the location of your gold beads to a projection model. The tool with the icon Fit will compute a set of shifts and a single angle psi of rotation for the tilt axis.
In the Fit menu on the GUI, you can find the current error, i.e., the mean residual between each observation and the projection estimated by the fitting model.
Extended fitting models
In a coarse fitting, Dynamo only tries to solve for shifts and a single rotation angle for all micrographs. It is possible to refine this fitting allowing a different rotation of the tilt axis for each micrograph. You can select for a richer model that computes for one different rotation angle on each micrograph by checking the option eachTilt on the parameter psi (default is single).
Although you will get a lower error value, this might be due to overfitting. Thus, richer parametric models should not be used if you don't have enough markers on each micrograph (in the order of the tens.)
Reconstruction through the command line
Creating reconstructions through the command line is convenient when organizing the processing of batches of tilt series. Automatic selection of markers is explored in a different walkthrough, here we describe the command line tools for creating reconstructions once a marker set is available. The steps are:
- Fitting of the available markers (using a fitter object).
- Extraction of alignment parameters (using an aligner object).
- Creation of an aligned tilt series.
- Weighting the tilt series appropriately for a weighted-back-projection or Sirt-like reconstruction.
- Creation of the tomogram through back projecting the filtered aligned stack.
If you have a set of markers saved in a file in disk, you can load it to memory through:
markers = dread('Tracks.dms');
Then, you can create a fitter object:
fitter = dfitter(markers);
This object needs to know where to put the rotation center of the aligned tilt series.
fitter.setCenter(ts);
and prepare it to run with standard parameters:
fitter.physical.defaultInitialization();
The command
fitter.linearScan();
will then compute the best psi angle for the rotation of the tilt axis together with the shifts. They can be gathered into an stack alignment object
stackAligner = fitter.getStackAligner();
that gets then applied onto the original tilt series in the variable ts.
tsAligned = stackAligner.applyOnStack(ts);
This aligned stack can be visualized through:
dtmshow(tsAligned);
Binned reconstruction
A reconstruction with a bigger pixel size can be computed by resizing both tilt series and markers. A marker object can be resized through:
markersBinned = markers.math.bin(2);
Here, the factor 2 indicates that the coordinates of the markers get halved twice. This factor needs to be applied also to the tilt series:
tsBinned = dpktilt.bin(ts,2);
Now, we can refit the binned markers, proceeding as above:
binnedFitter = dfitter(markersBinned); binnedFitter.setCenter(tsBinned); binnedFitter.physical.defaultInitialization(); binnedFitter.linearScan(); binnedAligner = binnedFitter.getStackAligner(); tsBinnedAligned = binnedAligner.applyOnStack(tsBinned);
To create a weighted back projection reconstruction, this stack needs to be weighted with a ramp function in the Fourier space.
tsBinnedRamp = dpktomo.rec.applyRampFilter(tsBinnedAligned);
Then, we can use the command dpktilt.math.backproject to create a reconstruction.
fbp = dpktilt.math.backproject([400,400,400],tsBinnedRamp,-57:3:60,'mw','*');
Here, the flag 'mw' is merely instructing Dynamo to use all available cores.
In case you did not mark a bead on every tilt you might get an error message at this point. Ideally you would go back and either mark at least one bead on the corresponding tilt or, if there are no good beads, you would exclude the tilt. Alternatively (but not recommended) you can use the following command to exclude the tilts without marked beads from the reconstruction:
fbp = dpktilt.math.backproject([400,400,400],tsBinnedRamp,fitter.physical.thetas(fitter.physical.indicesActiveTilts),'mw','*');
The reconstruction object fbp contains the reconstructed tomogram in its property .rec, which can be visualized through:
dtmshow(fbp.rec);






