dskstl |
Table of contents
ProcedureDSKSTL ( DSK, set tolerance ) ENTRY DSKSTL ( KEYWRD, DPVAL ) AbstractSet the value of a specified DSK tolerance or margin parameter. Required_ReadingDSK KeywordsDSK MARGIN NUMERIC TOLERANCE DeclarationsINTEGER KEYWRD DOUBLE PRECISION DPVAL Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- KEYWRD I Code specifying parameter to modify. DPVAL I New value of parameter. Detailed_InputKEYWRD is an integer code specifying the parameter to set. See the include file dsktol.inc for a description of the possible keywords. DPVAL is the new value of the parameter specified by KEYWRD. This value will be retrieved by future calls to to DSKGTL made to retrieve the specified parameter. <<< Use extreme caution. This routine performs no checks on DPVAL. >>> Detailed_OutputNone. This routine operates by side effects. ParametersSee the include file dsktol.inc for descriptions and values of the tolerance or margin parameters accessed by this routine, and of the keyword parameters used to refer to them. Exceptions1) If the input keyword is not recognized, the error SPICE(INDEXOUTOFRANGE) is signaled. 2) If an attempt is made to modify a fixed parameter, the error SPICE(IMMUTABLEVALUE) is signaled. FilesNone. ParticularsThe routines in this package serve to centralize numeric tolerance and margin values used by the DSK subsystem. The subsystem retrieves values from this package to use at run time. The entry points of this routine are DSKGTL {DSK, get tolerance value} DSKSTL {DSK, set tolerance value} To minimize run time overhead, the "keywords" used by these routines to identify parameters are actually integer codes. SPICE users may override certain values maintained by this package; others values are fixed. It is recommended that any change to the tolerance values made at run time be performed only by expert SPICE users. ExamplesThe numerical results shown for this example may differ across platforms. The results depend on the SPICE kernels used as input, the compiler and supporting libraries, and the machine specific arithmetic implementation. 1) Obtain, display, and update the DSK type 2 plate expansion fraction. Example code begins here. PROGRAM DSKSTL_EX1 IMPLICIT NONE C C Include files C INCLUDE 'dsktol.inc' C C Local variables C DOUBLE PRECISION DPVAL CALL DSKGTL ( KEYXFR, DPVAL ) WRITE(*,*) 'Default plate expansion fraction = ', DPVAL C C Update the parameter. C CALL DSKSTL ( KEYXFR, 1.D-8 ) C C Verify the update. C CALL DSKGTL ( KEYXFR, DPVAL ) WRITE(*,*) 'New plate expansion fraction = ', DPVAL END When this program was executed on a Mac/Intel/gfortran/64-bit platform, the output was: Default plate expansion fraction = 1.0000000000000000E-010 New plate expansion fraction = 1.0000000000000000E-008 Restrictions1) The default settings used by the DSK subsystem should be overridden only by expert SPICE users. 2) This routine does not check the validity of new parameter values supplied by the calling application. Literature_ReferencesNone. Author_and_InstitutionN.J. Bachman (JPL) J. Diaz del Rio (ODC Space) VersionSPICELIB Version 1.0.1, 09-JUL-2020 (JDR) Updated the header to comply with NAIF standard. Added complete example code. SPICELIB Version 1.0.0, 01-AUG-2016 (NJB) |
Fri Dec 31 18:36:15 2021