xfmodel(1)                  General Commands Manual                 xfmodel(1)



NAME
       xfmodel - solves for transformations and applies them to models

SYNOPSIS
       xfmodel  [options]  input_model  output_file

DESCRIPTION
       Xfmodel will take an IMOD model, and either a) use corresponding points
       in two sections to obtain a transformation
          between the sections, or b) transform the points in the model to
       match a new alignment of images

       To solve for transforms, the model objects should consist of corre-
       sponding points in two or more successive sections.  The program con-
       siders each pair of successive sections independently.  If an object
       contains two points in the same section, the program will take the
       point whose Z value is closer to that of the other section in the pair.

       The program can "edit" an existing list of f transforms (transforms
       that relate each section to the previous one).  That is, the model may
       have points from only a few sections, or one may specify which sections
       to find transforms for, and the program will output a list containing
       new transforms for those sections and transforms from the existing list
       for the rest.

       In solving for transforms, the model can be built on unaligned images
       or on images that have been aligned with a previously existing set of
       transforms.  In the latter case, if you specify the file of g trans-
       forms that were used to prealign the images, then the new transforms
       will apply to the original images; otherwise, the new transforms are
       incremental to the first alignment and would apply to the prealigned
       images.

       When the program solves for the transformation between a pair of sec-
       tions, it applies the transformation to the points on the second sec-
       tion of the pair, and computes the displacement, or deviation, between
       each point and the corresponding point on the first section of the
       pair.  It then reports the mean deviation for all of the points, the
       maximum deviation, and the object number of the point with maximum
       deviation.  In addition, you may elect to have a complete report of the
       deviations of all points for particularly bad sections.  If you choose
       this option, you control which sections are reported by specifying cri-
       terion values for the mean and maximum deviations; the full report will
       be made for any sections with mean or maximum deviations greater than
       the respective criteria.

       If the images are montaged, this is specified by entering the the name
       of the file of piece coordinates.  The Z values in this list of pieces
       are used to establish the correspondence between Z values in the model
       and transform number in the list of transforms.  If the image is miss-
       ing some sections, you should specify whether the transform lists con-
       tain a transform only for each existing section or a transform for each
       section number, including the missing sections.  The choice here will
       be applied both to lists of existing transforms that are read in and to
       the list that is computed by the program, if any.  In either case, if
       there are model objects that bridge a gap over missing sections, the
       program can compute a transform between the sections on either side of
       the gap.

       Instead of solving for transforms between pairs of adjacent sections,
       the typical mode of operation, the program can solve for transforms
       between a single specified section and each other section.

       It is possible to find the X/Y translation alone that best aligns the
       set of points on a section to those on a previous section.  The result-
       ing transformations (which involve no rotations or size changes) can be
       used in a second stage of model alignment to remove progressive shifts
       in position while retaining trends in size and rotation.  It is also
       possible to find the translation and rotation alone that best aligns
       two sections.  The resulting transformations (which involve no size
       changes) can be used in a second stage of model alignment to remove
       progressive shifts in position and rotations while retaining trends in
       size.  Finally, you can also obtain transformations that include trans-
       lation, rotation, and magnification change but no stretch.

   Transforming Models
       A model that was built on unaligned images can be transformed to match
       with aligned images.  A model built on aligned images can be back-
       transformed to match the raw, unaligned images, or it can be trans-
       formed to match a new alignment of the images.  This behavior is con-
       trolled by specifying the transforms used for prealignment.  The possi-
       bilities can be illustrated with operations on a fiducial model for
       tilt series alignment, which was built on images prealigned with the
       transforms in setname.prexg.  Tiltalign produces transforms in set-
       name.tltxf that could be used to bring the prealigned images into final
       alignment.  To transform the fiducial model to the final aligned stack,
       use:
         xfmodel -xf setname.tltxf setname.fid setname.fidali

       Once setname.tltxf and setname.prexg are multiplied to obtain the full
       alignment transforms setname.xf, the same result is achieved with:
         xfmodel -xf setname.xf -pre setname.prexg setname.fid setname.fidali

       To transform the model back to the raw stack, use:
         xfmodel -back -pre setname.prexg setname.fid setname.fidunali

       When a distortion field is specified, it is important to indicate the
       prealignment transforms, if any, because the distortion field is accu-
       rate only for the original images.  The program can behave in 4 differ-
       ent ways:
         1) -distort only: the model is assumed to be built on unaligned
       images and is simply undistorted (or redistorted, if -back in included)
         2) -distort and -xform: the model is assumed to be built on unaligned
       images and is undistorted then transformed by the given transforms.
         3) -distort and -prealign: the model was built on prealigned images.
       It is back-transformed, undistorted, then re-transformed into alignment
       with undistorted prealigned images.
         4) -distort, -prealign, -xform: the model was built on prealigned
       images.  The transforms specified by -xform must be ones that would
       apply to original rather than prealigned images.  The model is back-
       transformed by the prealignment transforms, undistorted, then re-trans-
       formed by the transforms specified by -xform.

       Each linear transformation in a transform file is specified by a line
       with six numbers:
         A11 A12 A21 A22 DX DY where the coordinate (X, Y) is transformed to
       (X', Y') by:
         X' = A11 * X + A12 * Y + DX
         Y' = A21 * X + A22 * Y + DY

OPTIONS
       Xfmodel uses the PIP package for input (see the manual page for pip)
       and can take input interactively only for options available when the
       program was converted to PIP input, to maintain compatibility with old
       command files.  The following options can be specified either as com-
       mand 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 (-in) OR -InputFile     File name
              Input model file to be transformed, or from which transforma-
              tions will be found.

       -output (-o) OR -OutputFile    File name
              Output file, either transformed model or list of transforma-
              tions.

       -image (-im) OR -ImageFile     File name
              Image file that model was built on, used to determine center
              coordinate for transformations.  If neither this nor Center-
              InXandY are entered, the image size will be used from the model
              header.

       -piece (-pi) OR -PieceListFile      File name
              Name of piece list file for a montaged image file

       -allz (-al) OR -AllZhaveTransforms
              When there is a list of piece coordinates that has gaps in the Z
              values, use this entry to indicate that transform files have
              transforms for all Z values; otherwise the files will be assumed
              to have matching gaps in Z.

       -center (-ce) OR -CenterInXandY     Two floats
              Center coordinates of image in X and Y.  If neither this nor
              ImageFile are entered, the image size will be used from the
              model header.

       -transonly (-t) OR -TranslationOnly
              Solve for transformations that include only translations in X
              and Y.

       -rottrans (-r) OR -RotationTranslation
              Solve for transformations that include rotations and transla-
              tions.

       -magrot (-m) OR -MagRotTrans
              Solve for transformations that include magnifications, rotations
              and translations, i.e. no stretch.

       -sections (-se) OR -SectionsToAnalyze    List of integer ranges
              List of sections to find transformations for. identified by the
              second one of each pair, numbered from 0.  The default is all
              sections.

       -single (-si) OR -SingleSection     Integer
              Align all sections to a single reference section with the given
              section number.

       -full (-f) OR -FullReportMeanAndMax      Two floats
              A detailed report will be printed for any section that exceeds
              either the given mean deviation or the given maximum deviation.

       -prealign (-pr) OR -PrealignTransforms   File name
              File of g transforms that were used to prealign the images on
              which the model was built

       -edit (-e) OR -EditTransforms       File name
              Name of file with existing f transforms to be replaced by any
              transforms that are solved for

       -xforms (-x) OR -XformsToApply      File name
              File of g transforms to apply to transform the model

       -useline (-use) OR -UseTransformLine     Integer
              Line number of single transform to apply to all points in model,
              regardless of their Z values.  Line numbers start at 0.  This
              option can be used only when forward or back-transforming the
              model.  This option will be invoked automatically if there is
              only one transform in the file.  If prealignment transforms are
              specified when transforming or undistorting a model, they will
              be applied as usual, with a separate transform used for each Z
              value.

       -chunks (-ch) OR -ChunkSizes   List of integer ranges
              If the model consists of a set of blocks in Z, such as a model
              built on a set of serial tomograms, then this option can be used
              to apply one transform per chunk of Z values.  Enter a list giv-
              ing the number of sections in each chunk.  Z values beyond the
              total of these chunk sizes will not be transformed.  The same
              chunk structure will be used when applying prealignment trans-
              forms if -prealign is entered.

       -back (-ba) OR -BackTransform
              If no distortion field is involved, apply the inverse of the
              transforms specified by -prealign or -xforms.  Either of these
              two options may be used to specify transforms, but not both.  If
              a distortion field or mag gradient is specified, this option can
              be used to transform a model built on undistorted images to
              match original images.  In this case, prealignment transforms
              will be treated differently depending on how they are specified:
              with -xforms, the model will be back-transformed to match the
              raw images; with -prealign, the model will be transformed to
              match prealigned but distorted images.

       -scale (-sc) OR -ScaleShifts   Floating point
              Factor by which to scale X/Y translations in the transforms
              before applying them.  Use this option if a set of transforms is
              appropriate for images at one scale but the model was built on
              images at another scale.  For example, if images are scaled by
              binning, the factor would be the binning of the images that the
              transforms apply to, divided by the binning of the images on
              which the model was built.

       -adjust (-ad) OR -AdjustForRotationBy90       Integer
              When transforming the model, adjust for a rotation near 90
              degrees by shifting by the difference between center coordinates
              in X and Y.  This operation assumes that the model is going to
              be used with an image file whose X and Y sizes are transposed
              from the original image.  Newstack automatically transposes
              sizes when it detects that the transformations make this size
              fit the transformed images better.  However, this option should
              not be used when the rotated image was made with the -adjust
              option to Newstack, because origin values inserted by New-
              stack(1) will already result in an appropriate shift in the
              model in Xfmodel.  Enter 1 to detect a 90-degree rotation and
              adjust if it is detected, or 2 to apply the adjustment regard-
              less, which would be useful if the detection fails because a
              small fraction of images are not rotated enough.

       -distort (-d) OR -DistortionField   File name
              File with image distortion field to be applied in transforming
              model.  If BackTransform is specified, the model will be redis-
              torted, i.e.  transformed to match original distorted images.

       -binning (-bi) OR -BinningOfImages       Floating point
              The camera binning at which images were taken.  This entry may
              be required when undistorting if the program cannot deduce the
              binning unambiguously.

       -gradient (-g) OR -GradientFile     File name
              File with magnification gradients to be applied for each image.
              This should be a file listing the tilt angle, the percent magni-
              fication change per micron of Z height, and the degrees of rota-
              tion per micron of Z height for each image, such as is produced
              by Extractmaggrad.  The mag gradient correction is applied
              before a distortion field correction and before any transforma-
              tions.

       -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.

   INTERACTIVE INPUT
       If the program is started with no command line arguments, it reverts to
       interactive input with the following entries:

       Name of image file that model was built on, or blank line to enter cen-
       ter coordinates instead

       IF you entered an image file name, next enter the name of a piece list
       file if the image is a montage, otherwise enter a blank line

       OR if you did not enter an image file, next enter the X and Y index
       coordinates of the center of the image (NX/2, NY/2)

       IF there are gaps in the Z values described by the piece list, next
       enter 0 if transform files have transforms only for the Z values that
       exist, or 1 if they have transforms for all Z values

       Name of model file

       Enter one of:
         -1 to back-transform the model to fit a raw image stack
         0 to find linear transformations
         1 to transform the model with a set of transformations
         2 to find X/Y translations only
         3 to find translations and rotations
         4 to find translation, ratation, and mag change

       IF you entered any option other than -1 to back-transform, next enter 0
       if the model was built on raw sections, or the sections that you want
       to further transform; or 1 if the model was built on pre-aligned sec-
       tions and you want to reference transforms to the raw sections

       IF you are back-transforming OR if you entered 1 to the last query,
       next enter the file name of the g transforms used to pre-align the sec-
       tions

       IF you are transforming or back-transforming the model, next enter the
       name of the output model file.  This is the final entry for option -1

       IF you are transforming, enter the name of the file with transforms to
       apply; this is the final entry for option 1

       IF you finding transforms instead, continue with the following entries:

       Name of file with existing f transforms to be replaced by any trans-
       forms that are solved for

       Name of output file for new f transforms

       A list of section numbers to find transforms for (the second section of
       each pair, sections numbered from zero), or / to find transforms for
       all sections with data in the model, or -999 to find transforms of all
       sections relative to a single section

       IF you entered -999, next enter:
          The number of the single section
          The real list of transforms to find sections for, or / for all

       1 for complete reports of the deviations for each point on sections
       with bad fits, or 0 for no detailed reports

       IF you entered 1, then enter a criterion for the mean deviation and a
       criterion for the maximum deviation; a complete report will be given
       for any section that exceeds either criterion.

HISTORY
       Written by David Mastronarde, 1988
       DNM 7/20/89  changes for new model format
       DNM 1/10/90  have it transform only existing model points, not all
       points in p_coord array, to avoid bad Z values
       DNM 5/28/90  fix bug in rounding 0.5 values, implement ability to
       transform relative to a single section.
       DNM 3/31/92  Implement translation only finding
       DNM 5/1/92   Implement translation and rotation only finding
       DNM 4/24/95 changed model reading/writing to be portable
       DNM 9/23/97  Add translation, rotation, and mag change finding
       DNM 9/4/02  Change to take scaling from model and scale properly
       DNM 12/27/03 Convert to PIP input, add distortion correction

BUGS
       Email bug reports to mast at colorado dot edu.



IMOD                                 5.2.0                          xfmodel(1)