scps01 |
Table of contents
ProcedureSCPS01 ( Convert type 1 SCLK string to ticks ) SUBROUTINE SCPS01 ( SC, CLKSTR, ERROR, MSG, TICKS ) AbstractConvert a character representation of a type 1 spacecraft clock count to ticks. Required_ReadingSCLK KeywordsCONVERSION TIME DeclarationsIMPLICIT NONE INCLUDE 'sclk.inc' INTEGER SC CHARACTER*(*) CLKSTR LOGICAL ERROR CHARACTER*(*) MSG DOUBLE PRECISION TICKS Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- SC I NAIF spacecraft ID code. CLKSTR I Character representation of a clock count. ERROR O Parsing error flag. MSG O Output message for parsing error. TICKS O Number of ticks represented by the clock count. MXNFLD P Maximum number of allowed fields in an SCLK string. DELIMS P The accepted delimiters of an SCLK string. DPLEN P Maximum width of a clock field. Detailed_InputSC is a NAIF spacecraft identification code. See the `Examples' section below, and also the NAIF_IDS required reading file for a complete list of body ID codes. CLKSTR on input is the character representation of a spacecraft clock count (SCLK), without a partition number. Using Galileo as an example, a SCLK string without a partition number has the form wwwwwwww:xx:y:z where z is a mod-8 counter (values 0-7) which increments approximately once every 8 1/3 ms., y is a mod-10 counter (values 0-9) which increments once every time z turns over, i.e., approximately once every 66 2/3 ms., xx is a mod-91 (values 0-90) counter which increments once every time y turns over, i.e., once every 2/3 seconds. wwwwwwww is the Real-Time Image Count (RIM), which increments once every time xx turns over, i.e., once every 60 2/3 seconds. The roll-over expression for the RIM is 16777215, which corresponds to approximately 32 years. wwwwwwww, xx, y, and z are referred to interchangeably as the fields or components of the spacecraft count. SCLK components may be separated by any of the single character delimiters in the string DELIMS, with any number of spaces separating the components and the delimiters. The presence of the RIM component is required. Successive components may be omitted, and in such cases are assumed to represent zero values. Values for the individual components may exceed the maximum expected values. For instance, '0:0:0:9' is an acceptable Galileo clock string, and indicates the same time interval as '0:0:1:1'. Consecutive delimiters containing no intervening digits are treated as if they delimit zero components, except in the case of blanks. Consecutive blanks are treated as a single blank. Trailing zeros should always be included to match the length of the counter. For example, a Galileo clock count of '25684.90' should not be represented as '25684.9'. Some spacecraft clock components have offset, or starting, values different from zero. For example, with an offset value of 1, a mod 20 counter would cycle from 1 to 20 instead of from 0 to 19. See the SCLK required reading for a detailed description of the Galileo, Mars Observer, and Voyager clock formats. See the `Examples' section in SCPS01, below. Detailed_OutputERROR is .TRUE. if an error occurred parsing the input clock string and converting it to ticks. MSG is the message generated if an error occurred parsing the input clock string. TICKS is the number of "ticks" corresponding to the input spacecraft clock string CLKSTR. "Ticks" are the units in which encoded SCLK strings are represented. A typical Galileo SCLK string looks like 'wwwwwwww xx y z', as described above. Since z is the mod-8 (one tick) counter, the number of ticks represented by y is 8*y. And since y is the mod-10 counter, the number of ticks represented by xx is 10*8*xx. The total number of ticks represented by the above string is wwwwwwww( 7280 ) + xx( 80 ) + y( 8 ) + z Clock strings for other spacecraft are converted in a similar manner. See $Examples below. ParametersSee the INCLUDE file sclk.inc. ExceptionsIn the case of any SPICELIB error occurring, ERROR is set to .TRUE. and MSG to 'SPICELIB error detected.'. 1) This routine assumes that that an SCLK kernel appropriate to the spacecraft clock identified by the input argument SC has been loaded. If an SCLK kernel has not been loaded, does not contain all of the required data, or contains invalid data, an error is signaled by a routine in the call tree of this routine. The output argument TICKS will not be modified. and MSG The variables that must be set by the SCLK kernel are: - The number of fields in an (unabridged) SCLK string - The output delimiter code - The parallel time system code - The moduli of the fields of an SCLK string - The offsets for each clock field. - The SCLK coefficients array - The partition start times - The partition end times 2) When using SCLK kernels that map SCLK to a time system other than ET (also called barycentric dynamical time---`TDB'), it is necessary to have a leapseconds kernel loaded at the time this routine is called. If a leapseconds kernel is required for conversion between SCLK and ET but is not loaded, an error is signaled by a routine in the call tree of this routine. The output argument TICKS will not be modified. The time system that an SCLK kernel maps SCLK to is indicated by the variable SCLK_TIME_SYSTEM_nn in the kernel, where nn is the negative of the NAIF integer code for the spacecraft. The time system used in a kernel is TDB if and only if the variable is assigned the value 1. 3) If any of the following kernel variables have invalid values, an error is signaled by a routine in the call tree of this routine: - The time system code - The number of SCLK coefficients - The number of partition start times - The number of partition end times - The number of fields of a SCLK string - The number of moduli for a SCLK string If the number of values for any item read from the kernel pool exceeds the maximum allowed value, it is may not be possible to diagnose the error correctly, since overwriting of memory may occur. This particular type of error is not diagnosed by this routine. 4) The input argument CLKSTR may be invalid for a variety of reasons: -- One of the extracted clock components cannot be parsed as an integer -- CLKSTR contains too many components -- the value of one of the components is less than the offset value If any of these conditions is detected, no error is signaled. ERROR is set to .TRUE. and MSG contains the specific issue. The output argument TICKS will not be modified. FilesNone. ParticularsThis routine converts a character string representation of a spacecraft clock count into the number of ticks represented by the clock count. An important distinction between this type of conversion and that carried out by SCENCD is that this routine treats spacecraft clock times as representations of time intervals, not absolute times. This routine does not make use of any partition information. See SCENCD for details on how to make use of partition numbers. Examples1) Below are some examples illustrating various inputs and the resulting outputs for the Galileo spacecraft. CLKSTR TICKS ---------------- -------------------- '0:0:0:1' 1 '0:0:1' 8 '0:1' 80 '1' 7280 '1 0 0 0' 7280 '1,0,0,0' 7280 '1:90' 14480 '1:9' 8000 '1:09' 8000 '0-0-10' 80 |-- Third component is supposed '0-1-0' 80 | to be a mod-10 count. '0/1/0' Error: '/' is not an accepted delimiter. '1: 00 : 0 : 1' 7281 '1:::1' 7281 '1.1.1.1.1' Error: Too many components '1.1.1.1.' Error: The last delimiter signals that a fifth component will follow. The following examples are for the Voyager 2 spacecraft. Note that the last component of the Voyager clock has an offset value of 1. CLKSTR TICKS ---------------- -------------------- '0.0.001' 0 '0:0:002' 1 '0:01' 800 '1' 48000 '1.0' 48000 '1.0.0' Error: The 3rd component is never 0. '0.0:100' 99 '0-60-1' 48000 '1-1-1' 48800 '1-1-2' 48801 Restrictions1) An SCLK kernel appropriate to the spacecraft clock identified by SC must be loaded at the time this routine is called. 2) If the SCLK kernel used with this routine does not map SCLK directly to barycentric dynamical time, a leapseconds kernel must be loaded at the time this routine is called. Literature_ReferencesNone. Author_and_InstitutionN.J. Bachman (JPL) J. Diaz del Rio (ODC Space) J.M. Lynch (JPL) VersionSPICELIB Version 1.1.1, 20-AUG-2021 (JDR) Edited the header to comply with NAIF standard. Added introductory paragraph to $Exceptions section, split entry #1 into two, and added description of behavior in entry #4. SPICELIB Version 1.1.0, 11-FEB-2008 (NJB) Global parameters are now declared in the Fortran INCLUDE file sclk.inc. SPICELIB Version 1.0.0, 25-FEB-1993 (JML) |
Fri Dec 31 18:36:46 2021