| SPICE Kernel Required Reading | 
| Table of ContentsSPICE Kernel Required Reading Abstract Document Outline Introduction to Kernels Kernel Types Text Kernels and the Kernel Pool Binary Kernels SPICE Kernel Type Identification and Kernel Naming SPICE Kernel Type Identification Recommendations on Kernel File Naming Binary Kernel Specifications Text Kernel Specifications and Interfaces Text Kernel Specifications Variable Name Rules Assignment Rules Variable Value Rules Additional Text Kernel Syntax Rules Maximum Numbers of Variables and Variable Values Treatment of Invalid Text Kernels Additional Meta-kernel Specifications Text Kernel Interfaces - Fetching Data from the Kernel Pool Informational Functions Section 5 -- Kernel Management Loading Kernels Kernel Priority Path Symbols in Meta-kernels Keeping Track of Loaded Kernels Reloading Kernels Changing Kernel Priority Load Limits Finding Out What's Loaded Unloading Kernels Loading of Non-native Text and Binary Kernels Manipulating Kernel Pool Contents Detecting Changes in the Kernel Pool Using Watchers Appendix A -- Discussion of Competing Data Binary Kernels SPKs CKs Binary PCKs Text Kernels Appendix B -- Glossary of Terms Agent Assignment Continued string Control words Direct assignment Element Incremental assignment Keeper (subsystem) Kernel pool (sometimes just called ``the pool'') Kernel variable Meta-kernel (also known as ``FURNSH kernel'') Operator Principal data Value Variable name Vector value Appendix C -- Summary of Routines Appendix D -- Summary of Key Text Kernel Parameter Values Appendix E -- Revision History SPICE Kernel Required Reading
 Abstract
 Document Outline
 
 
 
 
 
 
 ``Kernel type identification and kernel naming'' contains specifications for kernel architecture and type identification and restrictions and recommendations concerning kernel file naming. ``Binary kernel specifications'' points the reader to other SPICE documents for most information on binary kernels. ``Text kernel specifications and interfaces,'' which includes extra rules for meta-kernels, provides a good deal of technical detail for both producers and consumers (users) of text kernels. ``Kernel management'' contains important information about managing and obtaining information about both text and binary kernels. Appendix A discusses the notion of ``competing data.'' Appendix B provides definitions of terms used in this document with SPICE-specific meaning. Appendix C provides a listing of kernel subsystem functions. Appendix D provides a summary of key text kernel parameter values. Appendix E provides the revision history of this document. Introduction to Kernels
 Within each architecture there are several kernel types. Kernel Types
 
 
 
 
 
 
 
 
 
 
 
 
 Text Kernels and the Kernel Pool
 Text kernels should contain descriptive information, provided by the kernel producer, describing the sources and intended uses of the kernel data. Text kernels associate values with variables using a ``name = value(s)'' form of assignment. The kernel pool is the repository of the information provided in these assignments. Populating the kernel pool occurs in either or both of two ways: by loading text kernels -- by far the most used method -- or by using pool subsystem functions. Once ``name = value(s)'' assignments provided in a text kernel have been loaded into the kernel pool the value(s) are said to be associated with the names. You may access these data through kernel pool look-up functions using the names as keys to find the associated values. The kernel pool look-up functions are described in detail a bit later in this document. However, some higher-level and more often used functions also access data loaded into the kernel pool. Two tables in the tutorial named ``Summary of Key Points'' provide details. Binary Kernels
 For EK binary kernels, the descriptive data mentioned above, and some database schema information, are read in at kernel load time. Principal data are read only when an EK query is made by a kernel reader function. Data from binary kernels do NOT get placed in the kernel pool; the pool is used only for text kernel data. Binary kernels contain a ``comment area'' where important descriptive information in ASCII form should be provided by the kernel producer. On occasion one may be given, or need to make, a ``transfer format'' file. This is an ASCII-format representation of a binary kernel, used in early versions of CSPICE to port binary kernels between dissimilar computers (e.g. IEEE - Little endian to IEEE - Big endian, or vice-versa). For the most part these transfer format files are no longer needed due to the addition of run-time translation capabilities in the binary kernel readers. But there are some situations when transfer format binary kernels are still needed; refer to the tutorial named ``Porting Kernels'' for details. SPICE Kernel Type Identification and Kernel NamingSPICE Kernel Type Identification
 The first 6 to 8 bytes of a SPICE kernel are used for file type identification. In binary and text kernels this identifier consists of two string IDs separated by the ``/'' character. The first ID, identifying the file architecture of the kernel file (``DAF'', ``DAS'', ``KPL''), is always three characters long. The second ID, identifying the file type of the kernel file (``SPK'', ``PCK'', ``IK'', ``SCLK'', etc.), is two to four characters long. In transfer format files this file type identifier consists of a single string ID. See the Convert User's Guide for details. In binary kernels the kernel type identifier always occupies the first eight bytes. If the combined length of the kernel architecture ID, the ``/'' character, and the kernel type ID is less than 8 characters, the identifier is padded on the right to eight characters using blanks (e.g. ``DAF/SPK '', ``DAS/EK ''). The correct identifier is written to a binary kernel automatically when the kernel is created by calling the kernel type specific ``open new file'' function -- spkopn_c for SPK files, ckopn_c for CK files, etc. If a binary kernel is created by calling an architecture specific ``open new file'' function -- dafonw_c for DAF files, dasonw_c for DAS files, etc., -- it is the caller's responsibility to specify the correct kernel type in the corresponding input argument of these functions to make sure the correct kernel type identifier is written into the kernel. In text kernels the kernel type identifier occupies the first six to eight characters and is followed by optional trailing blanks and then by the end-of-line terminator character(s), resulting in the identifier appearing on a line by itself. If the combined length of the kernel architecture ID, the ``/'' character, and the kernel type ID is less than 8 characters, the identifier can, but does not have to be padded on the right to eight characters using blanks (e.g. ``KPL/SCLK'', ``KPL/IK '', etc.). Since most text kernels are created manually using a text editor, it is the responsibility of the person making the kernel to put the correct identifier by itself on the first line of the kernel. In transfer format files the SPICE kernel type identifier occupies the first six characters of the file and is followed by the expanded name of the format (e.g. ``DAFETF NAIF DAF ENCODED TRANSFER FILE''). The correct kernel type identifier is written to a transfer format file automatically when the file is created by the SPICE utility programs TOXFR or SPACIT. See their user guides, toxfr.ug and spacit.ug, for details. The SPICE kernel type identifiers used in modern SPICE kernels are as follows. 
 
         Binary Kernels:
 
            SPK           DAF/SPK
            CK            DAF/CK
            PCK           DAF/PCK
            EK            DAS/EK
 
         Text Kernels:
 
            FK            KPL/FK
            IK            KPL/IK
            LSK           KPL/LSK
            MK            KPL/MK
            PCK           KPL/PCK
            SCLK          KPL/SCLK
 
         Transfer format files:
 
            DAF           DAFETF
            DAS           DASETF
 
 
Some older kernels used an earlier version of the kernel type
   identifier. In these kernels one would find:
 
           NAIF/DAF
           NAIF/DAS
The Toolkit includes the getfat_c function to retrieve the kernel file
   architecture and kernel type encapsulated in the SPICE kernel type
   identifier.A text kernel not having a kernel type identifier can, in fact, be processed by high-level functions, and by low-level functions other than getfat_c that use text kernel data. However, NAIF strongly recommends kernel creators to provide the identifier. Recommendations on Kernel File Naming
 
 
 
 
 NAIF recommends kernel names use only lower case letters. NAIF further recommends one follows the conventions established for kernel name extensions, shown below. 
 
            .bc    binary CK
            .bes   binary Sequence Component EK
            .bpc   binary PCK
            .bsp   binary SPK
            .tf    text FK
            .ti    text IK
            .tls   text LSK
            .tm    text meta-kernel (FURNSH kernel)
            .tpc   text PCK
            .tsc   text SCLK
 
Binary Kernel Specifications
 Text Kernel Specifications and Interfaces
 Text Kernel Specifications
 As the name implies, SPICE text kernels contain printable ASCII text (ASCII code 32-126). Text kernels may not contain non-printing characters, excepting tab (ASCII code 9). However NAIF recommends against use of tabs in text kernels. NAIF also recommends caution be exercised when cutting/pasting text from a formatted document into a text kernel; the text characters displayed in a document may not be in the accepted ASCII range, in which case the text kernel parser will fail when reading those characters. Assignments in SPICE text kernels have a ``name = value(s)'' or ``name += value(s)'' format. We illustrate this format by way of an example using an excerpt from a SPICE text planetary constants kernel (PCK). The format description given below applies to all SPICE text kernels; the specific data names shown in this example apply only to text PCK kernels. The example begins with a SPICE kernel type identifier and is then filled out with a combination of descriptive information, called comment blocks, and data blocks. 
 
   KPL/PCK
 
   Planets first. Each has quadratic expressions for the direction
   (RA, Dec) of the north pole and the location and rotation state
   of the prime meridian. Planets with satellites (except Pluto)
   also have linear expressions for the auxiliary (phase) angles
   used in the nutation and libration expressions of their satellites.
 
   \begindata
 
   BODY399_POLE_RA        = (    0.      -0.64061614  -0.00008386  )
   BODY399_POLE_DEC       = (  +90.      -0.55675303  +0.00011851  )
   BODY399_PM             = (   10.21  +360.98562970  +0.          )
   BODY399_LONG_AXIS      = (    0.                                )
 
   BODY3_NUT_PREC_ANGLES  = (  125.045    -1935.53
                               249.390    -3871.06
                               196.694  -475263.
                               176.630  +487269.65
                               358.219   -36000.    )
 
   \begintext
 
   Each satellite has similar quadratic expressions for the pole and
   prime meridian. In addition, some satellites have nonzero nutation
   and libration amplitudes. (The number of amplitudes matches the
   number of auxiliary phase angles of the primary.)
 
   \begindata
 
   BODY301_POLE_RA      = (  270.000   -0.64061614  -0.00008386   )
   BODY301_POLE_DEC     = (  +66.534   -0.55675303  +0.00011851   )
   BODY301_PM           = (   38.314  +13.1763581    0.           )
   BODY301_LONG_AXIS    = (    0.                                 )
 
   BODY301_NUT_PREC_RA  = (  -3.878  -0.120  +0.070  -0.017   0.     )
   BODY301_NUT_PREC_DEC = (  +1.543  +0.024  -0.028  +0.007   0.     )
   BODY301_NUT_PREC_PM  = (  +3.558  +0.121  -0.064  +0.016  +0.025  )
 
   \begintext
 
   Here we include the radii of the satellites and planets.
 
   \begindata
 
   BODY399_RADII    = (     6378.140    6378.140     6356.755  )
   BODY301_RADII    = (     1738.       1738.        1738.     )
 
   \begintext
End of example text kernel.In this example there are several comment blocks providing information about the data. Except for the comments appearing just after the kernel type identifier and before the first data block, all comment blocks are introduced by the control word 
 \begintextA comment block may contain any number of comment lines. Once a comment block has begun, no special characters are required to introduce subsequent lines of comments within that block. A comment block is terminated by the control word 
 \begindataor by the end of the kernel file. The 
 \begindatacontrol word also serves to introduce a block of data that will be stored in the kernel pool. A data block is terminated by the control word 
 \begintextor by the end of the kernel file. Each of these control words must appear on a line by itself, and each may be preceded by white space. Within each data block there are one or more variable assignments. Each variable assignment consists of three components: 
 
 
 
 Variable Name Rules
 
 
 
 
 
 
 
 Variable names are case-sensitive. Note that this behavior is different from that of most CSPICE high-level functions, which tend to ignore case in string inputs. Variable names that don't have the expected case will be invisible to CSPICE functions that try to fetch their values. Since high-level CSPICE functions that use kernel variables accept only upper case names, NAIF recommends upper case always be used for variable names. NAIF recommends you do not use a variable name with ``+'' as the last character. Assignment Rules
 
 BODY301_NUT_PREC_RA = -3.878 BODY301_NUT_PREC_RA += -0.120 BODY301_NUT_PREC_RA += +0.070 BODY301_NUT_PREC_RA += -0.017 BODY301_NUT_PREC_RA += 0.has the same effect as the single assignment 
 BODY301_NUT_PREC_RA = ( -3.878 -0.120 +0.070 -0.017 0 ) Variable Value Rules
 Numeric values may be provided in integer or floating point representation, with an optional sign. Engineering notation using an ``E'' or ``D'' is allowed. All numeric values, including integers, are stored as double precision numbers. Examples of assignments using valid numeric formats: 
 BODY399_RADII = ( 6378.1366 6378.1366 6356.7519 ) BODY399_RADII = ( 6.3781366D3 6.3781366D3 6.3567519D3 ) BODY399_RADII = ( 6.3781366d3 6.3781366d3 6.3567519d3 ) BODY399_RADII = ( 6.3781366E3 6.3781366E3 6.3567519E3 ) BODY399_RADII = ( 6.3781366e3 6.3781366e3 6.3567519e3 ) BODY399_RADII = ( 6378 6378 6357 )String values are supplied by quoting the string using a single quote at each end of the string, for example 
 
         DISTANCE_UNITS = ( 'KILOMETERS' )
This quoting convention is independent of the CSPICE Toolkit language
   version being used.All string values, whether part of a scalar or vector assignment, must not exceed 80 characters on a given line. Creating a string value longer than 80 characters is possible through continuation of an assignment over multiple lines; this is described later. There is no practical limit on the length of a string value other than as mentioned in the section on String Continuation below. If you need to include a single quote in the string value, use the FORTRAN convention of ``doubling'' the quote. 
 
         MESSAGE = ( 'You can''t always get what you want.' )
Date values may be entered in a wide variety of formats, using two
   methods. The easiest method is to enter a date as a string, as described
   above. There are no restrictions on the format of a date string entered
   as a string, but if you wish to later use that date string in SPICE
   software the string must conform to SPICE date/time formation rules (see
   the ``Time Required Reading'' document for details).A second method for entering dates, unique to text kernels, uses an ``@'' syntax. Some examples: 
 
         CALIBRATION_DATES = ( @31-JAN-1987,
                               @feb/4/1987,
                               @March-7-1987-3:10:39.221 )
Dates entered using the ``@'' syntax may not contain embedded blanks.Dates entered using the ``@'' syntax are converted to double precision seconds past the reference epoch J2000 as they are read into the kernel pool. Note that NO time system specification (e.g. UTC or TDB) is implied by dates using the ``@'' syntax. Association of a time system with such dates is performed by the software that uses them. For example, in SPICE leapseconds kernels, such dates represent UTC times; in frames kernels, they represent TDB times. You should refer to software user's guides or API documentation to understand the interpretation of these dates for your application. Vector values, whether of numeric, string or date types, are enclosed in parenthesis, and adjacent components are separated by either white space (blank or carriage return, but not TAB) or commas. 
 
         MISSION_UNITS = ( 'KILOMETERS','SECONDS'
                           'KILOMETERS/SECOND' )
The types of values assigned to a given kernel pool variable must all be
   the same. If you attempt to make an assignment such as the one shown
   here:
 
         ERROR_EXAMPLE = ( 1, 2, 'THREE', 4, 'FIVE' )
 
 
the kernel pool reader will regard the assignment as erroneous and
   reject it.Additional Text Kernel Syntax Rules
 All assignments, or portions of an assignment, occurring on a line must not exceed 132 characters, including the assignment operator and any leading or embedded white space. String Continuation It is possible to treat specified, consecutive elements of a string array as a single ``continued'' string. String continuation is indicated by placing a user-specified sequence of non-blank characters at the end (excluding trailing blanks) of each string value that is to be concatenated to its successor. The string continuation marker can be any positive number of printing characters that fit in a string value (except not true for meta-kernels). For example, if the character sequence 
 
         //
is used as the continuation marker, the assignment
 
         CONTINUED_STRINGS = ( 'This //  ',
                               'is //  ',
                               'just //',
                               'one long //',
                               'string.',
                               'Here''s a second //',
                               'continued //'
                               'string.'              )
allows the string array elements on the right hand side of the
   assignment to be treated as the two strings
 
         This is just one long string.
         Here's a second continued string.
Everything between the single quotes, including white space and the
   continuation marker, counts towards the limit of 80 characters in the
   length of each string element.The CSPICE function stpool_c, and ONLY that function, provides the capability of retrieving continued strings from the kernel pool. See the discussion below under ``Fetching Data from the Kernel Pool'' or the header of stpool_c for further information. Maximum Numbers of Variables and Variable Values
 See Appendix D for the numeric values of these limits. Treatment of Invalid Text Kernels
 If the CSPICE error handling subsystem is in RETURN mode, furnsh_c will return control to the calling program. RETURN mode is typically used in interactive programs. In the latter case, all data loaded from the text kernel prior to discovery of the error will remain loaded. If, in RETURN mode, an error occurs while a meta-kernel is being loaded, all files listed in that meta-kernel that have already been loaded will remain loaded. Files listed in the meta-kernel later than the file for which the failure occurred will not be loaded. Note that continuing program operation after a load failure could, due to changes in the availability of competing data, result in performing computations with data that were not planned to be used. Additional Meta-kernel Specifications
 
 
 
 
 Text Kernel Interfaces - Fetching Data from the Kernel Pool
 The values of variables stored in the kernel pool may be retrieved using the functions: 
 
 
 
 
 
 
 gcpool_c( name, first, room, lenout, nvalues, values, found ); gdpool_c( name, first, room, nvalues, values, found ); gipool_c( name, first, room, nvalues, values, found ); stpool_c( name, nth, contin, lenout, string, size, found );The meanings of the arguments are as follows: 
 
 
 
 
 
 
 
 
 
 
 
 
 Informational Functions
 
 
 
 
 
 Section 5 -- Kernel Management
 Loading Kernels
 The principal kernel loading function is named furnsh_c (pronounced ``furnish''). A kernel database stores the existence information for any kernel (text or binary) loaded by furnsh_c. The subsystem provides a set of functions that enable an application to find the names and attributes of kernels stored in the database. Early versions of CSPICE loaded kernels using functions specific to each kernel type. Code written for the binary kernels also supported a kernel unload facility. CSPICE continues to support the original kernel loaders and unloaders, but anyone writing new code should use the furnsh_c function instead of the kernel-specific functions. NAIF recommends loading multiple kernels using a ``meta-kernel'' rather than by executing multiple calls to furnsh_c. (``Meta-kernels'' are sometimes called ``furnsh kernels.'') A meta-kernel is a SPICE text kernel that lists the names of the kernels to load. At run time, the user's application supplies the name of the meta-kernel as an input argument to furnsh_c. For example, instead of loading kernels using the code fragment: 
 
 
   #include "SpiceUsr.h"
        .
        .
        .
   furnsh_c ( "leapseconds.tls"  );
   furnsh_c ( "mgs.tsc"          );
   furnsh_c ( "generic.bsp"      );
   furnsh_c ( "mgs.bc"           );
   furnsh_c ( "earth.bpc"        );
   furnsh_c ( "mgs.bes"          );
 
 
one may now write
 
   #include "SpiceUsr.h"
        .
        .
        .
   furnsh_c ( "kernels.tm" );
 
 
 
where the file ``kernels.tm'' is a SPICE text meta-kernel containing the
   lines
 
   KPL/MK
   \begindata
 
   KERNELS_TO_LOAD = ( 'leapseconds.tls',
                       'mgs.tsc',
                       'generic.bsp',
                       'mgs.bc',
                       'earth.bpc',
                       'mgs.bes'           )
 
   \begintext
This technique has the important advantage of enabling a user to easily
   change the set of kernels to be loaded without modifying his source
   code.While far less robust, it is also possible to provide the names of kernels to be loaded as input arguments to furnsh_c. For example, one may write 
 
 
 
   #include "SpiceUsr.h"
        .
        .
        .
 
   #define NKER  6
 
   char  * kernels[NKER] = {  "leapseconds.tls",
                              "mgs.tsc",
                              "generic.bsp",
                              "mgs.bc",
                              "earth.bpc",
                              "mgs.bes"        };
 
   for ( int i = 0;  i < NKER;  i++ )
      {
      furnsh_c ( kernels[i] );
      }
 
 
Kernel Priority
 If orientation data for a given body-fixed frame are provided in both a text PCK and a binary PCK, data from the binary PCK always have higher priority. Path Symbols in Meta-kernels
 
 PATH_VALUES PATH_SYMBOLSTo create symbols for path names, one assigns an array of path names to the variable PATH_VALUES. Next, one assigns an array of corresponding symbol names to the variable PATH_SYMBOLS. The nth symbol in the second array represents the nth path name in the first array. Then you can prefix with path symbols the kernel names specified in the KERNELS_TO_LOAD variable. Each symbol is prefixed with a dollar sign to indicate that it is in fact a symbol. Suppose in our example above the MGS kernels reside in the path 
 /flight_projects/mgs/SPICE_kernelsand the other kernels reside in the path 
 /generic/SPICE_kernelsThen we can add paths to our meta-kernel as follows: 
 
   \begindata
 
   PATH_VALUES  = ( '/flight_projects/mgs/SPICE_kernels',
                    '/generic/SPICE_kernels'              )
 
   PATH_SYMBOLS = ( 'MGS',
                    'GEN' )
 
 
   KERNELS_TO_LOAD = ( '$GEN/leapseconds.tls',
                       '$MGS/mgs.tsc',
                       '$GEN/generic.bsp',
                       '$MGS/mgs.bc',
                       '$GEN/earth.bpc',
                       '$MGS/mgs.bes'           )
 
   \begintext
It is not required that paths be abbreviated using path symbols; it's
   simply a convenience available to you.Caution: the symbols defined using PATH_SYMBOLS are not related to the symbols supported by a host shell or any other operating system interface. Keeping Track of Loaded Kernels
 When a kernel is loaded using furnsh_c, a new entry is created in the database of loaded kernels, whether or not the kernel is already loaded. All load and unload operations (see the discussion of unload_c below) affect the list of loaded kernels and therefore affect the results returned by the functions ktotal_c, kdata_c, and kinfo_c, all of which are discussed below under ``Finding Out What's Loaded.'' Reloading Kernels
 Changing Kernel Priority
 Load Limits
 The DAF/DAS handle manager system imposes its own limit on the number of DAF binary kernels that may be loaded simultaneously. This limit is currently set to a total of 5000 DAF kernels. Finding Out What's Loaded
 CSPICE provides kernel access functions to support these needs. For every loaded kernel, an application can find the name of the kernel, the kernel type (text or one of SPK, CK, PCK, or EK), the kernel's DAF or DAS handle if applicable, and the name of the meta-kernel used to load the kernel, if applicable. The function ktotal_c returns the count of loaded kernels of a given type. The function kdata_c returns information on the nth kernel of a given type. The two functions are normally used together. The following example shows how an application could retrieve summary information on the currently loaded SPK files: 
 
 
      #include <stdio.h>
      #include "SpiceUsr.h"
 
      #define  FILLEN   128
      #define  TYPLEN   32
      #define  SRCLEN   128
 
      SpiceInt        which;
      SpiceInt        handle;
 
      SpiceChar       file  [FILLEN];
      SpiceChar       filtyp[TYPLEN];
      SpiceChar       source[SRCLEN];
 
      SpiceBoolean    found;
           .
           .
           .
 
      ktotal_c ( "spk", &count );
 
      if ( count == 0 )
         {
         printf ( "No SPK files loaded at this time.\n" );
         }
      else
         {
         printf ( "The loaded SPK files are: \n\n" );
         }
 
      for ( which = 0;  which < count;  which++ )
         {
         kdata_c ( which,  "spk",    FILLEN,   TYPLEN, SRCLEN,
                   file,   filtyp,  &source, &handle,  &found );
         printf ( "%s\n",  file   );
         }
 
 
Above, the input argument"spk" is a kernel type specifier. The allowed set of values is shown below. 
 
            SPK  --- Only SPK kernels are counted in the total
            CK   --- Only CK kernels are counted in the total
            PCK  --- Only binary PCK kernels are counted in the
                     total
            EK   --- Only EK kernels are counted in the total
            TEXT --- Only text kernels that are not meta-
                     kernels are included in the total
            META --- Only meta-kernels are counted in the
                     total
            ALL  --- Every type of kernel is counted in the
                     total
In this example, `filtyp' is a string indicating the type of kernel.
   `handle' is the file handle if the file is a binary SPICE kernel.
   `source' is the name of the meta-kernel used to load the kernel, if
   applicable. `found' indicates whether a kernel having the specified type
   and index was found.CSPICE also contains the function kinfo_c that returns summary information about a kernel whose name is already known. kinfo_c is called as follows: 
 
 
      kinfo_c ( file,   TYPLEN, SRCLEN,
                filtyp, source, &handle, &found );
 
 
Unloading Kernels
 
 
 
 
 Text kernels are unloaded by clearing the kernel pool and then reloading the other text kernels not designated for removal. Note that unloading text kernels has the side effect of wiping out any kernel variables and associated values that had been entered in the kernel pool using any of the kernel pool assignment functions, such as pcpool_c. It is important to consider whether this side effect is acceptable when writing code that may unload text kernels or meta-kernels. Call unload_c as follows: 
 
 
      unload_c ( kernel );
 
 
Unloading a meta-kernel involves unloading all the kernels referenced by
   the meta-kernel.Loading of Non-native Text and Binary Kernels
 
 
   Environment                  Native End-Of-Line
                                Indicator
   ___________                  _____________________
 
   PC DOS/Windows                <CR><LF>
   Unix                          <LF>
   Linux                         <LF>
   Mac OS X                      <LF>
As of CSPICE version N0059, the CSPICE text kernel loader furnsh_c (and
   the deprecated loader ldpool_c) can read and parse non-native text
   files. (Caution: the FORTRAN SPICELIB text kernel readers do not include
   this capability.)The CSPICE text file reader, rdtext_c, does not possess the capability to read non-native text files. Starting with the version N0052 release of the SPICE Toolkit (January, 2002), supported platforms are able to read DAF-based binary kernels (SPK, CK and binary PCK) that were written using a non-native binary representation. This access is read-only; any operations requiring writing to the file--for example, adding information to the comment area, or appending additional ephemeris data-- require prior conversion of the kernel to the native binary file format. See the ``Convert User's Guide'' for details. Manipulating Kernel Pool Contents
 
 
 
 
 
 
 
 
 
 
 
   #include "SpiceUsr.h"
          .
          .
          .
   #define  LNSIZE      81
   #define  BUFSIZE     30
 
   static SpiceChar     text [BUFSIZE][LNSIZE] =
      {
      "DELTET/DELTA_T_A =   32.184",
      "DELTET/K         =    1.657D-3",
      "DELTET/EB        =    1.671D-2",
      "DELTET/M         = (  6.239996D0",
      "                      1.99096871D-7 )",
      "DELTET/DELTA_AT  = ( 10, @1972-JAN-1",
      "                     11, @1972-JUL-1",
      "                     12, @1973-JAN-1",
      "                     13, @1974-JAN-1",
      "                     14, @1975-JAN-1",
      "                     15, @1976-JAN-1",
      "                     16, @1977-JAN-1",
      "                     17, @1978-JAN-1",
      "                     18, @1979-JAN-1",
      "                     19, @1980-JAN-1",
      "                     20, @1981-JUL-1",
      "                     21, @1982-JUL-1",
      "                     22, @1983-JUL-1",
      "                     23, @1985-JUL-1",
      "                     24, @1988-JAN-1",
      "                     25, @1990-JAN-1",
      "                     26, @1991-JAN-1",
      "                     27, @1992-JUL-1",
      "                     28, @1993-JUL-1",
      "                     29, @1994-JUL-1",
      "                     30, @1996-JAN-1",
      "                     31, @1997-JUL-1",
      "                     32, @1999-JAN-1",
      "                     33, @2006-JAN-1",
      "                     34, @2009-JAN-1  )"
      };
 
      /*
      Add the contents of the buffer to the kernel pool:
      */
      lmpool_c ( text, BUFSIZE );
 
 
See the headers of the kernel subsystem functions for specific details
   regarding their use.Detecting Changes in the Kernel Pool Using Watchers
 
 
 
 Appendix A -- Discussion of Competing DataBinary Kernels
 SPKs
 By definition, SPKs contain continuous data during the time interval covered by a segment, so there is no chance for a ``data gap'' in a segment within a higher priority file (later loaded file) leading to a state lookup coming from a segment in a lower priority file. SPK segment chaining may lead to a problem. It may happen that you have loaded into your program sufficient SPK data to compute the desired state or position vector, but CSPICE nevertheless returns an error message saying insufficient ephemeris data have been loaded. This can occur if a higher priority SPK segment, for which there are not sufficient additional SPK data to fully construct your requested state or position vector, is masking (blocking) a segment that is part of a viable (complete) chain. See the BACKUP section of the SPK tutorial for further discussion about this. Having competition between two SPKs can be a relatively common occurrence when using mission operations kernels, but is far less likely when using PDS-archived SPICE data sets because of the clean-up and consolidation actions usually taken when an archive delivery is produced. CKs
 If transformation data from any two segments, whether found in a single CK file or in two CK files, are for the same object/structure (are for the same ``to'' frame) and have an overlap in the time span covered, then the two kernels may have competing data. But read on. However, unlike for SPKs, competition between CK files goes beyond segment-level considerations. The so-called ``continuous'' CK types (Types 2 through 5) do not necessarily provide orientation results for any epoch falling within a segment--there may be real data gaps. And the now little used Type 1 CK, containing discrete instances of orientation data, can be thought of as containing mostly data gaps. While some of the Toolkit software used to compute orientation obtained from CKs can provide an orientation result within a gap, this is usually not the case. See the CK tutorial and the ``CK Required Reading'' document for discussions on interpolation intervals, tolerance, and how the various CK readers work. CK segment chaining may lead to a problem. It may happen that you have loaded into your program sufficient CK data to compute the desired rotation matrix, but CSPICE nevertheless returns an error message saying insufficient data have been loaded. This can occur if a higher priority CK segment, for which there are not sufficient additional CK data to fully construct your requested rotation matrix, is masking (blocking) a segment that is part of a viable (complete) chain. Having competition between two CKs can be a relatively common occurrence when using mission operations kernels, but is far less likely when using PDS-archived SPICE data sets because of the clean-up and consolidation actions usually taken when an archive delivery is prepared. Binary PCKs
 At present binary PCKs produced by NAIF exist only for the earth and the moon. Having competition between the latest high precision, short term earth orientation binary PCK and the lower precision, long term predict earth orientation binary PCK is a clear possibility -- be sure to load the long term predict file first to ensure any higher precision files also loaded have higher priority. Orientation data provided in any loaded binary PCK have priority over what would have otherwise been competing data provided in any loaded text PCK. Text Kernels
 It is generally best to unload a text kernel before loading another one containing competing data. Appendix B -- Glossary of TermsAgent
 Often the string is the name of a function that needs to be informed if any of a specified set of kernel variables has had a change made to its associated value(s). Assignment
 
 BODY399_RADII = ( 6378.14 6378.14 6356.75 )is an assignment with a vector value. Once a text kernel is loaded, the value(s) on the right hand sides of the assignments become associated with the variable names on the corresponding left hand sides. See ``direct assignment'' and ``incremental assignment'' below. Continued string
 Control words
 
 \begindata \begintext Direct assignment
 Element
 Incremental assignment
 Keeper (subsystem)
 Kernel pool (sometimes just called ``the pool'')
 Kernel variable
 Meta-kernel (also known as ``FURNSH kernel'')
 Operator
 Principal data
 Value
 variable name = value(s) Variable name
 variable name = value(s) Vector value
 Appendix C -- Summary of Routines
 
 clpool_c ( Clear the pool of kernel variables ) cvpool_c ( Check variable in the pool for update ) dtpool_c ( Return information about a kernel pool variable ) dvpool_c ( Delete a variable from the kernel pool ) expool_c ( Confirm the existence of a pool kernel variable ) furnsh_c ( Furnish a program with SPICE kernels ) gcpool_c ( Get character data from the kernel pool ) gdpool_c ( Get double precision values from the kernel pool ) gipool_c ( Get integers from the kernel pool ) gnpool_c ( Get names of kernel pool variables ) kclear_c ( Clear and re-initialize the kernel database ) kdata_c ( Return information about the nth loaded kernel ) kinfo_c ( Return information about a specific loaded kernel ) ktotal_c ( Return the number of kernels loaded using KEEPER ) lmpool_c ( Load variables from memory into the pool ) pcpool_c ( Put character strings into the kernel pool ) pdpool_c ( Put double precision values into the kernel pool ) pipool_c ( Put integers into the kernel pool ) stpool_c ( Return a string associated with a kernel variable ) swpool_c ( Set watch on a pool variable ) szpool_c ( Get size parameters of the kernel pool) unload_c ( Unload a kernel ) Appendix D -- Summary of Key Text Kernel Parameter Values
 
 
   Maximum variable name length:                         32
   Maximum length of any element of a string value:      80
   Maximum number of distinct variables:              26003
   Maximum number of numeric variable values:        400000
   Maximum number of character strings
    stored in the kernel pool as values:              15000
   Maximum length of a file name, including any
    path specification, placed in a meta-kernel:        255
Other applicable limits
 Maximum total number of kernel files of any type that can be loaded simultaneously: 5000 Appendix E -- Revision History
 Updated numeric limits. Added discussion of kernel loading errors. Made small additions to discussion of file name restrictions. Added mention of treatment by GIPOOL of non-integer values. Made small addition to discussion of ``@'' time values in text kernels. Corrected a ``setparamsize'' setting that truncated function names. Changed quoting style to standard (`` '')for .ftm documents. Changed double quotes to single quotes in IDL code example. Made other miscellaneous, minor edits. 2011 October 24, CHA (JPL) Re-organization and added further clarifications. Also added Appendix A discussion of competing data, Appendix B providing a glossary of terms, and an Appendix C summarizing kernel subsystem functions. Includes much information provided by N. Bachman. 2011 APR 18, EDW (JPL) Edits for clarity and organization. Added description of the 32 character limit on user defined kernel pool variable names for furnsh_c, lmpool_c, pcpool_c, pdpool_c, and pdpool_c. Added mention that tabs are now allowed in text kernels. kclear_c now included in routines list. 2009 APR 08, BVS (JPL) Previous edits. 
 |