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
cspice_tparch

Table of contents
Abstract
I/O
Parameters
Examples
Particulars
Exceptions
Files
Restrictions
Required_Reading
Literature_References
Author_and_Institution
Version
Index_Entries

Abstract


   CSPICE_TPARCH restricts the set of strings that are recognized by SPICE
   time parsing routines to those that have standard values for all time
   components.

I/O


   Given:

      type     a character string that is used to adjust the set of strings
               that will be regarded as valid time strings by SPICE time
               parsing routines.

               [1,c1] = size(type); char = class(type)

                  or

               [1,1] = size(type); cell = class(type)

               The default behavior of SPICE time software is to allow
               an extended range of values for the various components
               (tokens) of a time string. For example, using its default
               behavior, cspice_tparse would regard 1993 JAN 367 as a valid
               time string and return the UTC seconds past the J2000
               epoch value that corresponds to Jan 2, 1994.

               While this is a "reasonable" interpretation of such a
               string, there may be occasions when such a string should
               be regarded as an error.

               By calling cspice_tparch with a value of 'YES', the action of
               the time software will be modified. Strings that have
               components that are out of the range of values used in
               most English discourse will be regarded as errors. Thus
               the numeric values of MONTH, DAY, HOUR, MINUTE, and
               SECOND must satisfy the following conditions to be
               regarded as legitimate calendar time strings.

                  ITEM     Valid Range
                  ------   -----------------------------------------
                  MONTH    1 to 13
                  DAY      1 to 365 (366 for leap years) when
                           DAY is interpreted as the day of year
                           i.e. the month token is empty.
                           1 to 31  if month is January
                           1 to 28  (29 in leap years) if month is
                                    February
                           1 to 31  if month is March
                           1 to 30  if month is April
                           1 to 31  if month is May
                           1 to 31  if month is June
                           1 to 30  if month is July
                           1 to 31  if month is August
                           1 to 30  if month is September
                           1 to 31  if month is October
                           1 to 30  if month is November
                           1 to 31  if month is December
                  HOUR     0 to 23
                  MINUTE   0 to 59
                  SECOND   0 up to but not including 60 on days that
                           can not have a leapsecond.
                           0 up to but not including 61 for times
                           that are the last second of June or
                           December. In other words,
                                JUN 30, 23:59:60.xxxxxx...x
                           and  DEC 31, 23:59:60.xxxxxx...x

               To reset the action of time software to the default
               action, set `type' to a value that is not equivalent to
               'YES' when case and spaces are ignored.

   the call:

      cspice_tparch( type )

   returns:

      None.

Parameters


   None.

Examples


   Any numerical results shown for this example may differ between
   platforms as the results depend on the SPICE kernels used as input
   and the machine specific arithmetic implementation.

   1) When accepting times as input interactively, you usually
      read a string typed at a keyboard and then pass that string
      to the SPICE time system to convert it to an ephemeris time.
      The default behavior of SPICE software is to accept strings
      such as FEB 34, 1993 and to interpret these in a "natural way"
      (FEB 34, 1993 is regarded as MARCH 6, 1993.) The following
      example code demonstrates how to modify this behavior.


      Example code begins here.


      function tparch_ex1()

         %
         % Local parameters.
         %
         TIMSTR =   'FEB 34, 1993';

         %
         % First, demonstrate the default behavior of SPICE.
         % Let's get the number of UTC seconds past J2000 epoch.
         %
         [sp2000, errmsg] = cspice_tparse( TIMSTR );

         if ( strcmp( errmsg, '' ) )

            fprintf( 'UTC (s):  %17.6f\n', sp2000 )

         else

            fprintf( 'Error  : %s\n', errmsg )

         end

         %
         % Now, turn error checking on and parse the time string
         % again.
         %
         cspice_tparch( 'YES' );
         [sp2000, errmsg] = cspice_tparse( TIMSTR );

         if ( strcmp( errmsg, '' ) )

            fprintf( 'UTC (s):  %17.6f\n', sp2000 )

         else

            fprintf( 'Error  : %s\n', errmsg )

         end


      When this program was executed on a Mac/Intel/Octave6.x/64-bit
      platform, the output was:


      UTC (s):  -215352000.000000
      Error  : The day of the month specified for the month of February was***


      Warning: incomplete output. 1 line extended past the right
      margin of the header and has been truncated. This line is
      marked by "***" at the end of the line.


Particulars


   This routine is used to alter the collections of strings
   that SPICE software regards as legitimate calendar strings. The
   default behavior of SPICE software is to accept strings such
   as FEB 34, 1993 and to interpret these in a "natural way"
   (FEB 34, 1993 is regarded as MARCH 6, 1993.) This behavior
   is sometimes useful for "private" programs that you write.
   However, such a string may be a typo (a finger accidentally hit
   two keys for the day instead of one). Given that this string
   does not appear in common usage, you may want to consider
   that it is more likely the result of erroneous input. You
   can alter the behavior of SPICE software so that it will
   treat such a string as an error. To do this call this entry
   point with `type' having the value 'YES'.

      cspice_tparch( 'YES' );

   Until the behavior is reset by calling cspice_tparch with a value
   other than 'YES' (such as 'NO'), SPICE software will treat all
   out-of-bound components of time strings as errors.

   If you are happy with the SPICE default interpretation of
   strings, you do not need to make any calls to cspice_tparch.

   All time parsing routines --including the top-level API cspice_tparse--
   respect the setting assigned by cspice_tparch, except the
   Mice routine cspice_str2et.

Exceptions


   1)  If the input argument `type' is undefined, an error is
       signaled by the Matlab error handling system.

   2)  If the input argument `type' is not of the expected type, or
       it does not have the expected dimensions and size, an error is
       signaled by the Mice interface.

Files


   None.

Restrictions


   None.

Required_Reading


   MICE.REQ
   TIME.REQ

Literature_References


   None.

Author_and_Institution


   J. Diaz del Rio     (ODC Space)

Version


   -Mice Version 1.0.0, 01-NOV-2021 (JDR)

Index_Entries


   Restrict time strings to proper form


Fri Dec 31 18:44:28 2021