nad_eed_3d(1)               General Commands Manual              nad_eed_3d(1)



NAME
       nad_eed_3d - Nonlinear anisotropic diffusion, edge enhancing, in 3D

SYNOPSIS
       nad_eed_3d  [options]  input_file  output_file

DESCRIPTION
       nad_eed_3d is Frangakis and Hegerl's 3D anisotropic diffusion program
       with edge-enhancing diffusion only (see Frangakis, A., and Hegerl, R.,
       2001.  "Noise reduction in electron tomographic reconstructions using
       nonlinear anisotropic diffusion." J. Struct. Biol. 135: 239-205).  In
       addition to options to control the algorithm itself, this version pro-
       vides some options to make it easier to explore the effects of differ-
       ent parameters.

       The program requires ~36 times as much memory as the number of voxels
       in the input file.  To process a large volume, place the command line
       needed to run the program into a command file and use chunksetup to
       obtain command files to process the volume in chunks.  Determine the
       maximum number of megabytes of memory that you want this processing to
       require, and divide by 36 to obtain the value to enter with the -m
       option to chunksetup.  See the example below.

       Finding the right parameters for anisotropic diffusion can be diffi-
       cult.  To adjust parameters, first clip out a small subvolume, e.g.,
       100x100x30 pixels, with typical features of interest.  One strategy is
       to look at a restricted range of iterations, such as 5-10 or possibly
       5-15, and find the K value that gives the desired result.  A very wide
       range of K needs to be explored, perhaps from .02 to 5 times the stan-
       dard deviation of the data.  For typical byte data this might be a
       range of 0.4 to 100.  The range should thus be explored in two stages.
       In the first stage, you might try K values of 0.4, 1.6, 6.4, 26, 102,
       then look at the results as described below.  When you see that the
       desired K value falls in one of these intervals, then try 5 K values to
       fill in the interval with finer steps, such as 2.4, 3.2, 4.0, 4.8, and
       5.6 for the interval from 1.6 and 6.4.  Once you have chosen your
       parameters, you can process the whole volume.

       The Etomo program contains an interface for extracting a subvolume,
       testing different K values and iteration numbers, and running the dif-
       fusion on a full volume.  From the File menu, select "New Parallel
       Process" then press the "Nonlinear Anisotropic Diffusion" button.

OPTIONS
       -k value
              The K value (sometimes referred to as lambda).  The ratio of the
              local image gradient to K is used to determine whether density
              will diffuse isotropically or primarily in the direction of
              least density variation (along edges).  Lower K values will pre-
              serve more edges; higher K values will give more isotropic
              smoothing.

       -n value
              The number of iterations.  The higher the number of iterations,
              the smoother the result.

       -i list
              A list of iterations at which output should be written to a file
              (ranges such as 1-3,5,8 are allowed).  If such a list is
              entered, the -n option is ignored.  By default, the entire vol-
              ume will be written at each listed iteration, with the filename
              outfile_file-nnn, where output_file is the name entered on the
              command line, and nnn is the number of iterations, with leading
              zeros as needed to give three digits.  However, if the -o option
              is entered, a single slice will be written at each of the speci-
              fied iterations, all into the same output file.

       -e ext An extension (excluding the dot) to put after the iteration num-
              ber of the filename when writing files at selected iterations,
              so the name has the form output_file-nnn.ext.

       -o value
              Single slice to output (numbered from 1).  This option is useful
              when adjusting parameters if you can judge the performance by
              looking at just one slice.  It will not make the program do the
              computation on only one slice; it will still operate on the
              whole input volume.

       -m value
              Mode for output file: 0 for byte, 1 for integer, 2 for real, 6
              for unsigned integer, or 12 for 16-bit float.  By default, the
              output file will have the same mode as the input file, although
              the default mode of floating point output for MRC files is gov-
              erned by the value of environment variable
              IMOD_WRITE_FLOATS_16BIT.  The default works for byte data
              because densities will never become more extreme than in the
              original volume.  However, if you have byte input data with a
              low dynamic range, you may need to specify real output to avoid
              seeing discrete density levels in the smoothed regions.  Mode 12
              is allowed only if the output format is MRC.

       -s value
              Sigma value for smoothing or averaging the structure tensor,
              which might give a more accurate estimate of the direction of an
              edge.  The default is 0 for no smoothing.

       -t value
              The time step.  The product of the time step and the number of
              iterations determines the amount of diffusion.  The diffusion
              will run faster with a higher time step but may become unstable.

       -F format
              Set format of output file to MRC, TIFF, HDF (if the package sup-
              ports HDF), or JPEG (if the package supports JPEG) by entering
              MRC, TIF, TIFF, HDF, JPG, JPEG, or any lower case form of these.
              Only a single image can be output to a JPEG file.  This entry
              overrides a default format set with the environment variable
              IMOD_OUTPUT_FORMAT.

       -f     Use faster but less accurate routine for computing eigenvectors.
              With this option the program will run about 75% faster, but the
              results will differ by about 1%.  The difference is probably not
              meaningful.

       -P     Print process ID to standard error.

EXAMPLES
       To get a set of volumes, one at every third iteration, enter:
          nad_eed_3d -i 3,6,9,12,15,18,21 -k 1.2 tomo.rec tomo.nad

       This will produce tomo.nad-003, tomo.nad-006, etc.  They can be visual-
       ized with:
          3dmod tomo.nad-*

       To get a single file with one slice, say slice 16, from every iteration
       from 5 to 15, enter:
          nad_eed_3d -i 5-15 -k 1.2 -o 16 tomo.rec tomo.nad-1.2

       To get a series of such files at different K values, just repeat the
       above command, or (under tcsh) enter:
          foreach i (0.6 0.8 1.0 1.2 1.4 1.6)
          nad_eed_3d -i 5-15 -k $i -o 16 tomo.rec tomo.nad-$i
          end

       This will produce tomo.nad-0.6, tomo.nad-0.8, etc., which can be visu-
       alized with:
          3dmod tomo.nad-*.*

       If your file is large (e.g., > 10 megavoxels), and you have determined
       your optimal parameters, say 15 iterations with a K of 1.3, then pre-
       pare a command file, e.g., nad.com, with the line:
          $nad_eed_3d -k 1.3 -n 15 INPUTFILE OUTPUTFILE
       (Do not indent the line; the $ must be the first character on the line.
       Also, do not substitute your input and output files, the command file
       really should say INPUTFILE and OUTPUTFILE.)

       Then enter:
          chunksetup -m 10 nad.com tomo.rec tomo.nad

       If you are doing more than 8 iterations, you should increase the over-
       lap between chunks by adding the option "-p #" where "#" is the number
       of iterations; this will reduce the effects of cutting the volume into
       chunks to a minor level.  Overlap of 4 times the number of iterations
       is needed to eliminate these effects but this could increase chunk
       sizes substantially.

       The Chunksetup command with option "-m 10" will produce command files
       in which each run of the program will require less than 360 MB of mem-
       ory (use a different amount to allow for more memory).  On a single
       processor machine, run these with:
          subm nad-all

       If multiple machines or processors are available, run in parallel with:
          processchunks list_of_machines nad
       or just
          processchunks # nad
       to run with # processors on the local machine.

FILES
       If an output file already exists, it will be made a backup file by
       adding ~ to its name.

AUTHORS
       Achilleas Frangakis and Reiner Hegerl (IMOD modifications by David Mas-
       tronarde).  The program is copyright Max-Planck-Institut for Biochem-
       istry, Martinsried, Germany.

SEE ALSO
       chunksetup, processchunks, 3dmod

BUGS
       Email bug reports to mast at colorado dot edu.



IMOD                                 5.2.0                       nad_eed_3d(1)