sct2e |
Table of contents
ProcedureSCT2E ( SCLK ticks to ET ) SUBROUTINE SCT2E ( SC, SCLKDP, ET ) AbstractConvert encoded spacecraft clock (`ticks') to ephemeris seconds past J2000 (ET). Required_ReadingCK SCLK SPK TIME KeywordsCONVERSION TIME DeclarationsIMPLICIT NONE INTEGER SC DOUBLE PRECISION SCLKDP DOUBLE PRECISION ET Brief_I/OVARIABLE 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_InputSC 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_OutputET is the epoch, specified as ephemeris seconds past J2000, that corresponds to SCLKDP. ParametersNone. Exceptions1) 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. FilesNone. ParticularsThis 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. Examples1) 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 ) 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) W.L. Taber (JPL) E.D. Wright (JPL) VersionSPICELIB 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