framewatcher(1) General Commands Manual framewatcher(1) NAME framewatcher - watch for command files or stacks to run with align- frames SYNOPSIS framewatcher [options] DESCRIPTION Framewatcher is a Python program that can watch for either command files or frame stacks appearing in a directory. The command files are expected to run the program Alignframes and to have extension .pcm, the extension on files produced by the SerialEMCCD plugin to DigitalMi- crograph. The program can modify a few of the parameters in such a file with the options below. The frame stacks must have extension .mrc or .tif. Output files with aligned sums can be placed in a different directory. Stacks and command files can be moved to another directory when they are finished. Whole tilt series can be processed when a com- mand file specifies the metadata (.mdoc) file for the tilt series stack. To process frame stacks, either a master command file for alignment must be supplied or the -nocom option must be entered; in either case, the program will watch only for stacks, not for command files. It will avoid moving an image file that has no images in it yet and a tilt series file that is not yet finished. The master command file can run Alignframes, in which case the same parameters can be modified before running on each stack as when watching for command files. Alternatively, the command file can run other software, in which case it should contain the text "INPUTFILE" and "OUTPUTFILE" wherever the input and output filenames are needed, respectively. The name of the stack will be substituted for "INPUTFILE", and the name of the output file for the aligned sum, including the optional output directory, will be substituted for "OUTPUTFILE". A command file will be written with the root name of the stack plus the extension ".pcm". In either case, the command file is run with Vmstopy in the direc- tory where it is located and produces a log file there. If files are not being moved elsewhere when done, the command file is renamed with ".done" added at the end, which is how the program keeps from rerunning stacks or command files even if restarted. If no command file at all is run, ".done" will be added to the stack name itself unless it is moved elsewhere. An arbitrary command can be run before or after the command file is run (or a stack is moved or renamed, when there is no command file). Items such as the root name of the data can be substituted into the command, as described below. This may provide a more flexible way to run other alignment software than the master command file. The program works by looking in the directory for eligible files and running all of the ones that it sees. When it sees no files, it waits 5 seconds before scanning the directory again. When it see stacks, it runs all but the last one immediately, then waits until the last one (which typically would be the only one seen) has not changed for at least 15 seconds. Entrl Ctrl C to terminate the program. This will kill any running alignment operation. OPTIONS Framewatcher uses the PIP package for input (see the manual page for pip). Options can be specified either as command line arguments (with the -) or one per line in a command file (without the -). Options can be abbreviated to unique letters; the currently valid abbreviations for short names are shown in parentheses. -watch (-w) OR -WatchDirectory Text string Directory to watch for Alignframes command files, whose extension should be .pcm, or stacks, whose extension should be .mrc or .tif. -output (-o) OR -OutputDirectory Text string Directory in which to write aligned sums and other output. This directory must already exist. By default, files are written to the command file directory. -processed (-pr) OR -ProcessedDirectory Text string One or more directories into which frame stacks will be moved when they are finished being processed. If a relative path is entered, it will be treated as relative to the watched direc- tory, not the current directory. The directory will be created if it does not exist. If multiple directories are entered, the program will cycle through them. When a command file to process a single frame file is done, the program will move the stack, command file, and log file into the directory. If this direc- tory is on another filesystem, the files will be copied there and deleted from their current location. If the command file has options to use a gain reference file or a defect correction file, copies of these files will also be maintained in the pro- cessed directory. Alternatively, when moving files without a command file, the program will look for the names of the gain and defect files in the stack header and make sure there are copies of those. When a command file to process a whole tilt series is done, nothing is moved unless the last component of the path to the frame files is the same as the tilt series root name. SerialEM will write files in this way if the option to use the file name of the current open file in the name of the frame stack folder is selected in the Frame File Options dialog. In that case, the directory itself is moved to the processed directory, since it can be assumed not to contain other frame stacks to be processed. If this -processed option is not entered, the program will just rename each ".pcm" file used to align the frames to "...pcm.done". (Successive entries accumu- late) -master (-ma) OR -MasterCommandFile File name Name of a command file to use if watching for frame stacks instead ".pcm" files. For each stack, the entries will be modi- fied appropriately, a file will be written with the root name of the stack plus ".pcm", and that file will be run. This master file should have either commands to run Alignframes (includ- ing lines with the options "InputFile" and "OutputImageFile") or entries INPUTFILE and OUTPUTFILE that will be substituted with the names of the frame stack and aligned sum file, respectively. If a file contains Alignframes options to apply a gain refer- ence or defect file, the specified files will be used without any checking for whether there is a newer file that applies to the current frames. Thus, be sure these entries are correct for the current session before using a command file with such entries. -nocom (-noc) OR -NoCommandFile Just watch for frame stacks without running a command file. This option cannot be entered with -master and must be accompa- nied by either -processed, -before, or -after; i.e., there must be something for the program to do with each stack. If a com- mand file does exist with the same root name as the stack, it will be copied also. -exclude (-e) OR -ExcludeFilesMatching Text string When watching for stacks, exclude file names containing the given string. This option can be used to exclude the frame stacks when processing whole tilt series with an .mdoc file con- taining frame file names. -lacks (-l) OR -MdocLacksImageExt When watching for stacks, .mdoc file names will be derived from the root name of the stack instead of the full name with exten- sion (e.g., setname.mdoc instead of setname.mrc.mdoc). -fmdoc (-f) OR -FrameFilesInMdoc Use names of frame stacks from an .mdoc file. This option is useful when watching for tilt series stacks and not doing dose weighting. -ddrop (-dd) OR -DropAndReplacementDoses Two floats Threshold dose for excluding frame set and dose to accumulate instead. This option is appropriate if Alignframes is being run and causes the corresponding option to be inserted into the command file. -mdrop (-md) OR -DropSetIfMeanBelow Floating point Exclude frame sets with a mean in an .mdoc file below the given value. This option is appropriate if Alignframes is being run and causes the corresponding option to be inserted into the command file. -age (-ag) OR -MinimumAgeOfStacks Floating point When watching for frame stacks, use this option to set the mini- mum time interval between the last detected change in the modi- fication time of the stack and starting to process the stack. The default is 15 seconds. -gpu (-g) OR -UseGPU Integer Use the GPU (graphical processing unit) for computations; enter 0 to use the best GPU on the system, or the number of a specific GPU (numbered from 1). This entry overrides whatever was origi- nally written into the command file. -binning (-bi) OR -BinningOfSum Integer Image reduction to apply to summed frames; this will override the value in the command files, which was set from the binning of the image returned to SerialEM. -sumscale (-su) OR -ScalingOfSum Floating point Amount to scale summed values before output; this will override the value in the command files, which was set to match the scal- ing of images returned to SerialEM. If dose-weighting is being used without the -dnorm option, additional scaling may be needed to preserve intensity resolution in highly filtered images. -dmdoc (-dm) OR -DosesInMetadataFile Do dose weighting with dose values in metadata file, if it is present. This entry will lead to an entry "TypeOfDoseFile 4" in the ".pcm" file and remove entries for FixedTotalDose or Fixed- FrameDoses. When frames sets are being aligned for a whole tilt series, the metadata file entry is already present in the ".pcm" file. In other cases, the program will look for a frame stack .mdoc file, i.e., a file with ".mdoc" appended to the name of the input stack. If this file is present, the MetadataFile option will be added to the ".pcm" file; otherwise nothing will be added. This option cannot be entered with -dframe or -dto- tal. -dtotal (-dt) OR -FixedTotalDose Floating point Total dose for each set of frames (not for entire tilt series), in electrons/square Angstrom. This entry will lead to a corre- sponding entry in the ".pcm" file, replacing an existing one if any, and remove entries for TypeOfDoseFile or FixedFrameDoses. This option cannot be entered with -dmdoc or -dframe. -dframe (-df) OR -FixedFrameDoses Floating point List of frame doses and numbers that applies to all sets of frames. The list is a set of paired numbers: a dose in elec- trons/square Angstrom and the number of frames taken at that dose (e.g., enter "2,10,4,5" for 10 frames of 2 e/A^2 and 5 frames of 4 e/A^2). This entry will lead to a corresponding entry in the ".pcm" file, replacing an existing one if any, and remove entries for TypeOfDoseFile or FixedTotalDose. This option cannot be entered with -dmdoc or -dtotal. -dprior (-dp) OR -InitialPriorDose Floating point Dose applied before any of the images in each frame set were taken; this value will lead to a corresponding entry in the ".pcm" file, replacing an existing one if any. -dnorm (-dn) OR -NormalizeDoseWeighting Normalize the dose weight filters so that they add up to to 1.0 within each set of frames. This entry will lead to a corre- sponding entry in the ".pcm" file. It is useful for tilt series where dose weighting of the tilt images is to be done in a later step. -unweight (-un) OR -UnweightedFileSuffix Text string Suffix for name of output file of summed images that have not been dose weighted, created in addition to the dose-weighted images placed in the main output file. The file will be named with _suffix.mrc after the stack root name. -volt (-v) OR -Voltage Integer Microscope voltage in kV; this value must be either 200 or 300. This entry will lead to a corresponding entry in the ".pcm" file, replacing an existing one if any; if none is entered, the default in Alignframes is 300 kV. -drift (-dr) OR -DriftLimitDistAndNumber Two floats Maximum shift between frames above which to drop initial frames of the set (in unbinned pixels), and either the maximum fraction or the maximum number of frames to drop. This entry will lead to a corresponding entry in the ".pcm" file. It is particularly useful for single-exposure (frame) tilt series. -reduce (-r) OR -ReducedSum Integer Amount to reduce image by, or target size, to get a reduced copy of the summed image. A value of 32 or less will be taken as the shrinkage factor, and a value greater than 32 will be taken as the target size to shrink too. In the latter case, the geomet- ric mean of the X and Y size will be divided by the target size and rounded to an integer. The output file will be named as the stack root name followed by "_redN.mrc", where N is the reduc- tion factor. The file will be placed in the same directory as the aligned sum unless a different destination is specified with the -thumb option. If the summed file is a tilt series, only the middle image will be used. -power (-po) OR -PowerSpectrum Integer Height for a JPEG file with a side-by-side reduced sum and reduced power spectrum. The summed image will be reduced by exactly the amount to give the specified height. The power spectrum will be computed on the full-sized summed image and reduced to the given height, so it shows all the frequencies in the summed image. The output file will be named as the stack root name followed by "_power.jpg". The file will be placed in the same directory as the aligned sum unless a different desti- nation is specified with the -thumb option. If the summed file is a tilt series, only the middle image will be used. -scale (-sc) OR -ScaleSpectrum Two floats Background gray level near the edge of the power spectrum, and the relative diameter of the annulus around the center whose mean will be scaled to be white. The default gray level is 48, and the default diameter is 0.02. Making the diameter smaller will saturate less area at the center of the power spectrum; making it bigger may give more dynamic range to show Thon rings away from the center. -thumb (-thu) OR -ThumbnailDirectory Text string Directory into which the reduced sums or power spectra will be written. If this option is not entered, they will be placed in the same directory as the aligned sums. The directory will be created if it does not exist. -before (-be) OR -RunCommandBefore Text string Command to run before running a command file, if any. The com- mand can include items enclosed in %{...} to be substituted with the actual values for the current frame stack. These items include: %{frameFile} - Frame stack, including original path when watching for ".pcm" files %{outputFile} - Aligned sum output file, including path %{gainReference} - Gain reference file, including path %{defectFile} - Defect file, including path %{rootName} - Root name of command file/stack %{outputDir} - Directory entered with -output, if any %{processedDir} - Directory entered with -processed, if any %{reducedDir} - Directory entered with -thumb, if any The substituted text will be enclosed in double quotes, unless it is a root name with no spaces included. Despite the quotes, it may be possible to concatenate these items with other text (it works in Linux). The output file will not exist when a com- mand is run before a command file. -after (-af) OR -RunCommandAfter Text string Command to run after running a command file, if any. The com- mand can include the items enclosed in %{...} just described. This command will be run after any moving or renaming of pro- cessed files, so the input stack may no longer exist by the same name. -none (-non) OR -TextForNone Text string Text to substitute in a command entered with -before or -after if the file or directory is not available for a particular item. The default is simply to remove the %{...} item if it has no value. Using a defined text such as "NONE" can make it easier for a script to parse the command, for example, because then each option entered to the script would always be followed by another token instead of a blank. -keep (-k) OR -KeepCommandLogs Keep log files with output from running commands before or after a command file. The default is to write a log then delete it if there is no error. -avoid (-av) OR -AvoidWindowsCopy Integer 1 to use Xcopy in Windows instead of Robocopy, or 2 to use nei- ther Xcopy nor Robocopy. In the latter case, Cygwin commands will be used when running through Cygwin or Python commands when running a Windows Python. This option exists because Robocopy can give obscure failures in some cases. Xcopy can do the same operations but is "deprecated". Copies with Cygwin commands may be significantly slower in some cases (e.g., with a 10G net- work); copies of whole directories through Python may be incred- ibly slow. -nice (-ni) OR -NicenessSetting Integer Priority at which to run jobs, a number between 1 and 19, where a higher value has lower priority. All values in this range are meaningfully different on Linux or Mac OS X, but they will be translated into a smaller selection of priority levels on Linux. The default is 15. -thread (-thr) OR -ThreadLimit Integer Limit on number of threads used for processing. This value will be used to set OMP_NUM_THREADS, which sets an upper limit to the number of threads used for operations that are multi-threaded with OpenMP (image reductions, FFTs). This thread number is already limited to the number of real cores when hyperthreading is enabled, but allowing that many threads may be counterproduc- tive when other multi-threaded operations are running. You can determine the number of physical and logical cores by entering "imodqtassist -t" in a terminal. -help (-h) OR -usage Print help output -StandardInput Read parameter entries from standard input EXAMPLES To run command files that appear in the current directory with no optional modifications, enter framewatcher To watch for files in a directory "X:\MyFrames" and move them to a sub- directory "Processed" when done, enter (in a DOS terminal on Windows) framewatcher -watch X:\MyFrames -proc Processed where the directory would be entered as "X:/MyFrames" in a Cygwin win- dow. To make sums with image reduction by 2 and run on a specific GPU, say # 2, enter framewatcher -bin 2 -gpu 2 where you could enter "-gpu 0" to run on the best available GPU even if the command file does not specify using a GPU. AUTHOR David Mastronarde SEE ALSO alignframes Email bug reports to mast at colorado dot edu. IMOD 5.2.0 framewatcher(1)