xfjointomo(1) General Commands Manual xfjointomo(1) NAME xfjointomo - use model features to refine serial tomogram alignment SYNOPSIS xfjointomo [options] input_file output_file(s) DESCRIPTION Xfjointomo computes transforms for aligning tomograms of serial sec- tions from features modeled on an initial joined tomogram. This fidu- cial model can have two kinds of features: contours following trajecto- ries on either side of a boundary, and contours with one point on either side of a boundary. Thus, features such as oblique microtubules can be used for alignment and, if trajectories at different angles are available, the optimal spacing between the tomograms can be determined. The inputs to and outputs from the program depend on how one plans to generate an aligned joined tomogram. If this refinement step is done right after making a joined tomogram, then the results should be used to rerun Finishjoin, since this avoids interpolating the data twice. In this case, the program needs to be informed about the offsets and binning, if any, used to compute the joined file that was modeled. It will output two transform files: one with the transforms that align each tomogram to the previous one (referred to as f transforms); and one with global transforms (g transforms) to be passed to Fin- ishjoin(1). Note that the latter are not necessarily suitable for transforming the fiducial model into the new alignment; rather, trans- forms for this purpose should be obtained by running "xftoxg -n 0" on the output file of f transforms. The resulting g transforms can be used with Xfmodel provided that the sizes of the sections are given to Xfmodel with the -chunk option. When used in this mode, the pro- gram can run repeatedly to "edit" a file of f transforms. For example, you can run it with one set of parameters and get solutions for a sub- set of the boundaries, then run it again with other parameters for a different subset of boundaries. The second way of using the program is with the intention of using New- stack(1) to transform the existing joined volume, or Xfmodel to transform a model on that volume. Transforming the joined volume will degrade the image data slightly but might be the most convenient option in some cases. To use this method, use the -slice option to get one transform per slice in the image file. These are f transforms relating each slice to the previous, and need to be converted to g transforms with "xftoxg -n 0". Note that the resulting transformation will be slightly different from that produced by running Xfjointomo without the -slice option, so you need to avoid mixing the modes of operation of this program. Data from trajectories such as microtubules are used to determine a pair of positions at a boundary between two sections, each position determined by extrapolating the trajectory on each side of the bound- ary. When you model trajectories such as microtubules, use enough points on each side of a boundary so that a line fit will give a rea- sonable extrapolation of the trajectory. The number of points used for the line fit is controlled by the -points entry; by default, fits will be done to 5 points if they are available, and to a minimum of 2 points. Points on each side of the gap must be on more than one Z slice, otherwise the line through them will not extrapolate to the other side of the gap. If a microtubule is curved at some distance from a boundary, you should add points densely enough so that the points being fit will be in a straight segment near the boundary. Avoid using the "Fill in Z" option, because that will create redundant data between actual points within a section, and incorrect data in a line segment across the boundary. In addition to trajectories, you can use contours with two points in them to specify the centers of features that should align across a boundary. You may find that setting a symbol size or spherical point size for each point allows you to judge the centering of the point in a feature such as a vesicle. These pairs of points are included together with the pairs of positions extrapolated from trajectories in a single least-squares fit to find the transformation at a boundary. You can select the kind of transformation to solve for: translation only, rota- tion as well, magnification as well, or a full linear transformation including stretch. The linear transformation requires the most data, and requires data spread out over the area that you want to align well. With data from trajectories, the program can fit the data with differ- ent assumed spacings between the sections (gap sizes) and find the adjustment to the spacing that minimizes the error. It will print out the error and other information for each gap size, and save the trans- form that occurs at the gap size wit the minimum error. If you find that the minimum error occurs at a gap other than zero, you can change the number of sections in the final join, adding sections for a posi- tive gap size and taking some away for a negative gap size. If you do not want to adjust the section spacing, leave out the -gap option to get the best fitting solution for the current spacing between sections. Note that if you are transforming a model and need to adjust section spacings, you can use Remapmodel after transforming. OPTIONS Xfjointomo uses the PIP package for input exclusively (see the manual page for pip). The following options can be specified either as command line arguments (with the -) or one per line in a command file or parameter file (without the -). Options can be abbreviated to unique letters; the currently valid abbreviations for short names are shown in parentheses. -input (-i) OR -InputFile File name Input model file from which transforms will be found. If this option is not entered, the first non-option argument will be used. -foutput (-f) OR -FOutputFile File name Output file for list of f transforms, which align each section to the previous one. If this option is not entered, the second non-option argument will be used. -goutput (-go) OR -GOutputFile File name Output file for list of global transforms that can be supplied to Finishjoin, adjusted for any offsets used when making the join file that was modeled. This entry is required unless out- putting transforms for every slice, in which case it must be omitted. If this option is not entered, the third non-option argument will be used. -edit (-e) OR -EditExistingFile If the specified output file for f transforms exists, read transforms from it and use them for any boundaries not being aligned. This option allows the program to be run repeatedly, computing transforms for a subset of boundaries each time. -slice (-sl) OR -SliceTransforms Output transforms for every slice of joined tomogram that was modeled. Use this option if you plan to transform the joined file instead of rerunning Finishjoin. -join (-j) OR -JoinFileOrSizeXYZ File name Joined tomogram that model was built on, or its size in X, Y, and Z. If this option is not entered, the image X and Y size will be used from the model header. -sizes (-si) OR -SizesOfSections Multiple integers Number of slices in each section of joined file -zvalues (-z) OR -ZValuesOfBoundaries Multiple integers Z value of last slice before each boundary (numbered from 1). Either this entry or the sizes of the sections must be entered. If this option and the -slice option are used, then a -join entry is also needed to inform the program of the full Z size of the file. -offset (-of) OR -OffsetOfJoin Two integers Offset applied in making the join file that was modeled. This is the same as the offset entry to Finishjoin, and the nega- tive of the shift values that appear in Etomo. -binning (-bi) OR -BinningOfJoin Integer Binning used to make the join file that was modeled -refsec (-re) OR -ReferenceSection Integer Reference section that was not transformed in the join, numbered from 1 -transonly (-t) OR -TranslationOnly Solve for transformations that include only translations in X and Y. -rottrans (-ro) OR -RotationTranslation Solve for transformations that include rotations and transla- tions, which requires at least 2 points at each boundary. -magrot (-m) OR -MagRotTrans Solve for transformations that include magnifications, rotations and translations, i.e. no stretch. These solutions require at least 3 points at each boundary. If none of of these three options is given, the default is to solve for a full linear transformation, which requires at least 4 points. -boundaries (-bo) OR -BoundariesToAnalyze List of integer ranges List of boundaries to find transformations across, numbered from 1. The default is to do all boundaries. -points (-po) OR -PointsToFit Two integers Maximum and minimum number of points to fit on each side of boundary. If a contour contains the minimum number of points in each of the sections forming a boundary, then lines will be fit separately to the points on each side. The number of points in each fit is limited by the given maximum value. A contour is ignored at a particular boundary if it has fewer than the mini- mum number of points in the section on either side, unless it has just one point on each side. The defaults are 5 and 2. -gap (-ga) OR -GapStartEndInc Three floats Starting and ending gap size to try between sections, and incre- ment between gap sizes. The gap sizes can be negative or posi- tive. Only one gap size will be used if the ending value equals the starting value or the increment is 0. The default is 0,0,0. -objects (-ob) OR -ObjectsToInclude List of integer ranges Objects to include in the fits -param (-pa) OR -ParameterFile Parameter file Read parameter entries as keyword-value pairs from a parameter file. -help (-h) OR -usage Print help output -StandardInput Read parameter entries from standard input. HISTORY Written by David Mastronarde, 10/26/06 BUGS Email bug reports to mast at colorado dot edu. IMOD 4.11.0 xfjointomo(1)