Index of Functions: A  B  C  D  E  F  G  H  I  J  K  L  M  N  O  P  Q  R  S  T  U  V  W  X 
Index Page
sct2e

Table of contents
Procedure
Abstract
Required_Reading
Keywords
Declarations
Brief_I/O
Detailed_Input
Detailed_Output
Parameters
Exceptions
Files
Particulars
Examples
Restrictions
Literature_References
Author_and_Institution
Version

Procedure

     SCT2E ( SCLK ticks to ET )

     SUBROUTINE SCT2E ( SC, SCLKDP, ET )

Abstract

     Convert encoded spacecraft clock (`ticks') to ephemeris
     seconds past J2000 (ET).

Required_Reading

     CK
     SCLK
     SPK
     TIME

Keywords

     CONVERSION
     TIME

Declarations

     IMPLICIT NONE

     INTEGER               SC
     DOUBLE PRECISION      SCLKDP
     DOUBLE PRECISION      ET

Brief_I/O

     VARIABLE  I/O  DESCRIPTION
     --------  ---  --------------------------------------------------
     SC         I   NAIF spacecraft ID code.
     SCLKDP     I   SCLK, encoded as ticks since spacecraft clock
                    start.
     ET         O   Ephemeris time, seconds past J2000.

Detailed_Input

     SC       is a NAIF integer code for a spacecraft, one of
              whose encoded clock values is represented by
              SCLKDP.

     SCLKDP   is an encoded spacecraft clock value. SCLKDP
              represents time measured from spacecraft clock
              start: partition information IS reflected in the
              encoded value.

Detailed_Output

     ET       is the epoch, specified as ephemeris seconds past
              J2000, that corresponds to SCLKDP.

Parameters

     None.

Exceptions

     1)  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 ET will not be modified. This routine assumes
         that that an SCLK kernel appropriate to the spacecraft clock
         identified by the input argument SC has been loaded.

     2)  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
         ET will not be modified. 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.

         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 the clock type for the spacecraft clock identified by
         SC is not supported by this routine, the error
         SPICE(NOTSUPPORTED) is signaled. The output argument ET
         will not be modified.

     4)  If the input argument SCLKDP is invalid, an error is signaled
         by a routine in the call tree of this routine. The output
         argument ET will not be modified.

Files

     None.

Particulars

     This routine operates on encoded SCLK values. These values
     are obtained by calling the SPICELIB routine SCENCD or other
     SCLK conversion routines. The advantage of encoded SCLK, as
     opposed to character string representations of SCLK is that
     encoded SCLK values are easy to perform arithmetic operations on.
     Additionally, working with encoded SCLK reduces the overhead of
     repeated conversion of character strings to integers or double
     precision numbers.

     To convert a string representation of an SCLK value to ET, use
     the SPICELIB routine SCS2E.

     See the SCLK Required Reading for a list of the entire set of
     SCLK conversion routines.

Examples

     1)  Encode a Galileo SCLK string, and convert the encoded value
         to ET; use these time values to look up both GLL orbiter
         scan platform's pointing and the GLL--Earth state vector
         for an epoch specified by an SCLK string.

            During program initialization, load the leapseconds and
            SCLK kernels. We will pretend that these files are named
            "LEAPSECONDS.KER" and "GLLSCLK.KER".  To use this code
            fragment, you must substitute the actual names of these
            kernel files for the names used here.

               C
               C     Load leapseconds and SCLK kernels:
               C
                     CALL FURNSH ( 'LEAPSECONDS.KER' )
                     CALL FURNSH ( 'SCLK.KER'        )

            The mission is Galileo, which has spacecraft ID -77.
            Let's assume that the SCLK string is

                     1 / 1900000:00:00

            The number 1, followed by a slash, indicates that the
            epoch is in the first partition.

            The next step is to encode this SCLK string, and also
            find the corresponding ET value:

                     CALL SCENCD ( -77, '1/ 1900000:00:00', SCLKDP )
                     CALL SCT2E  ( -77,  SCLKDP,            ET     )

            We'll assume that you've already loaded SPK and CK files
            containing ephemeris data for the GLL orbiter and the
            Earth, as well as scan platform pointing.  Now you're
            ready to call both CKGP, which expects the input epoch to
            be specified by an encoded SCLK string, and SPKEZ, which
            expects the epoch to be specified as an ephemeris time.

               C
               C     Find scan platform pointing CMAT and s/c--target
               C     vector (first 3 components of STATE) at epoch.
               C     We assume that CK and SPK kernels have been loaded
               C     already, via CKLPF and SPKLEF respectively.
               C
                     SCANPL = -77001
                     EARTH  =    399

                     CALL CKGP  ( SCANPL,
                    .             SCLKDP,
                    .             TOL,
                    .             REFSYS,
                    .             CMAT,
                    .             CLKOUT,
                    .             FOUND   )

                     IF ( .NOT. FOUND ) THEN

                        [ Indicate to user that pointing was not
                          available ]

                     END IF


                     CALL SPKEZ ( EARTH,
                    .             ET,
                    .             REFSYS,
                    .             CORR,
                    .             -77,
                    .             STATE,
                    .             LT      )



     2)  Convert an encoded Voyager 2 SCLK value to UTC, using calendar
         format, with 3 digits of precision.

            Again, your initialization code must load the leapseconds
            and SCLK kernels:

               C
               C     Load leapseconds and SCLK kernels:
               C
                     CALL FURNSH ( 'LEAPSECONDS.KER' )
                     CALL FURNSH ( 'VGR2SCLK.KER'    )


            To find the UTC value corresponding to the encoded
            Voyager 2 SCLK value SCLKDP, you can use the code fragment

                     CALL SCT2E  ( -32,  SCLKDP,     ET  )
                     CALL ET2UTC (  ET,  'C',    3,  UTC )

Restrictions

     1)  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_References

     None.

Author_and_Institution

     N.J. Bachman       (JPL)
     J. Diaz del Rio    (ODC Space)
     W.L. Taber         (JPL)
     E.D. Wright        (JPL)

Version

    SPICELIB Version 1.1.0, 06-JUL-2021 (JDR)

        Added IMPLICIT NONE statement.

        Edited the header to comply with NAIF standard. Removed
        unnecessary $Revisions section.

        Moved the required readings present in $Literature_References
        section to $Required_Reading.

    SPICELIB Version 1.0.4, 22-AUG-2006 (EDW)

        Replaced references to LDPOOL with references
        to FURNSH.

    SPICELIB Version 1.0.3, 09-MAR-1999 (NJB)

        Explicit list of SCLK conversion routines in $Particulars
        section has been replaced by a pointer to the SCLK Required
        Reading.

    SPICELIB Version 1.0.2, 10-APR-1992 (NJB) (WLT)

        The $Brief_I/O section now lists ET correctly as an output
        from this routine. Header was updated to reflect possibility
        of needing to load a leapseconds kernel before calling this
        routine. Comment section for permuted index source lines was
        added following the header.

    SPICELIB Version 1.0.1, 12-OCT-1990 (NJB)

        $Restrictions section no longer states that you must load the
        leapseconds kernel prior to calling this routine.

        The examples have been slightly re-written. In particular,
        they no longer use calls to CLPOOL.

    SPICELIB Version 1.0.0, 03-SEP-1990 (NJB)
Fri Dec 31 18:36:46 2021