Index Page
FRMDIFF User's Guide

Table of Contents


   FRMDIFF User's Guide
      Abstract
      Summary
      If You Are in a Hurry
         To Check if Two CK Files Provide Identical Data
         To Assess Difference Between Two CK Files
         To Sample Quaternions from a CK File
         To Compute Transformation Between Two Frames
      Usage
      Options

   Inputs
      Kernel Files
         Primary Kernel Files
         Additional Kernel Files
      Comparison Runs vs. Sampling Runs
      Runs with Two, One, and No Primary Kernel File(s)
         Runs with Two Primary Kernel Files
         Runs with One Primary Kernel File
         Runs Without Primary Kernel Files
      ``From'', ``To'', and ``Coverage'' Frames
         ``From'' Frames
         ``To'' Frames
         ``Coverage'' Frames
      Times for Comparison/Sampling
         Coverage Window
         Times within Coverage Window
      Angular Velocities

   Output
      Overview of Report Types
         Time Tag Format for ``dump*'' Reports
         Numeric Format for ``dump*'' Reports
         Angle Units for ``dumpaa'' and ``dumpea'' Reports
      Report Header
         Report Header for Comparing Two Orientations
         Report Header for Coverage/Gaps for Two Orientations
         Report Header for Sampling an Orientation
         Report Header for Coverage/Gaps for An Orientation
      Report Formats
         Basic Report (no ``-t'' or ``-t basic'')
         Statistics Report (``-t stats'')
         Angle and Axis Dump Report (``-t dumpaa'')
         Matrix Dump Report (``-t dumpm'')
         SPICE-Style Quaternion Dump Report (``-t dumpqs'')
         ``Other''-Style Quaternion Dump Report (``-t dumpqo'')
         Euler Angles Dump Report (``-t dumpea'')
         Coverage Intervals Dump Report (``-t dumpc''):
         Coverage Gaps Dump Report (``-t dumpg'')

   Examples
      Checking if Two CKs Provide the Same Orientation
      Comparing Predicted and Reconstructed CKs
      Comparing Orientations from a CK Read Using Different SCLKs
      Comparing Binary and Text PCKs
      Comparing Two Text PCKs
      Sampling Orientation from a CK
      Sampling Orientation of a Built-in Frame
      Sampling Orientation of a Dynamic Frame
      Sampling Orientation With Two Different ``Coverage'' Frames
      Displaying Overlap in Coverage between Two CKs
      Displaying Gaps in a CK File

   Miscellaneous Things to Consider
      ``Apples vs. Oranges''
      Using Euler Angles for Small Rotation Differences
      Single Epoch

   References

   Acronyms

   Appendix 1: Comparison, Sampling and Report Quantity Algorithms
      Computing Rotation and Angular Velocity Difference
      Sampling Rotation and Angular Velocity
      Converting Rotation to Angle/Axis
      Converting Rotation to SPICE-Style Quaternion
      Converting Rotation to ``Other''-Style quaternion
      Converting Rotation to Euler Angles




Top

FRMDIFF User's Guide





Last revised on 2014 JAN 21 by B. V. Semenov.



Top

Abstract




FRMDIFF is a program that samples orientation of a reference frame known to SPICE or computes differences between orientations of two reference frames known to SPICE, and either displays this orientation or these differences, or shows statistics about it or them.



Top

Summary




FRMDIFF provides means for sampling orientation of a single reference frame, or for comparing orientations of two reference frames known to SPICE and supported by data from SPICE kernels.

To sample orientation of a single frame the program computes a set of transformations from one frame (the ``from'' frame) to another frame (the ``to'' frame) over an interval of time with fixed or variable time step, using a given set of kernel files. Then, depending on the requested type of output report, it prints to the screen a table containing these transformations expressed as total rotation angles and axes, quaternions, matrices or Euler angles and angular velocities, or only magnitude of the maximum rotation and angular velocity, or results of a simple statistical analysis of rotations.

To compare orientations of two frames the program computes a set of transformations from one frame (the ``from'' frame) to another frame (the ``to'' frame) over an interval of time with a fixed or variable time step using one set of kernels, computes a set of transformations for the same or a different ``from''-``to'' frame combination at the same times using the same or a different set of kernels, and then computes the difference in rotation and angular velocity between the corresponding transformations. Depending on the requested type of output report the program prints to the screen only maximum differences in rotation and angular velocity, or a complete table of rotation and angular velocity differences expressed as total rotation angles and axes, matrices, quaternions, or Euler angles, or results of a simple statistical analysis of the rotation differences.



Top

If You Are in a Hurry




This section shows four very common FRMDIFF usage scenarios with just enough explanations to get you going. An extensive set of detailed examples is provided at the end of this User's Guide.



Top

To Check if Two CK Files Provide Identical Data



To check if two CK files containing orientation for the same structure with respect to the same reference frame provide identical data, run FRMDIFF as follows:

   % frmdiff -k <lsk> <sclk> <fk> -s <step> <ck1> <ck2>
where ``<lsk>'', ``<sclk>'', ``<fk>'', ``<ck1>'' and ``<ck2>'' are the names of LSK, SCLK, FK, and two CK files (all five are required), and ``step'' is the time step, in seconds. If the maximum rotation angle in the output is zero (or close to zero, accounting for round off), then the CKs contain the same data. To include angular velocities in comparison, add ``-a yes'' before ``-s'', like this:

   % frmdiff -k <lsk> <sclk> <fk> -a yes -s <step> <ck1> <ck2>


Top

To Assess Difference Between Two CK Files



To assess the difference between two CK files containing orientation for the same structure with respect to the same reference frame as a function of time, run FRMDIFF as follows:

   % frmdiff -k <lsk> <sclk> <fk> -t dumpaa -s <step> <ck1> <ck2>
where ``<lsk>'', ``<sclk>'', ``<fk>'', ``<ck1>'' and ``<ck2>'' are the names of LSK, SCLK, FK, and two CK files (all five are required); ``-t dumpaa'' sets the output format to the rotation angle and axis dump; and ``step'' is the time step, in seconds. The program's output, which can be rather lengthy, can be re-directed to a file using the ``>'' pipe. Using the data captured in the file the total rotation angle (column 2) can be plotted against TDB seconds (column 1) to analyze the difference. To print output time tags as UTC in ISO date format instead of TDB seconds, add

   -f 'YYYY-MM-DDTHR:MN:SC.### ::RND'
before ``-k''. To use the Euler angle dump output instead of the rotation angle and axis dump output, replace ``dumpaa'' with ``dumpea''. To include angular velocities in the comparison, add ``-a yes'' before ``-s'', like this (the command line below is wrapped to fit the page width):

   % frmdiff -k <lsk> <sclk> <fk> -t dumpaa -a yes -s <step>
             <ck1> <ck2>


Top

To Sample Quaternions from a CK File



To sample orientation provided in a CK file and print it as SPICE-style quaternions, run FRMDIFF as follows:

   % frmdiff -k <lsk> <sclk> <fk> -t dumpqs -s <step> <ck>
where ``<lsk>'', ``<sclk>'', ``<fk>'', and ``<ck>'' are the names of LSK, SCLK, FK, and CK files (all four are required); ``-t dumpqs'' sets the output format to the SPICE-style quaternion dump; and ``step'' is the time step, in seconds. The program's output can be re-directed to a file using the ``>'' pipe. To print output time tags as UTC in ISO date format, add

   -f 'YYYY-MM-DDTHR:MN:SC.### ::RND'
before ``-k''. To use the ``other''-style quaternion dump instead of the SPICE-style quaternion dump, replace ``dumpqs'' with ``dumpqo''. To include angular velocities, add ``-a yes'' before ``-s''; to print angular velocities in the structure frame rather than the base frame, also add ``-m to'', like this (the command line below is wrapped to fit the page width):

   % frmdiff -k <lsk> <sclk> <fk> -t dumpqo -a yes -m to
             -s <step> <ck>


Top

To Compute Transformation Between Two Frames



To compute transformation from one frame known to SPICE to another frame known to SPICE and display this transformation as Euler angles, run FRMDIFF as follows (the command line below is wrapped to fit the page width):

   % frmdiff -k <kernels> -t dumpea
             -b <begintime> -e <endtime> -s <step>
             -f1 <from_frame> -t1 <to_frame>
where ``<kernels>'' are the names of kernel files needed to compute the transformation (an LSK must be included); ``-t dumpea'' sets the output format to the Euler angles dump; ``<begintime>'' and ``<endtime>'' set the begin and end time, as UTC, for the period of interest; ``step'' is the time step, in seconds; and ``<from_frame>'' and ``<to_frame>'' are the names of the frames from which and to which the transformation can be computed. For lengthy reports the program's output should be re-directed to a file using the ``>'' pipe.

Note that if the ``<to_frame>'' is a CK-based (Class 3) or PCK-based (Class 2) frame, the list of kernels (``<kernels>'') includes CKs or binary PCKs providing data for that frame, and ``-b <begintime> -e <endtime>'' are omitted, the program will automatically determine the ``<to_frame>''s data availability time window and will compute transformations with specified step over that whole window.



Top

Usage




FRMDIFF is a command line program with the following usage:

   % frmdiff [options] <first kernel> <second kernel>
   % frmdiff [options] <kernel>
   % frmdiff [options]
where either of the kernels can be a CK, a PCK, an FK, or any other SPICE kernel. The options are:

   -k  <supporting kernel(s) name(s)>
   -f1 <first ``from'' frame, name or ID>
   -t1 <first ``to'' frame, name or ID>
   -c1 <first frame for coverage look up, name or ID>
   -k1 <additional supporting kernel(s) for first file>
   -f2 <second ``from'' frame, name or ID>
   -t2 <second ``to'' frame, name or ID>
   -c2 <second frame for coverage look up, name or ID>
   -k2 <additional supporting kernel(s) for second file>
   -a  <compare angular velocities, yes|no (default: no)>
   -m  <frame for angular velocities, from|to (default: from)
   -b  <interval start time>
   -e  <interval stop time>
   -n  <number of points: 1 to 1000000 (default: 1000)>
   -s  <time step in seconds>
   -f  <time format, et|sclk|sclkd|ticks|picture_for_TIMOUT>
       (default: et)>
   -t  <report: basic|stats|dumpaa|dumpm|dumpqs|dumpqo|dumpea
       |dumpc|dumpg>
   -o  <rotation axes order (default: z y x)>
   -x  <units for output angles>
   -d  <number of significant digits: 6 to 17 (default: 14)>
The order of options and case of the option keys are not significant. The values provided after the option keys must be separated from keys by one or more spaces. Un-recognized options are not specifically checked for; instead they are treated as continuation of the value provided using the preceding recognized option.



Top

Options




Kernel file names and control parameters are provided to the program using the following command line options (only a brief description of each option is given in the list below; details, defaults, and dependencies are discussed later in this document):

<first kernel>

is the name of the first primary kernel. When two primary kernels are provided to the program this name must be the second to last item on the command line.
<second kernel>

is the name of the second primary kernel. When two primary kernels are provided to the program this name must be the last item on the command line.
<kernel>

is the name of the only primary kernel. When only one primary kernel is provided to the program this name must be the last item on the command line.
-k <kernels>

is used to specify the list of additional kernels that should be used for both frame transformations to be computed. Kernel names following ``-k'' must be separated by spaces.
-f1 <frame>

is used to specify the ``from'' frame for the first (or only) frame transformation to be computed. This frame must be known to SPICE and can be specified using the frame name, ID, or class ID.
-t1 <frame>

is used to specify the ``to'' frame for the first (or only) frame transformation to be computed. This frame must be known to SPICE and can be specified using the frame name, ID, or class ID.
-c1 <frame>

is used to specify the ``coverage'' frame to be used to look up the first coverage window. This frame must be known to SPICE and must be either a PCK-based (Class 2) or CK-based (Class 3) frame. It can be specified using the frame name, frame ID, or, if the first (or only) primary kernel is a CK or a binary PCK, class ID. If the first (or only) primary kernel file is a CK or a binary PCK, it must contain data for this frame.
-k1 <kernels>

is used to specify the list of additional kernels that should be used only for the first frame transformation to be computed. Kernel names following ``-k1'' must be separated by spaces.
-f2 <frame>

is used to specify the ``from'' frame for the second (or only) frame transformation to be computed. This frame must be known to SPICE and can be specified using the frame name, ID, or class ID.
-t2 <frame>

is used to specify the ``to'' frame for the second (or only) frame transformation to be computed. This frame must be known to SPICE and can be specified using the name, ID, or class ID.
-c2 <frame>

is used to specify the ``coverage'' frame to be used to look up the second coverage window. This frame must be known to SPICE and must be either a PCK-based (Class 2) or CK-based (Class 3) frame. It can be specified using the frame name, frame ID, or, if the second (or only) primary kernel is a CK or a binary PCK, class ID. If the second (or only) primary kernel file is a CK or a binary PCK, it must contain data for this frame.
-k2 <kernels>

is used to specify the list of additional kernels that should be used only for the second frame transformation to be computed. Kernel names following ``-k2'' must be separated by spaces.
-b <time>

is used to specify the coverage window begin time. This option must be provided when no primary kernels and ``coverage'' frames are specified. The time string provided using this option can be in any form accepted by SPICE's cspice_str2et function.
-e <time>

is used to specify the coverage window end time. This option must be provided when no primary kernels and ``coverage'' frames are specified. The time string provided using this option can be in any form accepted by SPICE's cspice_str2et function.
-n <number>

is used to specify the number of points within the coverage window, for which the frame transformation(s) must be computed. The number must be an integer between 1 and 1,000,000. The default value is 1000.
-s <step>

is used to specify the step, in seconds, for determining points within the coverage window, for which the frame transformation(s) must be computed. The step must be greater than 1E-8. This option supersedes ``-n''.
-t <report_type>

is used specify the type of report that the program should display:
                             basic   to display only the maximum
                                     rotation angle and angular
                                     velocity (AV) magnitude (default)
 
                             stats   to display statistics on rotation
                                     angles and AVs
 
                             dumpaa  to display a table of rotation
                                     angles and axes
 
                             dumpm   to display a table of matrices
 
                             dumpqs  to display a table of SPICE-style
                                     quaternions
 
                             dumpqo  to display a table of ``other''-
                                     style quaternions
 
                             dumpea  to display a table of Euler angles
 
                             dumpc   to display a table of coverage
                                     intervals
 
                             dumpg   to display a table of coverage
                                     gaps
-a <av_flag>

is used to tell the program whether angular velocities should be computed along with rotations:
                             no      to compute only rotations
                                     (default)
 
                             yes     to compute rotations and
                                     angular velocities
-m <av_frame>

is used to tell the program in which frame angular velocities should be reported:
                             from    to output angular velocities in
                                     ``from'' frame (default)
 
                             to      to output angular velocities in
                                     ``to'' frame
-f <time_type>

is used to specify the type of time tag to be used in tabular reports (``-t'' with ``dumpm'', ``dumpqs'', ``dumpqo'', ``dumpea'', ``dumpc'', or ``dumpg''):
                             et      to display times as TDB seconds
                                     past J2000 (default)
 
                             sclk    to display times as string SCLKs
 
                             sclkd   to display times as decimal SCLKs
 
                             ticks   to display times as encoded SCLK
                                     ticks
 
                             <PICT>  any time format picture accepted
                                     by the @TIMOUT @routine (for
                                     example ``YYYY-MM-DDTHR:MN:SC.###
                                     ::RND'' for time tags for be
                                     displayed as UTCs in ISO date
                                     format)
-o <axes>

is used to specify the list of axes determining the order of rotations used for converting rotation matrices to Euler angles. The value must be a space-delimited list of three axes from the set of ``X'', ``Y'', ``Z'' (case-insensitive). The second axis must differ from the first and third axes. The default order is ``Z Y X''.
-x <units>

is used to specify the units for the angles in the rotation angle and axis dump (``-t dumpaa'') and Euler angle dump (``-t dumpea'') reports; ignored for all other report types. Supported units are:
                             radians (default)
                             degrees
                             arcminutes
                             arcseconds
                             hourangle
                             minuteangle
                             secondangle
-d <number>

is used to specify the number of significant digits in the output numeric times (TDB seconds past J2000, decimal SCLKs and encoded SCLK ticks) and rotation component values or rotation difference component values included in the dump, coverage and coverage gap reports. The number must be an integer between 6 and 17. The default value is 14.
-v

causes the program to display only the version line. This option overrides all other options.
-u

causes the program to display the usage message. This option overrides all other options except ``-v''.
-h

causes the program to display a brief help message. This option overrides all other options except ``-v'' and ``-u''.


Top

Inputs





For a successful run the program must be supplied with kernel files providing sufficient data to compute the frame transformation(s) of interest, and with control parameters clearly specifying, together with default values determined from the kernels, what transformations should be computed and at what times. Both the kernels and the control parameters are provided to the program using command line options.



Top

Kernel Files




In most cases one or more kernel files must be provided to the program to perform comparison or sampling of frame orientations. Depending on how the kernel files are provided, they fall into one of two categories -- primary kernel files and additional kernel files.

Primary kernel files -- two, one, or none -- are provided at the end of the command line without any command line keys. Normally these kernel files contain orientations that differ (for example, predicted and reconstructed CKs for the same frame and time period, two versions of an FK with different alignment data for the same frame, etc.), or contain orientation to be sampled. These kernel files are also examined by the program to determine the default values for the ``from'', ``to'', and ``cov'' frames, and to determine the coverage window boundaries. Note that becasue the program slightly contracts coverage windows determined from CK files to compensate for roundoff occuring in SCLK to ET time conversions, in general FRMDIFF cannot be used to sample or compare CKs with discrete data, e.g. Type 1 CKs or Type 3 CKs with singleton intervals. For additional discussion of this limitation see the ``Coverage Window'' section below.

Additional kernel files -- none, or as many as needed -- are provided anywhere on the command line (except at the very end) using the ``-k'', ``-k1'', and ``-k2'' keys. Normally these kernel files contain additional SPICE data needed to compute requested orientations (for example, LSK and SCLK files providing supporting time conversion data, FK files providing frame definitions needed by SPICE to recognize specified frames, etc).



Top

Primary Kernel Files



The primary kernels can be of any type -- CK, PCK, FK, SCLK, LSK or even SPK -- and are provided as the last or the last two items on the command line. Since the primary kernel files do not require specific command line keys, the program determines if they were given by examining the last two words on the command line as follows:

    -- If the last word on the command line is not the name of an existing file, the program assumes that no primary kernel files were given.

    -- If the last word on the command line is the name of an existing file but the second to last word is not, the program assumes that only one primary kernel was given.

    -- If both last two words are names of existing files, the program assumes that it was given two primary kernel files

Due to the parsing approach described above, misspelling a primary kernel name leads to the program deciding that it either runs with no primary kernel files (if the last file name is misspelled) or that it runs with one primary kernel instead of two (if the second to last file name is misspelled). In either case, the misspelled file name(s) is(are) treated as a part of the value of the command line option immediately preceding it(them) causing the program to signal an error indicating an incorrect option value.

On the other hand, if any of the options for specifying additional kernel files (``-k'', ``-k1'', ``-k2'') followed by actual files names is provided at the end of the command line (for the case of no primary kernels) or immediately preceding the only primary file (for one primary kernel case), the last one or the last two additional kernels are mistakenly picked as the primary kernel(s). In this situation the program usually signals an error indicating that orientation could not be computed because insufficient data was loaded.



Top

Additional Kernel Files



As for primary kernels, additional kernels can also be of any type -- CK, PCK, FK, SCLK, LSK or even SPK. Unlike primary kernels, additional kernels are specified using the dedicated ``-k'', ``-k1'', and ``-k2'' keys. Any number of additional kernels can be provided using any of the three keys, with kernel file names listed in any order, separated by blanks. While in some rare cases no additional kernel files are required, in most cases at least an LSK file and an SCLK file containing time correlation data and an FK file containing frame definitions should be specified using these keys. The additional kernels are used by the program as follows:

    -- All additional kernel files provided using the ``-k'' are loaded and used for both ``from''-``to'' frame combinations.

    -- All additional kernel files provided using ``-k1'' are loaded and used only for the first ``from''-``to'' frame combination.

    -- All additional kernel files provided using ``-k2'' are loaded and used only for the second ``from''-``to'' frame combination.

Neither the combined set of additional kernel files given using ``-k''/``-k1'' nor the combined set of additional kernel files given using ``-k''/``-k2'' can contain enough data to compute corresponding orientations at any time in the time buffer without loading the corresponding primary file(s). If they do, the program signals an error. The two exceptions from this requirement are:

    -- when no primary kernel files are specified the additional kernel files given using ``-k''/``-k1'' and ``-k''/``-k2'' should contain enough data to compute the corresponding orientations

    -- when both ``from'' and ``to'' frames in one or both``from''-``to'' frame pairs are built-in frames, the check for inability to compute orientations without loading primary kernel files is skipped



Top

Comparison Runs vs. Sampling Runs




The program automatically decides whether it should compare two orientations or sample one orientation, based on the primary kernels provided at the end of the command line, additional kernel files provided using the ``-k1'' and ``-k2'' keys, and on the ``from'' and ``to'' frames specified on the command line using the ``-f1'', ``-t1'', ``-f2'', and ``-t2'' keys and/or determined from the primary kernel data.

To run the program in comparison mode, it is enough to satisfy any of the following guidelines for specifying inputs that tell the program to compute two different orientations:

    -- provide two different primary kernels

    -- provide two different sets of orientation-specific additional kernels using ``-k1'' and ``-k2''

    -- specify two different ``from'' frames using ``-f1'' and ``-f2''

    -- specify two different ``to'' frames using ``-t1'' and ``-t2''

To run the program in sampling mode, it is required to satisfy all of the following guidelines telling the program to compute a single orientation:

    -- provide only one primary kernel or no primary kernels

    -- provide no orientation-specific additional kernels using ``-k1'' and ``-k2''

    -- specify only one ``from'' frame using either ``-f1'' or ``-f2'' or no ``from'' frames

    -- specify only one ``to'' frame using either ``-t1'' or ``-t2'' or no ``to'' frames

There are only two cases when the program runs in sampling mode after being given two primary kernels and/or two orientation-specific additional kernel sets. These cases are:

    -- When run with two primary kernel files, the program samples orientation only if these kernel files are the same file and additional kernel files provided using the ``-k1''/``-k2'' keys are the same files listed the same order and ``from'' frames provided using the ``-f1''/``-f2'' keys or determined automatically are the same and ``to'' frames provided using the ``-t1''/``-t2'' keys or determined automatically are the same.

    -- When run with one primary kernel file or no primary kernel files but with some orientation-specific additional kernels, the program will sample orientation only if additional kernel files provided using the ``-k1''/``-k2'' keys are the same files listed in the same order and the ``from'' frames provided using the ``-f1''/``-f2'' keys or determined automatically are the same frames and the ``to'' frames provided using the ``-t1''/``-t2'' keys or determined automatically are the same frames.



Top

Runs with Two, One, and No Primary Kernel File(s)




The number and types of primary kernel files and the mode in which the program is run (``comparing'' vs. ``sampling'') directly affect the requirements in regards to which command line options must be provided, approaches for determining default values for omitted options, and ways in which kernels are loaded and orientations are computed. The three subsections below discuss specifics of runs with two, one, and no primary kernel files.



Top

Runs with Two Primary Kernel Files



When two primary kernel files are provided on the command line:

    -- All ``-*1'' and ``-*2'' options, and ``-b'' and ``-e'' options can be omitted if one of the primary files (or both primary files) are a CK or a binary PCK, for which defaults for these options can be picked from the file(s).

    -- ``-f1'' or ``-f2'' or both, ``-t1'' or ``-t2'' or both, and sufficient coverage information (e.g. a sufficient combination of ``-b'', ``-e'', ``-c1'', and ``-c2'') must be specified if neither of the primary files is a CK or binary PCK because the program has no way of picking defaults for the ``from'' frame(s), ``to'' frame(s), and time boundaries for any other types of primary kernels.

    -- If the program is run in comparison mode, the first primary file and the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first default/specified ``from''-``to'' frame combination are computed at times within the default/specified time window, then the second primary file and the additional kernel files given using ``-k'' and ``-k2'' are loaded and orientations for the second default/specified ``from''-``to'' frame combination are computed at the same times within the default/specified time window, then the differences between the corresponding orientations are computed and printed in the specified format.

    -- If the program is run in sampling mode, the first primary file and the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first default/specified ``from''-``to'' frame combination are computed at times within the default/specified time window and printed in the specified format.



Top

Runs with One Primary Kernel File



When one primary kernel file is provided on the command line:

    -- All ``-*1'' and ``-*2'' options, and ``-b'' and ``-e'' options can be omitted if the primary file is a CK or a binary PCK, for which defaults for these options can be picked from the file.

    -- ``-f1'' or ``-f2'' or both, ``-t1'' or ``-t2'' or both, and sufficient coverage information (e.g. a sufficient combination of ``-b'', ``-e'', ``-c1'', and ``-c2'') must be specified if the primary file is not a CK or a binary PCK because the program has no way of picking defaults for the ``from'' frame(s), ``to'' frame(s) and time boundaries for any other types of primary kernels.

    -- If the program is run in comparison mode, the primary file and the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first ``from''-``to'' frame combination are computed at times within the default/specified time window, then the primary file and the additional kernel files given using ``-k'' and ``-k2'' are loaded and orientations for the second ``from''-``to'' frame combination are computed at the same times within the default/specified time window, then the differences between corresponding orientations are computed and printed in the specified format.

    -- If the program is run in sampling mode, the primary file and the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first ``from''-``to'' frame combination are computed at times within the default/specified time window and then printed in the specified format.



Top

Runs Without Primary Kernel Files



When no primary kernel files are specified on the command line:

    -- ``-f1'' or ``-f2'' or both, ``-t1'' or ``-t2'' or both, and sufficient coverage information (e.g. a sufficient combination of ``-b'', ``-e'', ``-c1'', and ``-c2'') must be specified because the program has no way of picking defaults for the ``from'' frame(s), ``to'' frame(s), and time boundaries when it is not given any primary kernel(s) to examine.

    -- If the program is run in comparison mode, the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first ``from''-``to'' frame combination are computed at times within the default/specified time window, then the additional kernel files given using ``-k'' and ``-k2'' are loaded and orientations for the second ``from''-``to'' frame combination are computed at the same times within the default/specified time window, then the differences between corresponding orientations are computed and printed in the specified format.

    -- If the program is run in sampling mode, the additional kernel files given using ``-k'' and ``-k1'' are loaded and orientations for the first ``from''-``to'' frame combination are computed at times within the default/specified time window and then printed in the specified format.



Top

``From'', ``To'', and ``Coverage'' Frames




The program has six command line keys -- ``-f1'', ``-t1'', ``-c1'', ``-f2'', ``-t2'', and ``-c2'' -- to specify frames to be used to compute rotations (``-f*'' and ``-t*'' keys) and to determine coverage from primary or additional CK or binary PCK files (``-c*'' keys). A single frame can be specified using each of these keys using the frame name, frame ID, or frame class ID (only for runs with primary kernel files that are CKs or binary PCKs).

Whether the frame is specified by the name, ID, or class ID, it must be known to SPICE, i.e. it must either be a built-in frame or one of the frames defined in the FK file(s) provided as primary or additional kernels. If the frame name, ID, or class ID specified on the command line or picked from the primary file is not recognized after loading the kernel files provided using ``-k''/``-k1'' and the first primary file for the ``-*1'' frames, or provided using ``-k''/``-k2'' and the second primary file for the ``-*2'' frames, the program signals an error.

Not all six frames have to be specified for every program run. In fact in many cases only one, two, or even no frames can be given and the program will set the rest to default values based on the other frames that are provided and/or by examining the primary kernel files. The three subsections below discuss specifying and picking defaults for the ``from'', ``to'', and ``coverage'' frames.



Top

``From'' Frames



The following rules apply to specifying and picking defaults for the ``from'' frames:

    -- If both ``-f1'' and ``-f2'' are specified, orientations are computed with respect to these ``from'' frames.

    -- If only ``-f1'' or only ``-f2'' is specified, the specified ``from'' frame is used for both ``from'' frames.

    -- If neither ``-f1'' nor ``-f2'' is specified and only one of the primary kernel files is a CK or a binary PCK, the ``from'' frame from the last segment of this CK or PCK file is used for both ``from'' frames.

    -- If neither ``-f1'' nor ``-f2'' is specified and both primary kernel files are CKs or binary PCKs, the ``from'' frame from the last segment of the first primary CK or PCK file is used for both ``from'' frames.

    -- If neither ``-f1'' nor ``-f2'' is specified and no primary files are given or neither of the primary files is a CK or binary PCK, the program signals an error.



Top

``To'' Frames



The following rules apply to specifying and picking defaults for the ``to'' frames:

    -- If ``-t1'' and ``-t2'' are specified, orientations are computed for these ``to'' frames.

    -- If only ``-t1'' or only ``-t2'' is specified, the specified ``to'' frame is used for both ``to'' frames.

    -- If neither ``-t1'' nor ``-t2'' is specified and only one of the primary kernel files is a CK or a binary PCK, the frame from the last segment of this CK or PCK is used for both ``to'' frames.

    -- If neither ``-t1'' nor ``-t2'' is specified and both primary kernel files are CKs or binary PCKs, the frame from the last segment of the first CK or PCK is used for both ``to'' frames.

    -- If neither ``-t1'' nor ``-t2'' is specified and no primary files are given or neither of the primary files is a CK or binary PCK, the program signals an error.



Top

``Coverage'' Frames



The following rules apply to specifying and picking defaults for the ``coverage'' frames:

    -- Only PCK-based (Class 2) or CK-based (Class 3) frames can be specified using ``-c1'' and ``-c2''. Specifying frames of any other class using these keys is an error.

    -- If ``-c1'' is not specified and the first ``to'' frame is a PCK-based (Class 2) or CK-based (Class 3) specified using ``-t1'' or picked by default, the first ``coverage'' frame is set to the first ``to'' frame. Similarly, if ``-c2'' is not specified and the second ``to'' frame is a PCK-based (Class 2) or CK-based (Class 3) specified using ``-t2'' or picked by default, the second ``coverage'' frame is set to the second ``to'' frame.

    -- If ``-c1'' is specified or set by default to the first ``to'' frame, and the first (or only) primary kernel is a CK or binary PCK file containing data for this frame, then this frame is used to look up the first coverage window from this primary file. Similarly, if ``-c2'' is specified or set by default to the second ``to'' frame, and the second (or only) primary kernel is a CK or binary PCK file containing data for this frame, then this frame is used to look up the second coverage window from this primary file.

    -- If ``-c1'' is specified and the first (or only) primary kernel is a CK or binary PCK file that does not contains data for this frame, then the program signals an error. Similarly, if ``-c2'' is specified and the second (or only) primary kernel is a CK or binary PCK file that does not contains data for this frame, then the program signals an error.

    -- If ``-c1'' is set by default to the first ``to'' frame and the first (or only) primary kernel is a CK or binary PCK file that does not contains data for this frame, then the program does not attempt to determine the first coverage window for this frame based on the primary or additional kernels. Similarly, if ``-c2'' is set by default to the second ``to'' frame and the second (or only) primary kernel is a CK or binary PCK file that does not contains data for this frame, then the program does not attempt to determine the second coverage window for this frame based on the primary or additional kernels.

    -- If ``-c1'' is specified or set by default to the first ``to'' frame, and the first (or only) primary kernel is not a CK or binary PCK file, then this frame is used to look up the first coverage window from the kernels specified using ``-k'' and ``-k1''. Similarly, if ``-c2'' is specified or set by default to the second ``to'' frame, and the second (or only) primary kernel is not a CK or binary PCK file, then this frame is used to look up the second coverage window from the kernels specified using ``-k'' and ``-k2''.

    -- If ``-c1'' is specified or set by default to the first ``to'' frame and no primary kernels are given, then this frame is used to look up the first coverage window from the kernels specified using ``-k'' and ``-k1''. Similarly, if ``-c2'' is specified or set by default to the second ``to'' frame, and no primary kernels are given, then this frame is used to look up the second coverage window from the kernels specified using ``-k'' and ``-k2''.



Top

Times for Comparison/Sampling




The program picks times at which orientation(s) are computed based on the coverage window determined by examining the primary or additional files(s) and/or specified using the ``-b'' and ``-e'' keys, and on either the number of points within that window specified using the ``-n'' key or the time step specified using the ``-s'' key''.

The coverage window begin and end times specified using the ``-b'' and ``-e'' options can be in any format accepted by SPICE's cspice_str2et function (see cspice_str2et header for details). If one or both of these times are provided, an LSK file must be provided as one of the additional or primary kernels.

The number of points specified using the ``-n'' key must be an integer between 1 to 1,000,000 while the step specified using the ``-s'' key must be in seconds and be greater than 1.0E-8. If both ``-n'' and ``-s'' are specified, ``-s'' takes precedence.

The coverage window determined by examining the primary or additional kernels -- especially if these kernels are CK files, which frequently have gaps in coverage -- may consist of many intervals, some of which may be singletons (with the interval begin time equal to the interval end time). Whether the coverage window consists of only one interval or of many intervals, the program computes times within the window in such a way that the interval ends are always included in the set of points. The rest of times are distributed within the intervals, stepping from the beginning of each interval with the specified step. If the number of points is given instead of the step, the step is computed using the measure of the coverage window (the sum of the lengths of the individual intervals) and the specified number of points.

Not all of the keys controlling selection of points have to be specified for every program run. In some cases none of these options are required; in the other cases ``-b'', ``-e'', ``-c1'', and/or ``-c2'' must be specified. The two subsections below discuss specifics of providing and picking defaults for the coverage window and step or number of points.



Top

Coverage Window



The program determines the coverage window either by examining the primary or additional kernels (resulting in the ``default coverage window''), or by using the begin and end times specified using the ``-b'' and ``-e'' keys, or as a combination of both.

The default coverage window can be determined only from the primary or additional kernel files that are binary PCK files (using SPICE's cspice_pckcov function) or CK files (using SPICE's cspice_ckcov function) and only if these kernels contain data for the ``coverage'' frames either specified using the ``-c1''/``-c2'' keys or set to default values as described earlier in this document. When both ``coverage'' frames are specified or set to default values, the program determines the frame-specific coverage window for each of them using the corresponding primary or additional kernels and sets the default coverage window to the intersection of these two frame-specific coverage windows. When only one ``coverage'' frame is specified or set to the default value, the program determines the frame-specific coverage window for that frame using corresponding primary or additional kernels and sets the default coverage window to that frame-specific coverage window.

In cases when a frame-specific coverage window is obtained from the corresponding primary kernel, the program examines only that primary kernel to construct the desired frame-specific coverage window. In cases when a frame-specific coverage window is obtained from additional kernels, the program examines all kernels of a particular type -- all CKs if the ``coverage'' frame is a CK-based frame or all binary PCKs if the ``coverage'' frame is a PCK-based frame -- listed explicitly with the ``-k''/``-k1'' or ``-k''/``-k2'' keys or included in meta-kernels provided with these keys and constructs the frame-specific coverage window as the union of coverages obtained from individual additional kernels.

When the program determines the coverage window for a CK file it slightly contracts the actual coverage window given by the CK data to compensate for roundoff occuring in SCLK-ET time conversions. The contraction is done by adjusting inward the window interval boundary times by three times the amout of maximum roundoff that was determined by converting all boundary times from SCLK to ET then back to SCLK. This adjustment is done to ensure that the program is able to compute orientation at any time within the comparison or sampling time domain using the high level SPICE frames routines (cspice_pxform and cspice_sxform). While this contraction does not have any noticable effect when the program is run with CKs containing continuous data, it makes the program unuseable with CKs containing disrete data -- Type 1 CKs and Type 3 CKs with singleton intervals -- because such contraction eliminates all singleton intervals corresponding to the discrete time point from the comparison window. The error messages that the program would display in such cases say that CK files do not provide any roundoff-adjusted coverage for a particular CK-based frame. An exception to this limitation is the rare ciscumstance when SCLK-ET time conversions have no round off; in such cases the program will work on CKs containing discrete data.

If the default coverage window was determined from primary or additional kernel file(s) and either ``-b'' or ``-e'', or both ``-b'' and ``-e'' were specified, it is truncated according to these begin and end times. If the time specified using ``-b'' is before the start of the default window, this time is ignored. If the time specified using ``-b'' is after the end of the default coverage window, the program signals an error. If the time specified using ``-e'' is after the end of the default window, this time is ignored. If the time specified using ``-e'' is before the start of the default coverage window, the program signals an error.

If no ``coverage'' frames are specified or set by default, or if one or both ``coverage'' frames are given but corresponding primary or additional kernels don't contain any data for them, both the coverage window begin time and the coverage window end time must be specified using the ``-b'' and ``-e'' keys because the program has no way to determining the default coverage window. If either ``-b'' or ``-e'' is not provided in such cases, the program signals an error.



Top

Times within Coverage Window



The program picks times within the coverage window based on the number of points specified using the ``-n'' key or the time step specified using the ``-s'' key''.

When neither the number of points is specified using ``-n'' nor the step is specified using ``-s'', the number of points is set to a default value determined by examining the coverage window. If the total number of endpoints -- 2 for each non-singleton interval, 1 for each singleton interval -- for all intervals in the coverage window is greater than 1000, the number of points is set to the number of endpoints and the step is not computed. Otherwise it is set to 1000 or a number less than but close to 1000 (the actual number is determined at run-time based on the lengths of the intervals) and the step is computed by dividing the measure of the coverage window by the number of points minus the number of endpoints.

When the number of points is specified using ``-n'' but this number is less than the number of the coverage window interval endpoints, the value given using ``-n'' is ignored and the number of points is set to the number of interval endpoints and the step is not computed. Otherwise the number of points is set to the value provided using ``-n'' or a number less than but close to this value (the actual number is determined at run time based on the lengths of the intervals) and the step is computed by dividing the measure of the coverage window by the number of points minus the number of endpoints.

When step is specified using ``-s'', the number of points is computed by adding the number of interval endpoints to the total of the numbers of points that can fit within each non-singleton interval when it's stepped through with this step. If the resultant number of points is greater than 1,000,000, the program signals an error.

Whether the step was provided or computed using the provided or default number of points, the set of times at which orientation is computed includes all interval ends -- 2 for each non-singleton interval, 1 for each singleton interval -- plus additional points computed by stepping with this step within each non-singleton interval starting from the interval start time. The last point within each non-singleton interval is computed such that it always lies inside the 1.5*step to 0.5*step range off the interval end.

Care should be taken when picking the step using ``-s'' or specifying the number of points using ``-n''. Picking a very small step for a large time window, or very many points for any window, leads to very long run times. In some cases the number of points computed using the step may even be greater that 1,000,000, preventing the program from running because its buffers are not large enough to deal with so many points. On the other hand, picking a large step or too few points prevents the program from doing a thorough comparison.



Top

Angular Velocities




The ``-a'' key is used to tell the program to compute angular velocities in addition to orientations. When the value provided using ``-a'' is ``yes'', the program computes angular velocities and reports them or their differences along with the orientation or orientation differences. If the key is omitted or set to ``no'', the program does not compute angular velocities. For any value other than ``yes'' or ``no'' the program reports an error.

If the program samples or compares angular velocities (``-a yes''), the ``-m'' key is used to specify whether they or their differences should be reported in the ``from'' frame(s) or the ``to'' frame(s). When the value provided using the ``-m'' key is ``to'', the program reports angular velocities or their differences in the ``to'' frames. If the key is omitted or set to ``from'', the program reports angular velocities or their differences in the ``from'' frames. For any value other than ``to'' or ``from'' the program reports an error.

In order for the program to compute angular velocities the data provided to it must support this computation. This is not an issue for any frames except for CK-based frames. Therefore, when using CK files, whether as primary or as additional kernels, it's important to make sure that these CKs include angular velocities before requesting the program to compute angular velocities.



Top

Output





In a successful run the program prints to the screen a report consisting of the report header and report data. The report header provides the complete information about kernels and control parameters used by the program. The report data provides information about the orientation and angular velocity differences (for comparison runs) or orientations and angular velocities (for sampling reports) in a variety of ways, called report types. The algorithms used to compute orientations and angular velocities and their differences and to convert them to various representations used in the reports are shown in ``Appendix 1''.



Top

Overview of Report Types




The report data can be of one of the following types depending on the value provided using the ``-t'' key:

basic

the basic report including only the maximum and the average rotation angle difference (for comparison runs) or rotation angle (for sampling runs) and, if requested, the maximum and the average angular velocity magnitude difference (for comparison runs) or angular velocity magnitude (for sampling runs). This is the default report displayed when ``-t'' is omitted.
stats

the statistics report including a small set of statistical information on the difference between two frame orientations (for comparison runs) or statistics on a single orientation (for sampling runs). In addition to the items from the basic report (maximums and averages), this report includes RMS of the rotation angle difference/angle and angular velocity difference/angular velocity and the times when the maximum value of the rotation angle difference/angle and the angular velocity difference/angular velocity were found.
dumpaa

the angle and axis dump report containing a table listing the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as the rotation angle and axis and, if requested, the components and the magnitude of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the orientations were computed.
dumpm

the matrix dump report containing a table listing the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as a 3x3 rotation matrix and, if requested, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the orientations were computed.
dumpqs

the SPICE-style quaternion dump report containing a table listing the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as a SPICE-style quaternion and, if requested, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the orientations were computed.
dumpqo

produces the ``other''-style quaternion dump report containing a table listing the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as SPICE-style quaternion and, if requested, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the orientations were computed.
dumpea

the Euler angle dump report containing a table listing the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as three Euler angles and, if requested, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the orientations were computed.
dumpc

the coverage intervals dump report containing a table listing the start and stop times and durations for the intervals inside the coverage window, during which orientation(s) can be computed.
dumpg

the coverage gaps dump report containing a table listing the start and stop times and duration for the gaps inside the coverage window, during which orientation(s) cannot be computed.
The ``basic'' and ``stats'' report are useful for quick assessment of whether and by how much two frame transformations differ (for comparison runs) or of the maximum/average magnitude of one frame transformation (for sampling runs). The ``dumpaa'', ``dumpm'', ``dumpqs'', ``dumpqo'', and ``dumpea'' are useful to capture detailed information about differences of two transformations (in comparison runs) or information about a single transformation (for sampling runs) in various formats as a function of time, for analysis or use in other applications. The ``dumpc'' and ``dumpg'' reports are useful for CK or binary PCK coverage overlap analysis.

All reports have rigid formats. The only items in the reports that can be altered by command line options are:

    -- the format of time tags in all ``dump*'' reports; the time format is changed using the ``-f'' key

    -- the number of significant digits in the output numeric times (TDB seconds past J2000, decimal SCLKs and encoded SCLK ticks) and rotation component values or rotation difference component values included in all ``dump*'' reports; the number of significant digits is changed using the ``-d'' key

    -- units for the angles in the dump reports that include angles (``dumpaa'' and ``dumpea''); the units are changed using the ``-x'' key

    -- the order of rotations in the Euler angles dump report (``dumpea''); the order is changed using the ``-o'' key

    -- absence or presence of angular velocities in all non-coverage related dump reports (``dumpaa'', ``dumpm'', ``dumpqs'', ``dumpqo'', and ``dumpea''); whether angular velocities are included or not is controlled by the ``-a'' key as discussed earlier in this document.



Top

Time Tag Format for ``dump*'' Reports



The format of the time tags in the ``dump*'' reports is controlled using the ``-f'' key. The following values can be provided using ``-f'':

et

to display times as TDB seconds past J2000 (default format when ``-f'' is omitted)
sclk

to display times as string SCLKs
sclkd

to display times as decimal SCLKs
ticks

to display times as encoded SCLK ticks
<PICTUR>

a time format picture acceptable for cspice_timout function. For example:
                    YYYY-MM-DDTHR:MN:SC.### ::RND    for UTC ISO date
                    YYYY-DOYTHR:MN:SC.### ::RND      for UTC ISO DOY
                    JULIAND.######### ::TDB          for Julian day TDB
When one of the SCLK formats (``sclk'', ``sclkd'', ``ticks'') is specified, TDB times used internally by the program are converted to SCLK times using the SCLK ID associated with one of the ``to'' or ``coverage'' CK-based frames in the following priority order (from highest to lowest): first ``to'' frame, first ``coverage'' frame, second ``to'' frame, second ``coverage'' frame. If neither of the ``to'' or ``coverage'' frames is a CK frame, the program signals an error.

When decimal SCLK tags are requested, the SCLK string returned by SPICE's cspice_sce2s function is converted to ``decimal'' SCLK by stripping off the partition, using the left field as the integer part and converting the rest of the fields to the decimal fraction of the left field using the SCLK field values from the string SCLK and SCLK moduli and offsets from the SCLK kernel file. For example, the SCLK string ``1/883612839.255'' that has seconds in the left field and a count of ticks having duration of 1/256 of a second in the right field is converted to this DP SCLK 883612839.996094. This conversion is supported only for type 1 clocks.

When one of the numeric formats (``et'', ``sclkd'', ``ticks'') is specified, times are displayed in the scientific format with 14 significant digits (e.g. +1.2345678901234E+01), unless ``-d'' is used to specify a different number of significant digits.

``-f'' does not apply to times in the report header and the statistics report, in which the times are always displayed as TDBs in calendar and seconds past J2000 numeric (in scientific format with 14 significant digits) formats.



Top

Numeric Format for ``dump*'' Reports



The default format of numeric time tags (TDB seconds past J2000, decimal SCLKs and encoded SCLK ticks), rotation and angular velocity component values, and rotation and angular velocity difference component values in all ``dump*'' reports is the scientific format with 14 significant digits (e.g. +1.2345678901234E+01). A different number of significant digits can be specified using the ``-d'' option as an integer in the range from 6 to 17. If specified, the number of significant digits is used for all numeric items in the ``dump*'' report data part (table) but is not used for any numbers in the table header or in the data part of the non-``dump*'' (``basic'' and ``stats'') reports.

The default format, with 14 significant digits, is usually adequate for output from all comparison runs and from all sampling runs that are intended to produce tables of rotations or rotation differences for plotting but, due to round off, it may not be adequate for sampling runs that are intended to generate tables of quaternions, angles, or matrices for subsequent interpolation or packaging into CK files. For such outputs the number of significant digits should be increased to 16 -- if output rotations are planned to be packaged into an CK file using the MSOPCK program that employs a custom parser to ingest input numeric data -- or 17 -- if output rotations will read by an application that uses language-native means to parse input numeric data.



Top

Angle Units for ``dumpaa'' and ``dumpea'' Reports



The angles in the ``dumpaa'' and ``dumpea'' reports can be displayed using one of the following units depending on the value provided using the ``-x'' key:

                    radians (default)
                    degrees
                    arcminutes
                    arcseconds
                    hourangle
                    minuteangle
                    secondangle
``-f'' applies neither to the angles in the basic and statistics reports (in which the angles are always displayed in radians) nor to angular velocities in any reports (which are always displayed in radians per second).



Top

Report Header




The top portion of each report generated by the program is occupied by the report header providing complete information about the kernels and control parameters used by the program. The format and the set of information provided in the report header depends on

    -- the type of run (comparison vs. sampling)

    -- the type of report (data dump, coverage dump, etc.)

    -- the set of kernels that were provided

    -- whether angular velocities were computed

    -- and various miscellaneous control parameters.

All lines in the report header have

   #
as the first character. This allows common plotting programs, such as GNUPLOT, to skip these header lines when plotting the ``dump''-type reports generated by the program.



Top

Report Header for Comparing Two Orientations



For runs comparing two orientations the report header has the following format (the line numbers given on the left are not present in the actual report; they are provided for referencing purposes only):

    1  #
    2  # Comparison of N rotations
    3  #
    4  #    from 'FROM1NAME' (FROM1ID) to 'TO1NAME' (TO1ID)
    5  #    computed using
    6  #
    7  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
    8  #       -K1/KERNEL1 -K1/KERNEL2 ... -K1/KERNELm
    9  #       FIRSTKERNEL
   10  #
   11  # with N rotations
   12  #
   13  #    from 'FROM2NAME' (FROM2ID) to 'TO2NAME' (TO2ID)
   14  #    computed using
   15  #
   16  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
   17  #       -K2/KERNEL1 -K2/KERNEL2 ... -K2/KERNELm
   18  #       SECONDKERNEL
   19  #
   20  # with a S second (DDDAYS:HR:MN:SC.MSECND) step size
   21  # within the continuous time period
   22  #
   23  #    from 'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   24  #    to   'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   25  #
   26  # including differences in AVs relative to the FRAME frames.
   27  #
   28  # TIMESPEC.
   29  #
where:

    -- on lines 2 and 11 ``N'' is replaced with the actual number of comparison points

    -- on lines 4 and 13 ``FROM1NAME'', ``FROM1ID'', ``TO1NAME'', ``TO1ID'', ``FROM2NAME'', ``FROM2ID'', ``TO2NAME'', and ``TO2ID'' are replaced with the actual names/IDs used to compute transformations for comparison

    -- lines 7, 8, 9, 16, 17, and 18 contain lists of additional kernels provided using the ``-k'', ``-k1'', and ``-k2'' keys and primary kernels provided at the end of the command line, listed in the order in which they were loaded by the program. These lines are present only when corresponding kernel files are given on the command line.

    -- on line 20 the actual step replaces ``S'' and ``DDDAYS:HR:MN:SC.MSECND'' (step expressed as days, hours, minutes, seconds). If transformations are computed only at the interval endpoints, the whole line is replaced with the following string: ``at continuous coverage intervals' endpoints''

    -- line 21 has the form shown above when there are no gaps in coverage window. Otherwise the whole line is replaced with the following string: ``within the non-continuous (with M gaps) time period'' where ``M'' is replaced with the actual number of gaps.

    -- on lines 23 and 24 times are replaced with the first and last times from the set of times for which the comparison was made.

    -- lines 26 and 27 are displayed only when angular velocities are compared. The FRAME is set to ``from'' or ``to'' depending on the frame in which the angular velocity difference is reported.

    -- line 28 and 29 are displayed for all report types except ``basic'' and ``stats''. Depending on the output time type specified using the ``-f'' key TIMESPEC is replaced with one of the following strings:

            -f et       ``Times are TDB seconds past J2000.''
 
            -f sclk     ``Times are SCLKs computed using SCLK
                        ID <nnn>.''
 
            -f sclkd    ``Times are decimal SCLKs computed using
                        SCLK ID <nnn>.''
 
            -f ticks    ``Times are SCLK ticks computed using
                        SCLK ID <nnn>.''
 
            -f PICTURE  ``Times were generated by TIMOUT using
                        '<format>' format.''
    where ``nnn'' is replaced with the SCLK ID used to convert TDB to SCLK.



Top

Report Header for Coverage/Gaps for Two Orientations



For runs displaying coverage or gaps in coverage for two orientations the report header has the following format (the line numbers given on the left are not present in the actual report; they are provided only for referencing purposes):

    1  #
    2  # Coverage overlap for rotation
    3  #
    4  #    from 'FROM1NAME' (FROM1ID) to 'TO1NAME' (TO1ID)
    5  #    computed using
    6  #
    7  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
    8  #       -K1/KERNEL1 -K1/KERNEL2 ... -K1/KERNELm
    9  #       FIRSTKERNEL
   10  #
   11  # and rotation
   12  #
   13  #    from 'FROM2NAME' (FROM2ID) to 'TO2NAME' (TO2ID)
   14  #    computed using
   15  #
   16  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
   17  #       -K2/KERNEL1 -K2/KERNEL2 ... -K2/KERNELm
   18  #       SECONDKERNEL
   19  #
   20  # with a S second (DDDAYS:HR:MN:SC.MSECND) step size
   21  # within the continuous time period
   22  #
   23  #    from 'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   24  #    to   'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   25  #
   26  # TIMESPEC.
   27  #
where:

    -- on lines 4 and 13 ``FROM1NAME'', ``FROM1ID'', ``TO1NAME'', ``TO1ID'', ``FROM2NAME'', ``FROM2ID'', ``TO2NAME'', and ``TO2ID'' are replaced with the actual names/IDs used to compute transformations for comparison

    -- lines 7, 8, 9, 16, 17, and 18 contain lists of additional kernels provided using the ``-k'', ``-k1'', and ``-k2'' keys and primary kernels provided at the end of the command line, listed in the order in which they were loaded by the program. These lines are present only when corresponding kernel files are given on the command line.

    -- on line 20 the actual step replaces ``S'' and ``DDDAYS:HR:MN:SC.MSECND'' (step expressed as days, hours, minutes, seconds). If transformation is computed only at the interval endpoints, the whole line is replaced with the following string: ``at continuous coverage intervals' endpoints''.

    -- line 21 has the form shown above when there are no gaps in the coverage window. Otherwise the whole line is replaced with the following string: ``within the non-continuous (with M gaps) time period'' where ``M'' is replaced with the actual number of gaps.

    -- on lines 23 and 24 times are replaced with the first and last times from the set of times for which the comparison was made.

    -- on line 26, depending on the output time type specified using the ``-f'' key, ``TIMESPEC'' is replaced with one of the following strings:

            -f et       ``Times are TDB seconds past J2000.''
 
            -f sclk     ``Times are SCLKs computed using SCLK
                        ID <nnn>.''
 
            -f sclkd    ``Times are decimal SCLKs computed using
                        SCLK ID <nnn>.''
 
            -f ticks    ``Times are SCLK ticks computed using
                        SCLK ID <nnn>.''
 
            -f PICTURE  ``Times were generated by TIMOUT using
                        '<format>' format.''
    where ``nnn'' is replaced with the SCLK ID used to convert TDB to SCLK.



Top

Report Header for Sampling an Orientation



For runs sampling an orientation the report header has the following format (the line numbers given on the left are not present in the actual report; they are provided for referencing purposes only):

    1  #
    2  # Sampling of N rotations
    3  #
    4  #    from 'FROMNAME' (FROMID) to 'TONAME' (TOID)
    5  #    computed using
    6  #
    7  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
    8  #       -K1/KERNEL1 -K1/KERNEL2 ... -K1/KERNELm
    9  #       FIRSTKERNEL
   10  #
   11  # with a S second (DDDAYS:HR:MN:SC.MSECND) step size
   12  # within the continuous time period
   13  #
   14  #    from 'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   15  #    to   'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   16  #
   17  # including angular velocities relative to the FRAME frame.
   18  #
   19  # TIMESPEC
   20  #
where:

    -- on line 2 ``N'' is replaced with the actual number of comparison points

    -- on line 4 ``FROMNAME'', ``FROMID'', ``TONAME'', and ``TOID'' are replaced with the actual names/IDs used to compute transformations

    -- lines 7, 8, and 9 contain lists of additional kernels provided using ``-k'' and ``-k1'' (or ``-k2'') keys and the primary kernel provided at the end of the command line, listed in the order in which they were loaded by the program. These lines are present only when the corresponding kernel files are given on the command line.

    -- on line 11 the actual step replaces ``S'' and ``DDDAYS:HR:MN:SC.MSECND'' (step expressed as days, hours, minutes, seconds). If transformation is computed only at the interval endpoints, the whole line is replaced with the following string: ``at continuous coverage intervals' endpoints''

    -- line 12 has the form shown above when there are no gaps in the coverage window. Otherwise the whole line is replaced with the following string: ``within the non-continuous (with M gaps) time period'' where ``M'' is replaced with the actual number of gaps.

    -- on lines 14 and 15 times are replaced with the first and last times from the set of times for which transformation was computed.

    -- lines 17 and 18 are displayed only when angular velocities are computed. The FRAME is set to ``from'' or ``to'' depending on the frame in which the angular velocity is reported.

    -- line 19 and 20 are displayed for all report types except ``basic'' and ``stats''. Depending on the output time type specified using the ``-f'' key TIMESPEC is replaced with one of the following strings:

            -f et       ``Times are TDB seconds past J2000.''
 
            -f sclk     ``Times are SCLKs computed using SCLK
                        ID <nnn>.''
 
            -f sclkd    ``Times are decimal SCLKs computed using
                        SCLK ID <nnn>.''
 
            -f ticks    ``Times are SCLK ticks computed using
                        SCLK ID <nnn>.''
 
            -f PICTURE  ``Times were generated by TIMOUT using
                        '<format>' format.''
    where ``nnn'' is replaced with the SCLK ID used to convert TDB to SCLK.



Top

Report Header for Coverage/Gaps for An Orientation



For runs displaying coverage or gaps in coverage for an orientation the report header has the following format (the line numbers given on the left are not present in the actual report; they are provided for referencing purposes only):

    1  #
    2  # Coverage for rotation
    3  #
    4  #    from 'FROMNAME' (FROMID) to 'TONAME' (TOID)
    5  #    computed using
    6  #
    7  #       -K/KERNEL1  -K/KERNEL2  ... -K/KERNELn
    8  #       -K1/KERNEL1 -K1/KERNEL2 ... -K1/KERNELm
    9  #       FIRSTKERNEL
   10  #
   11  # with a S second (DDDAYS:HR:MN:SC.MSECND) step size
   12  # within the continuous time period
   13  #
   14  #    from 'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   15  #    to   'YYYY MON DD HR:MN:SC.### TDB' (SSS.###### TDB seconds)
   16  #
   17  # TIMESPEC
   18  #
where:

    -- on line 4 ``FROMNAME'', ``FROMID'', ``TONAME'', and ``TOID'' are replaced with the actual names/IDs used to compute transformations.

    -- lines 7, 8, and 9 contain lists of additional kernels provided using the ``-k'' and ``-k1'' (or ``-k2'') keys and the primary kernel provided at the end of the command line, listed in the order in which they were loaded by the program. These lines are present only when the corresponding the kernel files are given on the command line.

    -- on line 11 the actual step replaces ``S'' and ``DDDAYS:HR:MN:SC.MSECND'' (step expressed as days, hours, minutes, seconds). If transformation is computed only at the interval endpoints, the whole line is replaced with the following string: ``at continuous coverage intervals' endpoints''

    -- line 12 has the form shown above when there are no gaps in the coverage window. Otherwise the whole line is replaced with the following string: ``within the non-continuous (with M gaps) time period'' where ``M'' is replaced with the actual number of gaps.

    -- on lines 14 and 15 times are replaced with the first and last times from the set of times for which transformation was computed.

    -- on line 17, depending on the output time type specified using the ``-f'' key TIMESPEC is replaced with one of the following strings:

            -f et       ``Times are TDB seconds past J2000.''
 
            -f sclk     ``Times are SCLKs computed using SCLK
                        ID <nnn>.''
 
            -f sclkd    ``Times are decimal SCLKs computed using
                        SCLK ID <nnn>.''
 
            -f ticks    ``Times are SCLK ticks computed using
                        SCLK ID <nnn>.''
 
            -f PICTURE  ``Times were generated by TIMOUT using
                        '<format>' format.''
    where ``nnn'' is replaced with the SCLK ID used to convert TDB to SCLK.



Top

Report Formats






Top

Basic Report (no ``-t'' or ``-t basic'')



The basic report indicates if the two frame transformations are different, or if a single transformation is a non-zero transformation, by displaying only the maximum and the average rotation angle difference (for comparison runs) or rotation angle (for sampling runs) and, if requested using the ``-a'' key, the maximum and the average angular velocity magnitude difference (for comparison runs) or angular velocity magnitude (for sampling runs).

The basic report has the following format:

 
   Absolute difference magnitudes:
 
                                       maximum             average
 
     Rotation (rad):                  MAX_ANGLE         AVERAGE_ANGLE
     Angular Velocity (rad/s):        MAX_RATE          AVERAGE_RATE
 
where:

    -- ``MAX_ANGLE'', ``AVERAGE_ANGLE'', ``MAX_RATE'', ``AVERAGE_RATE'' are the maximum and average rotation angle difference (for comparison runs) or angle (for sampling runs) and angular velocity difference (for comparison runs) or angular velocity magnitude (for sampling runs) determined for the set of frame transformation differences or frame transformations computed by the program within the coverage window.

    -- The word ``difference'' is omitted from the ``Absolute difference magnitudes:'' line when the program is run in sampling mode.

    -- The line ``Angular Velocity ...'' is omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').

    -- All ``*ANGLE'' and ``*RATE'' values are printed in the ``x.xxxxxxxxxxxxxE+xx'' format.

    -- All ``*ANGLE'' values are always printed in radians (i.e. units specified using the ``-x'' key have no effect on the values in this report).

    -- All ``*RATE'' values are always printed in radians per second.

    -- Neither the custom time format specified using ``-f'' nor the number of significant digits specified using ``-d'' apply to this report.



Top

Statistics Report (``-t stats'')



The statistics report provides a small set of statistical information on the difference of two frame transformations (for comparison runs) or a single transformation (for sampling runs). It includes the same items as the basic report (maximums and averages) plus a few additional parameters such as RMS of the rotation angle difference/angle and angular velocity difference/angular velocity and the times when the maximum value of the rotation angle difference/angle and angular velocity difference/angular velocity were found.

The statistics report has the following format:

 
   1) Average difference
 
      1a) Rotation (rad):                               AVERAGE_ANGLE
 
      1b) Angular velocity (rad/s):                     AVERAGE_RATE
 
 
   2) RMS of difference
 
      2a) Rotation (rad):                               RMS_OF_ANGLE
 
      2b) Angular velocity (rad/s):                     RMS_OF_RATE
 
 
   3) Maximum rotation difference
 
      3a) Rotation (rad):                               MAX_ANGLE
 
      3b) Epoch (TDB, seconds past J2000):              TDB_SECONDS
 
      3c) Epoch (TDB, calendar format):         YYYY-MON-DD-HR:MN:SC.MMM
 
 
   4) Maximum angular velocity difference
 
      4a) Angular velocity (rad/s):                     MAX_RATE
 
      4b) Epoch (TDB, seconds past J2000):              TDB_SECONDS
 
      4c) Epoch (TDB, calendar format):         YYYY-MON-DD-HR:MN:SC.MMM
 
where:

    -- ``MAX_ANGLE'', ``AVERAGE_ANGLE'', ``RMS_OF_ANGLE'', ``MAX_RATE'', ``AVERAGE_RATE'', ``RMS_OF_RATE'' are the maximum, average, and RMS of rotation angle difference (for comparison runs) or angle (for sampling runs) and angular velocity difference (for comparison runs) or angular velocity magnitude (for sampling runs) determined for the set of frame transformation differences or frame transformations computed by the program within the coverage window. ``TDB_SECONDS'' and ``YYYY-MON-DD-HR:MN:SC.MMM'' are the times, as TDB seconds past J2000 and TDB in calendar date format, when the maximums were found.

    -- The word ``difference'' is omitted from the lines starting with ``1)'', ``2)'', ``3)'', and ``4)'' when the program is run in sampling mode.

    -- All lines pertaining to angular velocity are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').

    -- All ``*ANGLE'' and ``*RATE'' values are printed in ``x.xxxxxxxxxxxxxE+xx'' format.

    -- All ``*ANGLE'' values are always printed in radians (i.e. units specified using the ``-x'' key have no effect on the values in this report).

    -- All ``*RATE'' values are always printed in radians per second.

    -- ``TDB_SECONDS'' are printed in the ``xxxxxxxxxx.xxxxxx'' format.

    -- Neither the custom time format specified using ``-f'' nor the number of significant digits specified using ``-d'' apply to this report.



Top

Angle and Axis Dump Report (``-t dumpaa'')



The angle and axis dump report displays the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as the rotation angle and axis and, if requested using the ``-a'' key, the components and the magnitude of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the frame transformations were computed. The angle is displayed in units specified using the ``-x'' key -- ``radians'' (default), ``degrees'', ``arcminutes'', ``arcseconds'', ``hourangle'', ``minuteangle'', or ``secondangle''. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in this document.

The angle and axis dump report has the following format:

   # angle is shown in UNITS.
   #
   # time, angle, axis_x, axis_y, axis_z, av_x, av_y, av_z, av_magnitude
   TIME ANGLE AXIS(1) AXIS(2) AXIS(3) AV(1) AV(2) AV(3) |AV|
   ...
   TIME ANGLE AXIS(1) AXIS(2) AXIS(3) AV(1) AV(2) AV(3) |AV|
where:

    -- Items on each data line are separated by spaces.

    -- All items except TIME are printed in the ``+x.xxxxxxxxxxxxxE+xx'' format, either with the default 14 significant digits or with the number of significant digits specified using the ``-d'' option. TIME is displayed in the format specified using the ``-f'' key.

    -- The ANGLE is displayed in units specified using the ``-x'' key. The AV components and magnitude are always displayed in radians per second.

    -- The AV difference/AV components and the corresponding labels in the table header line are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').

    -- UNITS is replaced with the units used to display the angles.



Top

Matrix Dump Report (``-t dumpm'')



The matrix dump report displays the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as a 3x3 rotation matrix and, if requested using the ``-a'' key, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the frame transformations were computed. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in this document.

The matrix dump report has the following format:

   # time, m11, m12, m13, m21, m22, m23, m31, m32, m33, av_x, av_y, av_z
   TIME M11 M12 M13 M21 M22 M23 M31 M32 M33 AV(1) AV(2) AV(3)
   ...
   TIME M11 M12 M13 M21 M22 M23 M31 M32 M33 AV(1) AV(2) AV(3)
where:

    -- Items on each data line are separated by spaces.

    -- All items except TIME are printed in the ``+x.xxxxxxxxxxxxxE+xx'' format, either with the default 14 significant digits or with the number of significant digits specified using the ``-d'' option. TIME is displayed in the format specified using the ``-f'' key.

    -- The AV components are always displayed in radians per second.

    -- The AV difference/AV components and the corresponding labels in the table header line are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').



Top

SPICE-Style Quaternion Dump Report (``-t dumpqs'')



The SPICE-style quaternion dump report displays the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as a SPICE-style quaternion and, if requested using the ``-a'' key, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which the frame transformations were computed. The time tag is displayed in the format specified using the ``-f'' key, discussed earlier in this document.

The SPICE-style quaternion dump report has the following format:

   # time, q_cos, q_sin1, q_sin2, q_sin3, av_x, av_y, av_z
   TIME QS(1) QS(2) QS(3) QS(4) AV(1) AV(2) AV(3)
   ...
   TIME QS(1) QS(2) QS(3) QS(4) AV(1) AV(2) AV(3)
where:

    -- Items on each data line are separated by spaces.

    -- All items except TIME are printed in the ``+x.xxxxxxxxxxxxxE+xx'' format, either with the default 14 significant digits or with the number of significant digits specified using the ``-d'' option. TIME is displayed in the format specified using the ``-f'' key.

    -- The AV components are always displayed in radians per second.

    -- The AV difference/AV components and the corresponding labels in the table header line are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').



Top

``Other''-Style Quaternion Dump Report (``-t dumpqo'')



The ``other''-style quaternion dump report displays the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as the ``other''-style (or engineering-style) quaternion and, if requested using the ``-a'' key, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling reports), along with the time, for each of the times at which frame transformations were computed. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in the document.

The ``other''-style quaternion dump report has the following format:

   # time, q_sin1, q_sin2, q_sin3, q_cos, av_x, av_y, av_z
   TIME QO(1) QO(2) QO(3) QO(4) AV(1) AV(2) AV(3)
   ...
   TIME QO(1) QO(2) QO(3) QO(4) AV(1) AV(2) AV(3)
where:

    -- Items on each data line are separated by spaces.

    -- All items except TIME are printed in the ``+x.xxxxxxxxxxxxxE+xx'' format, either with the default 14 significant digits or with the number of significant digits specified using the ``-d'' option. TIME is displayed in the format specified using the ``-f'' key.

    -- The AV components are always displayed in radians per second.

    -- The AV difference/AV components and the corresponding labels in the table header line are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').



Top

Euler Angles Dump Report (``-t dumpea'')



The Euler angles dump report displays the orientation difference (for comparison runs) or orientation (for sampling runs) expressed as three Euler angles and, if requested using the ``-a'' key, the components of the angular velocity difference (for comparison runs) or angular velocity (for sampling runs), along with the time, for each of the times at which frame transformations were computed. The order of rotations is specified using the ``-o'' key as sequence of three axes from the set of ``X'', ``Y'', ``Z'' (case-insensitive), separated by spaces. The second axis in the sequence must differ from the first and third axes. When ``-o'' is not provided, the default order is set to ``Z Y X''. The angles are displayed in the units specified using the ``-x'' key -- ``radians'' (default), ``degrees'', ``arcminutes'', ``arcseconds'', ``hourangle'', ``minuteangle'', or ``secondangle''. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in this document.

The Euler angles dump report has the following format:

   # angles are shown in UNITS
   #
   # time, angle_AXIS3, angle_AXIS2, angle_AXIS1, av_x, av_y, av_z
   TIME ANGLE3 ANGLE2 ANGLE1 AV(1) AV(2) AV(3)
   ...
   TIME ANGLE3 ANGLE2 ANGLE1 AV(1) AV(2) AV(3)
where:

    -- Items on each data line are separated by spaces.

    -- All items except TIME are printed in the ``+x.xxxxxxxxxxxxxE+xx'' format, either with the default 14 significant digits or with the number of significant digits specified using the ``-d'' option. TIME is displayed in the format specified using the ``-f'' key.

    -- The ANGLEs are displayed in the units specified using the ``-x'' key. The AV components are always displayed in radians per second.

    -- The AV difference/AV components and the corresponding labels in the table header line are omitted when AVs are not compared/sampled (no ``-a'' or ``-a no'').

    -- UNITS is replaced with the units used to display angles.

    -- ``AXIS1'', ``AXIS2'', ``AXIS3'' are replaced with the corresponding axis labels (X,Y, or Z).



Top

Coverage Intervals Dump Report (``-t dumpc''):



The coverage intervals dump report displays the start and stop times for the intervals inside the coverage window, during which frame transformations can be computed. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in the document.

The coverage intervals dump report has the following format:

   # int_start_time, int_end_time, int_duration_sec, int_duration_string
   STARTTIME STOPTIME SECONDS DAYS:HR:MN:SC.MMMMMM
   ...
   STARTTIME STOPTIME SECONDS DAYS:HR:MN:SC.MMMMMM
where:

    -- Items on each data line are separated by spaces.

    -- The interval durations are printed as seconds in the ``xxxxxxxxxxxx.xxxxxx'' format (replaces SECONDS) and in days, hours, minutes, seconds format (replaces DAYS:HR:MN:SC.MMMMMM). The STARTTIMEs and STOPTIMEs are displayed in the format specified using the ``-f'' key.



Top

Coverage Gaps Dump Report (``-t dumpg'')



The coverage gaps dump report displays the start and stop times for the gaps inside the coverage window, during which frame transformations cannot be computed. The time tags are displayed in the format specified using the ``-f'' key, discussed earlier in this document.

The coverage gaps dump report has the following format:

   # gap_start_time, gap_end_time, gap_duration_sec, gap_duration_string
   STARTTIME STOPTIME SECONDS DAYS:HR:MN:SC.MMMMMM
   ...
   STARTTIME STOPTIME SECONDS DAYS:HR:MN:SC.MMMMMM
    -- Items on each data line are separated by spaces.

    -- The gap durations are printed as seconds in the ``xxxxxxxxxxxx.xxxxxx'' format (replaces SECONDS) and in days, hours, minutes, seconds format (replaces DAYS:HR:MN:SC.MMMMMM). The STARTTIMEs and STOPTIMEs are displayed in the format specified using the ``-f'' key.

    -- If the coverage window has no gaps, the string ``There are no gaps in coverage.'' is printed instead of the data records.



Top

Examples





The examples below illustrate some of the common FRMDIFF usage scenarios. In all examples the files are assumed to be in the current directory, the FRMDIFF command lines, which usually occupy a single line, span multiple lines and use the UNIX shell style continuation character (backslash), and the report lines are truncated to fit the width of the page (``...'' at the end of a line indicates that it was truncated).



Top

Checking if Two CKs Provide the Same Orientation




In this example the program is run to check if the daily reconstructed MRO CK ``mro_sc_2009-01-26.bc'' and the weekly reconstructed MRO CK ``mro_sc_psp_090120_090126.bc'' provide the same data. The CK files are provided as primary kernels to make the program run in comparison mode. The LSK ``naif0009.tls'' and SCLK ``MRO_SCLKSCET.00027.tsc'', required to support time conversions, and the FK ``mro_v13.tf'', required because it defines the MRO spacecraft frame and the frame used as the base frame in the CKs, apply to both CKs and, therefore, are provided using the ``-k'' key. To make sure the comparison is thorough the step is set to 1 second using the ``-s'' key. No other options need to be specified because the primary kernels are CKs, which the program can examine to automatically pick the ``from'' and ``to'' frames and the coverage window. The basic report displaying the maximum difference will suffice for this case; therefore, there is no need to specify the ``-t'' option.

   % frmdiff -k naif0009.tls MRO_SCLKSCET.00027.tsc mro_v13.tf \
             -s 1 \
             mro_sc_2009-01-26.bc mro_sc_psp_090120_090126.bc
   # int_start_time, int_end_time, int_duration_sec, int_duration_string
   #
   # Comparison of 86401 rotations
   #
   #    from 'MRO_MME_OF_DATE' (-74900) to 'MRO_SPACECRAFT' (-74000)
   #    computed using
   #
   #       naif0009.tls MRO_SCLKSCET.00027.tsc mro_v13.tf
   #       mro_sc_2009-01-26.bc
   #
   # with 86401 rotations
   #
   #    from 'MRO_MME_OF_DATE' (-74900) to 'MRO_SPACECRAFT' (-74000)
   #    computed using
   #
   #       naif0009.tls MRO_SCLKSCET.00027.tsc mro_v13.tf
   #       mro_sc_psp_090120_090126.bc
   #
   # with a 1.0000000000000 second (0:00:00:01.000000) step size
   # within the continuous time period
   #
   #    from '2009 JAN 26 00:01:06.261' TDB (286200066.26113 TDB seco...
   #    to   '2009 JAN 27 00:01:06.024' TDB (286286466.02413 TDB seco...
   #
 
   Absolute difference magnitudes:
 
                                        maximum                 avera...
 
     Rotation (rad):             +0.0000000000000E+00      +0.0000000...
 
The zero maximum rotation difference indicates that these two CKs provide the same data.



Top

Comparing Predicted and Reconstructed CKs




In this example the program is run to assess, for a specified period of time, the difference of the spacecraft orientation provided by the predicted CASSINI spacecraft CK ``09009_09025pa_fsiv_lud2.bc'' and the reconstructed CASSINI spacecraft CK ``09006_09011ra.bc''. The CK files are provided as primary kernels to make the program run in comparison mode. The LSK ``naif0009.tls'' and the SCLK ``cas00130.tsc'', required to support time conversions, and the FK ``cas_v40.tf'', required because it defines the CASSINI spacecraft frame, apply to both CKs and, therefore, are provided using the ``-k'' key. The angle and axis dump report is requested using ``-t dumpaa'' and the step is set to 10 seconds using ``-s 10''. The time boundaries for the period of interest are specified using ``-b'' and ``-e''. No other options need to be specified because the primary kernels are CKs, which the program can examine to automatically pick the ``from'' and ``to'' frames and the default coverage window (which is intersected with the window of interest specified using ``-b'' and ``-e''). The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k naif0009.tls cas00130.tsc cas_v40.tf \
             -s 10 -b 2009-JAN-09 00:00 -e 2009-JAN-10 00:00 -t dumpaa \
             09009_09025pa_fsiv_lud2.bc 09006_09011ra.bc \
             > output.txt
   % cat output.txt
   #
   # Comparison of 3143 rotations
   #
   #    from 'J2000' (1) to 'CASSINI_SC_COORD' (-82000)
   #    computed using
   #
   #       naif0009.tls cas00130.tsc cas_v40.tf
   #       09009_09025pa_fsiv_lud2.bc
   #
   # with 3143 rotations
   #
   #    from 'J2000' (1) to 'CASSINI_SC_COORD' (-82000)
   #    computed using
   #
   #       naif0009.tls cas00130.tsc cas_v40.tf
   #       09006_09011ra.bc
   #
   # with a 10.000000000000 second (0:00:00:10.000000) step size
   # within the non-continuous (with 1 gaps) time period
   #
   #    from '2009 JAN 09 15:17:06.359' TDB (284786226.35996 TDB seco...
   #    to   '2009 JAN 10 00:01:06.184' TDB (284817666.18419 TDB seco...
   #
   # Times are TDB seconds past J2000.
   #
   # angle is shown in radians.
   #
   # time, angle, axis_x, axis_y, axis_z
   +2.8478622635996E+08 +5.4958832051797E-05 +8.2101753099566E-01 +4....
   +2.8478623635996E+08 +5.4931030131424E-05 +8.2046010733260E-01 +4....
   +2.8478624635996E+08 +5.4903290577181E-05 +8.1990116349661E-01 +4....
   ...
   +2.8481765833081E+08 +2.3714852496640E-05 +4.7607884330795E-01 -8....
   +2.8481766618419E+08 +1.7506382825421E-05 -3.3218433215999E-01 -6....
The orientation difference expressed as the rotation angle (column 2) can be plotted against TDB seconds (column 1) for analysis.

Note that the time window shown in the report header is different from the requested window specified using the ``-b'' and ``-e'' options. The reason for that is the lack of coverage for the requested windows in one of the CKs (``09009_09025pa_fsiv_lud2.bc'').

To find out when the difference between two orientations is the greatest without plotting the difference as suggested above, the program can be re-run with the same options to generate a statistics report (``-t stats''). For such a run it makes sense to also decrease the time step in order to determine the time of interest more accurately, for example by setting the step to 1 second (``-s 1'').

   % frmdiff -k naif0009.tls cas00130.tsc cas_v40.tf \
             -s 1 -b 2009-JAN-09 00:00 -e 2009-JAN-10 00:00 -t stats \
             09009_09025pa_fsiv_lud2.bc 09006_09011ra.bc
   #
   # Comparison of 31414 rotations
   #
   #    from 'J2000' (1) to 'CASSINI_SC_COORD' (-82000)
   #    computed using
   #
   #       naif0009.tls cas00130.tsc cas_v40.tf
   #       09009_09025pa_fsiv_lud2.bc
   #
   # with 31414 rotations
   #
   #    from 'J2000' (1) to 'CASSINI_SC_COORD' (-82000)
   #    computed using
   #
   #       naif0009.tls cas00130.tsc cas_v40.tf
   #       09006_09011ra.bc
   #
   # with a 1.0000000000000 second (0:00:00:01.000000) step size
   # within the non-continuous (with 1 gaps) time period
   #
   #    from '2009 JAN 09 15:17:06.359' TDB (284786226.35996 TDB seco...
   #    to   '2009 JAN 10 00:01:06.184' TDB (284817666.18419 TDB seco...
   #
 
   1) Average difference
 
      1a) Rotation (rad):                               0.00007738559...
 
 
   2) RMS of difference
 
      2a) Rotation (rad):                               0.00016380723...
 
 
   3) Maximum rotation difference
 
      3a) Rotation (rad):                               0.00098956656...
 
      3b) Epoch (TDB, seconds past J2000):              284788762.33081
 
      3c) Epoch (TDB, calendar format):         2009-JAN-09-15:59:22.330
 
As seen in the report the maximum difference between orientations provided by these CKs between 2009-JAN-09 15:17:06 TDB and 2009-JAN-10 00:01:06 TDB is about 1 milliradian near 2009-JAN-09 15:59:22 TDB.



Top

Comparing Orientations from a CK Read Using Different SCLKs




In this example the program is run to assess the effect that using an out-of-date SCLK kernel has on the 2001 Mars Odyssey spacecraft orientation computed from the M01 CK file ``m01_sc_2009-01-27.bc''. To make the program run in comparison mode, the current SCLK ``ORB1_SCLKSCET.00157.tsc'' and the out-of-date SCLK ``ORB1_SCLKSCET.00147.tsc'' are provided using the ``-k1'' and ``-k2'' keys while the CK is provided as the only primary kernel. (Alternatively, the SCLK kernels could be provided as two primary kernels while the CK could be provided using the ``-k'' key, in which case the ``from'' and ``to'' frames and the coverage boundaries would have to be specified because the program would not be able to determine defaults from the SCLK kernels.) The LSK ``naif0009.tls'', required to support time conversions, and the FK ``m01_v28.tf'', required because it defines the M01 spacecraft frame, are provided using the ``-k'' key. The angle and axis dump report is requested using ``-t dumpaa'' and the step size is set to 10 seconds using ``-s 10''. No other options need to be specified because the primary kernel is a CK, which the program can examine to automatically pick the ``from'' and ``to'' frames and the default coverage window. The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k naif0009.tls m01_v28.tf \
             -k1 ORB1_SCLKSCET.00157.tsc \
             -k2 ORB1_SCLKSCET.00147.tsc \
             -s 10 -t dumpaa \
             m01_sc_2009-01-27.bc \
             > output.txt
   % cat output.txt
   #
   # Comparison of 8283 rotations
   #
   #    from 'MARSIAU' (16) to 'M01_SPACECRAFT' (-53000)
   #    computed using
   #
   #       naif0009.tls m01_v28.tf
   #       ORB1_SCLKSCET.00157.tsc
   #       m01_sc_2009-01-27.bc
   #
   # with 8283 rotations
   #
   #    from 'MARSIAU' (16) to 'M01_SPACECRAFT' (-53000)
   #    computed using
   #
   #       naif0009.tls m01_v28.tf
   #       ORB1_SCLKSCET.00147.tsc
   #       m01_sc_2009-01-27.bc
   #
   # with a 10.000000000000 second (0:00:00:10.000000) step size
   # within the non-continuous (with 2 gaps) time period
   #
   #    from '2009 JAN 27 00:01:07.301' TDB (286286467.30114 TDB seco...
   #    to   '2009 JAN 28 00:01:03.083' TDB (286372863.08345 TDB seco...
   #
   # Times are TDB seconds past J2000.
   #
   # angle is shown in radians.
   #
   # time, angle, axis_x, axis_y, axis_z
   +2.8628646730114E+08 +1.6811778261922E-04 -1.6518133891799E-03 -1....
   +2.8628647730114E+08 +1.6807590586987E-04 -2.5417591048513E-03 -9....
   ...
   +2.8637285336657E+08 +1.5490156847677E-04 -1.0767849826583E-03 -1....
   +2.8637286308345E+08 +1.5459290844816E-04 +5.3342008940173E-05 +1....
The orientation difference expressed as rotation angle (column 2) can be plotted against TDB seconds (column 1) for analysis.



Top

Comparing Binary and Text PCKs




In this example the program is run to compare Earth orientations provided by the high precision Earth orientation binary PCK file ``earth_000101_090421_090128.bpc'' and the low precision Earth orientation text PCK file ``pck00008.tpc''. The PCK files are specified as two primary kernels to make the program run in comparison mode. For this run both ``to'' frames must be specified because the frame associated with the high precision orientation -- ``ITRF93'' -- is different from the frame associated with the low precision orientation -- ``IAU_EARTH''. These two frames are provided using the ``-t1'' and ``-t2'' keys. Note that neither the coverage boundaries nor the ``from'' frames need to be specified because the program can set them to default values obtained by examining the binary PCK. The step is set to 1 hour (``-s 3600'') and the report type is picked to be the Euler angle dump (``-t dumpea'') with the rotation axis order Z,Y,X (``-o z y x''). Reporting differences as Euler angles might be desirable in this case because the angles will show how much of the difference is in the pole tilt (combination of angles about X and Y) and how much of it is in the rotation about the pole (angle about Z). The ``-x'' option used to report angles in degrees (``-x degrees''). The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -t1 ITRF93 -t2 IAU_EARTH \
             -s 3600 -t dumpea -o Z Y X -x degrees \
             earth_000101_090421_090128.bpc pck00008.tpc \
             > output.txt
   % cat output.txt
   #
   # Comparison of 81553 rotations
   #
   #    from 'ECLIPJ2000' (17) to 'ITRF93' (13000)
   #    computed using
   #
   #       earth_000101_090421_090128.bpc
   #
   # with 81553 rotations
   #
   #    from 'ECLIPJ2000' (17) to 'IAU_EARTH' (10013)
   #    computed using
   #
   #       pck00008.tpc
   #
   # with a 3600.0000000000 second (0:01:00:00.000000) step size
   # within the continuous time period
   #
   #    from '2000 JAN 01 00:01:04.183' TDB (-43135.816087188 TDB sec...
   #    to   '2009 APR 21 00:01:06.185' TDB (293544066.18557 TDB seco...
   #
   # Times are TDB seconds past J2000.
   #
   # angles are shown in degrees.
   #
   # time, ang3_about_Z, ang2_about_Y, ang1_about_X
   -4.3135816087188E+04 +4.6935841900452E-02 -1.3237283886873E-03 -1....
   -3.9535816087188E+04 +4.6935945731300E-02 -8.1268845525487E-04 -2....
   ...
   +2.9354046418391E+08 +5.9885369786058E-02 -1.7263299596662E-03 +1....
   +2.9354406618557E+08 +5.9885381660130E-02 -1.9758128919827E-03 +5....
The Euler angles about Z, Y, and X (column 2, 3, 4) can be plotted against TDB seconds (column 1) for analysis.



Top

Comparing Two Text PCKs




In this example the program is run to compare Mars orientations provided by the text PCK file ``pck00006.tpc'' containing 1994 IAU constants and the text PCK ``pck00008.tpc'' containing IAU 2000 constants. The PCK files are specified as two primary kernels to make the program run in comparison mode. Since both files are neither CKs nor binary PCKs, the ``from'' and ``to'' frames and the time boundaries for coverage window must be specified using the ``-t1'' (or ``-t2''), ``-f1'' (or ``-f2''), and ``-b'' and ``-e'' keys. Since the time boundaries are provided on the command line, the LSK ``naif0009.tls'' required for time conversions must be provided using ``-k'' (either ``-k1'' or ``-k2'' can also be used). The step is set to 1 hour (``-s 3600'') and the report type is picked to be the Euler angles dump (``-t dumpea'') with the rotation axis order Z,Y,X (``-o z y x''). Reporting differences as Euler angles might be desirable in this case because the angles will show how much of the difference is in the pole tilt (combination of angles about X and Y) and how much of it is in the rotation about the pole (angle about Z). The ``-x'' option is used to report angles in degrees (``-x degrees''). The ``-f'' option is used to print times as UTC in ISO date format (``-f YYYY-MM-DDTHR:MN:SC ::RND''). The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k naif0009.tls -f1 J2000 -t1 IAU_MARS \
             -b 2005-01-01 -e 2006-01-01 \
             -t dumpea -o z y x -x degrees \
             -f YYYY-MM-DDTHR:MN:SC ::RND -s 3600 \
             pck00006.tpc pck00008.tpc \
             > output.txt
   % cat output.txt
   #
   # Comparison of 8761 rotations
   #
   #    from 'J2000' (1) to 'IAU_MARS' (10014)
   #    computed using
   #
   #       naif0009.tls
   #       pck00006.tpc
   #
   # with 8761 rotations
   #
   #    from 'J2000' (1) to 'IAU_MARS' (10014)
   #    computed using
   #
   #       naif0009.tls
   #       pck00008.tpc
   #
   # with a 3600.0000000000 second (0:01:00:00.000000) step size
   # within the continuous time period
   #
   #    from '2005 JAN 01 00:01:04.183' TDB (157809664.18393 TDB seco...
   #    to   '2006 JAN 01 00:01:05.183' TDB (189345665.18393 TDB seco...
   #
   # Times were generated by TIMOUT using 'YYYY-MM-DDTHR:MN:SC ::RND'...
   #
   # angles are shown in degrees.
   #
   # time, ang3_about_Z, ang2_about_Y, ang1_about_X
   2005-01-01T00:00:00 +2.7193295981800E-01 +4.3458477098658E-04 +4.0...
   2005-01-01T01:00:00 +2.7193298908895E-01 +3.1750496671468E-04 +5.0...
   ...
   2005-12-31T23:00:00 +2.7218789688912E-01 +3.4616175147429E-04 -4.9...
   2006-01-01T00:00:00 +2.7218792598016E-01 +4.5965878416891E-04 -3.9...
The Euler angles about Z, Y, and X (column 2, 3, 4) can be plotted against UTC (column 1) for analysis.



Top

Sampling Orientation from a CK




In this example the program is run to sample the orientation and angular velocity of Deep Impact Flyby (DIF) spacecraft from the daily CK ``dif_sc_2009-01-27.bc'' every five seconds over the whole period covered by the file and and print the orientation as engineering style quaternions and angular velocities expressed in the spacecraft frame, tagged with DP SCLKs. In addition to the CK file the LSK ``naif0009.tls'' and SCLK ``DIF_SCLKSCET.00036.tsc'', required to support time conversions, and the FK ``di_v17.tf'', required because it defines the DIF spacecraft frame, must be provided to the program. The CK file is provided as the only primary kernel and all other kernels are provided using ``-k'' to make the program run in sampling mode. The step is set to 5 seconds using ``-s 5''. The report type is set to the ``other''-style quaternion dump using ``-t dumpqo''. The output time format is set to DP SCLK using ``-f sclkd''. ``-a yes'' and ``-m to'' are specified to add angular velocities rotated to the spacecraft frame (the ``to'' frame) to the output. No other options need to be specified because the primary kernel is a CK, which the program can examine to automatically pick the ``from'' and ``to'' frames and the coverage window. The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k naif0009.tls DIF_SCLKSCET.00036.tsc di_v17.tf \
             -s 5 -t dumpqo -f sclkd -a yes -m to \
             dif_sc_2009-01-27.bc \
             > output.txt
   % cat output.txt
   #
   # Sampling of 16864 rotations
   #
   #    from 'J2000' (1) to 'DIF_SPACECRAFT' (-140000)
   #    computed using
   #
   #       naif0009.tls DIF_SCLKSCET.00036.tsc di_v17.tf
   #       dif_sc_2009-01-27.bc
   #
   # with a 5.0000000000000 second (0:00:00:05.000000) step size
   # within the non-continuous (with 2 gaps) time period
   #
   #    from '2009 JAN 27 00:01:06.713' TDB (286286466.71354 TDB seco...
   #    to   '2009 JAN 28 00:01:05.346' TDB (286372865.34683 TDB seco...
   #
   # including angular velocities relative to 'to' frame.
   #
   # Times are decimal SCLKs computed using SCLK ID -140.
   #
   # time, q_sin1, q_sin2, q_sin3, q_cos, av_x, av_y, av_z
   2.8628543276953E+08 +6.9350853049532E-01 +3.7594179111024E-01 -6.1...
   2.8628543776953E+08 +6.9350851552324E-01 +3.7594215798843E-01 -6.1...
   ...
   2.8637182501172E+08 +6.9259444035804E-01 +3.8202205741497E-01 -6.0...
   2.8637183010156E+08 +6.9259433874053E-01 +3.8202240378948E-01 -6.0...


Top

Sampling Orientation of a Built-in Frame




In this example the program is run to print the rotation from the ``J2000'' frame to the ``ECLIPJ2000'' frame, both of which are built-in frames. To get this rotation, ``J2000'' is specified using ``-f1'' and ``ECLIPJ2000'' is specified using ``-t1''. While it may seem that no kernels would be needed in this case, it is not true. An LSK must be provided to the program because the time at which the orientation should be computed must be provided on the command line twice using the ``-b'' and ``-e'' keys and this time has to be converted to TDB inside the program. Therefore the program is given the LSK ``naif0009.tls'' using the ``-k'' option and an arbitrary time (``2000-01-01'') twice using the ``-b'' and ``-e'' options. The Euler angle dump report is picked using ``-t dump'' with the axis order X,Y,Z picked using ``-o x y z''. The angles are requested to be printed in degrees using ``-x degrees''.

   % frmdiff -k naif0009.tls \
             -f1 J2000 -t1 ECLIPJ2000 \
             -b 2000-01-01 -e 2000-01-01 \
             -t dumpea -o x y z -x degrees
   #
   # Sampling of 1 rotations
   #
   #    from 'J2000' (1) to 'ECLIPJ2000' (17)
   #    computed using
   #
   #       naif0009.tls
   #
   # at continuous coverage intervals' endpoints
   # within the continuous time period
   #
   #    from '2000 JAN 01 00:01:04.183' TDB (-43135.816087188 TDB sec...
   #    to   '2000 JAN 01 00:01:04.183' TDB (-43135.816087188 TDB sec...
   #
   # Times are TDB seconds past J2000.
   #
   # angles are shown in degrees.
   #
   # time, ang3_about_X, ang2_about_Y, ang1_about_Z
   -4.3135816087188E+04 +2.3439291111111E+01 +0.0000000000000E+00 +0....


Top

Sampling Orientation of a Dynamic Frame




In this example the program is run to sample orientation of the Geocentric Solar Ecliptic frame (``GSE''), a dynamic frame defined in the FK ``RSSD0002.TF'', relative to the ``J2000'' inertial frame and print this orientation as Euler angles tagged with Julian day TDB. The frames are specified using ``-f1'' and ``-t1''. All kernels needed to compute this transformation and convert times -- the FK, LSK ``NAIF0009.TLS'' and SPK ``DE405.BSP'' -- are listed using the ``-k'' key. Since there are no primary kernels, the default coverage window cannot be picked automatically. Therefore the coverage window boundaries are specified using ``-b'' and ``-e''. The step is set to 1 day using ``-s 86400''. The Euler angles dump report is requested using ``-t dumpea''. The time format for output is set to be the Julian day TDB using

   -f 'JULIAND.######### ::TDB''
The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k RSSD0002.TF NAIF0009.TLS DE405.BSP \
             -f1 J2000 -t1 GSE \
             -b 2008-01-01 -e 2009-01-01 -s 86400 \
             -t dumpea -f 'YYYY-MM-DD HR:MN:SC.### ::RND ::TDB' \
             > output.txt
   % cat output.txt
   #
   # Sampling of 367 rotations
   #
   #    from 'J2000' (1) to 'GSE' (1500399)
   #    computed using
   #
   #       RSSD0002.TF ../lsk/NAIF0009.TLS ../spk/DE405.BSP
   #
   # with a 86400.000000000 second (1:00:00:00.000000) step size
   # within the continuous time period
   #
   #    from '2008 JAN 01 00:01:05.183' TDB (252417665.18391 TDB seco...
   #    to   '2009 JAN 01 00:01:06.183' TDB (284040066.18393 TDB seco...
   #
   # Times were generated by TIMOUT using 'JULIAND.######### ::TDB' f...
   #
   # angles are shown in radians.
   #
   # time, ang3_about_Z, ang2_about_Y, ang1_about_X
   2454466.500754400 -1.3994266054604E+00 +1.6337747151270E-06 +4.090...
   2454467.500754400 -1.3816355414305E+00 +1.6343360047251E-06 +4.090...
   ...
   2454831.500754400 -1.4039978657128E+00 +1.8387392674578E-06 +4.090...
   2454832.500766000 -1.3862038203964E+00 +1.8393010792771E-06 +4.090...


Top

Sampling Orientation With Two Different ``Coverage'' Frames




In this example the program is run to sample orientation of the MGS MAG +Y sensor frame, ``MGS_MAG_+Y_SENSOR'', relative to the ``J2000'' inertial frame over two hour period from 2006-04-01 11:00 to 2006-04-01 13:00 (given using ``-b'' and ``-e'') and print this orientation as Euler angles tagged with UTC in ISO-date format. The ``from'' and ``to'' frames are specified using ``-f1'' and ``-t1''. All kernels needed to compute this transformation and convert times are listed in the meta-kernel ``mgs_2006_v01.tm'' from the MGS SPICE PDS data set, specified using the ``-k'' key. Because computing this orientation requires data from MGS solar array CKs and spacecraft CKs, both of which have gaps in coverage, ``-c1'' and ``-c2'' are used to tell the program to look up available coverages for the frames ``MGS_LEFT_SOLAR_ARRAY'' and ``MGS_SPACECRAFT'' associated with data in these CKs and intersect this available coverage with the requested two hour interval to guarantee that the program won't stop from not being able to compute orientation in one of the gaps. The step is set to 1 minute using ``-s 60''. The Euler angles dump report is requested using ``-t dumpea''. The time format for output is set to be the UTC in ISO-date format using

   -f  'YYYY-MM-DDTHR:MN:SC.### ::RND'
The program's output is re-directed to the file ``output.txt'' using the ``>'' shell pipe, with the contents of the file shown using the UNIX ``cat'' command.

   % frmdiff -k  mgs_2006_v01.tm \
             -f1 J2000 \
             -t1 MGS_MAG_+Y_SENSOR \
             -c1 MGS_LEFT_SOLAR_ARRAY \
             -c2 MGS_SPACECRAFT \
             -t  dumpea \
             -f  'YYYY-MM-DDTHR:MN:SC.### ::RND' \
             -b  2006-04-01 11:00 \
             -e  2006-04-01 13:00 \
             -s  60 \
             > output.txt
   % cat output.txt
   #
   # Sampling of 121 rotations
   #
   #    from 'J2000' (1) to 'MGS_MAG_+Y_SENSOR' (-94051)
   #    computed using
   #
   #       mgs_2006_v01.tm
   #
   # with a 60.000000000000 second (0:00:01:00.000000) step size
   # within the non-continuous (with 1 gaps) time period
   #
   #    from '2006 APR 01 11:01:05.185' TDB (197161265.18566 TDB seco...
   #    to   '2006 APR 01 13:01:05.185' TDB (197168465.18566 TDB seco...
   #
   # Times were generated by TIMOUT using 'YYYY-MM-DDTHR:MN:SC.### ::...
   #
   # angles are shown in radians.
   #
   # time, ang3_about_Z, ang2_about_Y, ang1_about_X
   2006-04-01T11:00:00.000 +1.1187945929621E+00 -1.7969108686644E-01 ...
   2006-04-01T11:01:00.000 +1.1187852723628E+00 -1.7931962082645E-01 ...
   2006-04-01T11:02:00.000 +1.1186582180859E+00 -1.7869508126719E-01 ...
   ...
   2006-04-01T12:57:55.804 +1.1175120633959E+00 -1.7734256227094E-01 ...
   2006-04-01T12:58:55.804 +1.1174237423840E+00 -1.7692771707569E-01 ...
   2006-04-01T13:00:00.000 +1.1173605546240E+00 -1.7633741045076E-01 ...


Top

Displaying Overlap in Coverage between Two CKs




In this example the program is run to determine the time intervals when both the MRO spacecraft CK ``mro_sc_psp_080408_080414.bc'' and MRO CRISM instrument CK ``mro_crm_psp_080413_080430.bc'' provide coverage and to display the boundaries of these intervals as UTC in ISO DOY format. The CKs are provided as the two primary kernels with other kernels -- the LSK ``naif0009.tls'' and the SCLK ``MRO_SCLKSCET.00027.65536.tsc'', required for time conversions, and the MRO FK ``mro_v13.tf'', defining frames used in the CKs, -- provided using ``-k''. The report is set to the coverage intervals dump using ``-t dumpc'' and the output time format is set to UTC in ISO DOY format using

   -f 'YYYY-DOYTHR:MN:SC.### ::RND'
For runs like this usually both ``from'' frames and both ``to'' frames should be specified using ``-f1'', ``-f2'', ``-t1'', and ``-t2'' and these frames should match the base and structure frames from the CK files (the names of the base and structure frames can be seen in the CK summary produced by the ``BRIEF'' utility program run using the ``-rel -n'' options).

   % frmdiff -k naif0009.tls MRO_SCLKSCET.00027.65536.tsc mro_v13.tf \
             -f1 MRO_MME_OF_DATE -t1 MRO_SPACECRAFT \
             -f2 MRO_CRISM_BASE  -t2 MRO_CRISM_ART \
             -t dumpc -f 'YYYY-DOYTHR:MN:SC.### ::RND' \
             mro_sc_psp_080408_080414.bc mro_crm_psp_080413_080430.bc
   #
   # Coverage overlap for rotation
   #
   #    from 'MRO_MME_OF_DATE' (-74900) to 'MRO_SPACECRAFT' (-74000)
   #    computed using
   #
   #       naif0009.tls MRO_SCLKSCET.00027.65536.tsc mro_v13.tf
   #       mro_sc_psp_080408_080414.bc
   #
   # and rotation
   #
   #    from 'MRO_CRISM_BASE' (-74011) to 'MRO_CRISM_ART' (-74012)
   #    computed using
   #
   #       naif0009.tls MRO_SCLKSCET.00027.65536.tsc mro_v13.tf
   #       mro_crm_psp_080413_080430.bc
   #
   # with a 0.56599156324219 second (0:00:00:00.565992) step size
   # within the non-continuous (with 22 gaps) time period
   #
   #    from '2008 APR 13 00:29:16.745' TDB (261318556.74553 TDB seco...
   #    to   '2008 APR 13 01:12:03.742' TDB (261321123.74222 TDB seco...
   #
   # Times were generated by TIMOUT using 'YYYY-DOYTHR:MN:SC.### ::RN...
   #
   # interval_start, interval_stop, interval_duration_sec, interval_d...
   2008-104T00:28:11.560 2008-104T00:31:11.564         180.003858    ...
   2008-104T00:43:10.558 2008-104T00:43:14.559           4.001042    ...
   ...
   2008-104T01:10:08.423 2008-104T01:10:12.424           4.000950    ...
   2008-104T01:10:54.556 2008-104T01:10:58.557           4.001042    ...


Top

Displaying Gaps in a CK File




In this example the program is run to display the gaps in the CASSINI CK ``09006_09011ra.bc''. The CK is given as the only primary kernel, with all other kernels -- the LSK ``naif0009.tls'' and the SCLK ``cas00130.tsc'', required for time conversions, and the CASSINI FK ``cas_v40.tf'', defining frames used in the CK, -- provided using ``-k''. The report type is set to the coverage gaps dump using ``-t dumpg'' and the output time format is set to UTC in ISO date format using

   -f 'YYYY-MM-DDTHR:MN:SC.### ::RND'
There is no need to specify the ``to'' and ``from'' frames because the program will pick them automatically by examining the CK file.

   % frmdiff -k naif0009.tls cas00130.tsc cas_v40.tf \
             -t dumpg -f 'YYYY-MM-DDTHR:MN:SC.### ::RND' \
             09006_09011ra.bc
   #
   # Coverage for rotation
   #
   #    from 'J2000' (1) to 'CASSINI_SC_COORD' (-82000)
   #    computed using
   #
   #       naif0009.tls cas00130.tsc cas_v40.tf
   #       09006_09011ra.bc
   #
   # with a 439.60863577834 second (0:00:07:19.608636) step size
   # within the non-continuous (with 8 gaps) time period
   #
   #    from '2009 JAN 06 00:01:08.565' TDB (284472068.56521 TDB seco...
   #    to   '2009 JAN 11 00:01:05.243' TDB (284904065.24341 TDB seco...
   #
   # Times were generated by TIMOUT using 'YYYY-MM-DDTHR:MN:SC.### ::...
   #
   # gap_start, gap_stop, gap_duration_sec, gap_duration_string
   2009-01-06T13:45:49.779 2009-01-06T13:46:10.029          20.249856...
   2009-01-06T15:15:49.740 2009-01-06T15:16:49.990          60.249572...
   ...
   2009-01-09T15:16:43.897 2009-01-09T15:17:12.147          28.249799...
   2009-01-10T17:18:27.481 2009-01-10T17:18:55.480          27.999801...


Top

Miscellaneous Things to Consider







Top

``Apples vs. Oranges''




Even though the program has the flexibility to compare any two transformations -- for example the transformation from the ``J2000'' frame to the ``IAU_MARS'' frame with the transformation from the ``MRO_SPACECRAFT'' frame to the ``MRO_CTX'' frame -- it doesn't mean that such comparisons make sense. In general, it makes sense to compare only transformations that are close to each other and have the same ``from'' frame.



Top

Using Euler Angles for Small Rotation Differences




While Euler angles included in the Euler angles dump report (``-t dumpea'') may be one of the more intuitive representations of rotations, in many cases, depending on the rotation order, the angle magnitudes can be large and not representative of the small rotation differences. The total rotation angle provided in the rotation angle and axis report (``-t dumpaa'') is a much more reliable indicator of the difference of two rotations.



Top

Single Epoch




Due to the algorithm which the program uses to determine the coverage window, when orientations must be compared at, or an orientation must be sampled at, a certain epoch this epoch must be provided on the command line twice, once using the ``-b'' key and once using the ``-e'' key.



Top

References





    2. CK Required Reading (ck.req)

    3. PCK Required Reading (pck.req)



Top

Acronyms





AV

angular velocity
ET

Ephemeris Time (synonymous to TDB)
SCLK

Spacecraft CLocK time
TDB

Barycentric Dynamical Time (synonymous to ET)


Top

Appendix 1: Comparison, Sampling and Report Quantity Algorithms







Top

Computing Rotation and Angular Velocity Difference




When run in comparison mode the program uses the following SPICE routines to compute the rotation and angular velocity differences at each of the times:

    -- if only rotations (without angular velocities) are to be compared:

            M1 = cspice_pxform ( FROM1, TO1, ET )
            M2 = cspice_pxform ( FROM2, TO2, ET )
 
            MDIFF = M1 * M2'
    -- if rotations and angular velocities in the ``from'' frames are to be compared:

            X1          = cspice_sxform ( FROM1, TO1, ET )
            [ M1, AV1 ] = cspice_xf2rav ( X1 )
 
            X2          = cspice_sxform ( FROM2, TO2, ET )
            [ M2, AV2 ] = cspice_xf2rav ( X2 )
 
            MDIFF  = M1 * M2'
            AVDIFF = AV1 - AV2
    -- if rotations and angular velocities in the ``to'' frames are to be compared:

            X1          = cspice_sxform ( FROM1, TO1, ET )
            [ M1, AV1 ] = cspice_xf2rav ( X1 )
 
            X2          = cspice_sxform ( FROM2, TO2, ET )
            [ M2, AV2 ] = cspice_xf2rav ( X2 )
 
            MDIFF    = M1 * M2'
            AVDIFFFR = AV1 - AV2
 
            AVDIFF   = M1 * AVDIFFFR
where FROM1, FROM2, TO1, TO2, and ET are the ``from'' and ``to'' frames of interest and time, MDIFF and AVDIFF are the rotation and angular velocity differences to be reported.



Top

Sampling Rotation and Angular Velocity




When run in sampling mode the program uses the following SPICE routines to compute the rotation and angular velocity at each of the times:

    -- if only rotation (without angular) velocity is to be sampled:

            MDIFF = cspice_pxform ( FROM, TO, ET )
    -- if rotation and angular velocity in the ``from'' frame is to be sampled:

            X                 = cspice_sxform ( FROM, TO, ET )
            [ MDIFF, AVDIFF ] = cspice_xf2rav ( X )
    -- if rotation and angular velocity in the ``to'' frame is to be sampled:

            X             = cspice_sxform ( FROM, TO, ET )
            [ MDIFF, AV ] = cspice_xf2rav ( X )
 
            AVDIFF = MDIFF * AV
where FROM, TO, and ET are the ``from'' and ``to'' frames of interest and time, MDIFF and AVDIFF are the rotation and angular velocity to be reported.



Top

Converting Rotation to Angle/Axis




If no ``-t'' is specified, or if ``-t basic'', ``-t stats'', or ``-t dumpaa'' is specified, the program converts MDIFF to the rotation angle and axis using

            [ AXIS, ANGLE ] = cspice_raxisa ( MDIFF )


Top

Converting Rotation to SPICE-Style Quaternion




If ``-t dumpqs'' is specified, the program converts MDIFF to the SPICE-style quaternion using

            QS = cspice_m2q ( MDIFF )


Top

Converting Rotation to ``Other''-Style quaternion




If ``-t dumpqo'' is specified, the program converts MDIFF to the ``other''-style quaternion using

            QS = cspice_m2q ( MDIFF )
            QO(1) = -QS(2)
            QO(2) = -QS(3)
            QO(3) = -QS(4)
            QO(4) =  QS(1)


Top

Converting Rotation to Euler Angles




If ``-t'' dumpea is specified, the program converts MDIFF to Euler angles using

            [ANG3, ANG2, ANG1] = ...
                            cspice_m2eul( MDIFF, AXIS3, AXIS2, AXIS1 )
where AXIS1-3 are either defaults (``Z Y X'') or the axes specified using the ``-o'' key. The axes are ``passed'' as input to M2EUL in the same order as they are listed using ``-o''. For example, for ``-o X Z Y'' M2EUL is called with ``( MDIFF, 1, 3, 2, ...)''.