wncomd |
Table of contents
ProcedureWNCOMD ( Complement a DP window ) SUBROUTINE WNCOMD ( LEFT, RIGHT, WINDOW, RESULT ) AbstractDetermine the complement of a double precision window with respect to the interval [LEFT,RIGHT]. Required_ReadingWINDOWS KeywordsWINDOWS DeclarationsIMPLICIT NONE INTEGER LBCELL PARAMETER ( LBCELL = -5 ) DOUBLE PRECISION LEFT DOUBLE PRECISION RIGHT DOUBLE PRECISION WINDOW ( LBCELL:* ) DOUBLE PRECISION RESULT ( LBCELL:* ) Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- LEFT, RIGHT I Left, right endpoints of complement interval. WINDOW I Input window. RESULT O Complement of WINDOW with respect to [LEFT,RIGHT]. Detailed_InputLEFT, RIGHT are the left and right endpoints of the complement interval. WINDOW is the window to be complemented. Detailed_OutputRESULT is the output window, containing the complement of WINDOW with respect to the interval from LEFT to RIGHT. If the output window is not large enough to contain the result, as many intervals as will fit are returned. RESULT must be distinct from WINDOW. ParametersNone. Exceptions1) If LEFT is greater than RIGHT, the error SPICE(BADENDPOINTS) is signaled. 2) The cardinality of the input WINDOW must be even. Left endpoints of stored intervals must be strictly greater than preceding right endpoints. Right endpoints must be greater than or equal to corresponding left endpoints. Invalid window data are not diagnosed by this routine and may lead to unpredictable results. FilesNone. ParticularsMathematically, the complement of a window contains those points that are not contained in the window. That is, the complement of the set of closed intervals [ a(1), b(1) ], [ a(2), b(2) ], ..., [ a(n), b(n) ] is the set of open intervals ( -inf, a(1) ), ( b(1), a(2) ), ..., ( b(n), +inf ) Because Fortran offers no satisfactory representation of infinity, we must take the complement with respect to a finite interval. In addition, Fortran offers no satisfactory floating point representation of open intervals. Therefore, the complement of a floating point window is closure of the set theoretical complement. In short, the floating point complement of the window [ a(1), b(1) ], [ a(2), b(2) ], ..., [ a(n), b(n) ] with respect to the interval from LEFT to RIGHT is the intersection of the windows ( -inf, a(1) ], [ b(1), a(2) ], ..., [ b(n), +inf ) and [ LEFT, RIGHT ] Note that floating point intervals of measure zero (singleton intervals) in the original window are replaced by gaps of measure zero, which are filled. Thus, complementing a floating point window twice does not necessarily yield the original window. ExamplesLet WINDOW contain the intervals [ 1, 3 ] [ 7, 11 ] [ 23, 27 ] Then the floating point complement of WINDOW with respect to [2,20] contains the intervals [ 3, 7 ] [ 11, 20 ] and the complement with respect to [ 0, 100 ] contains [ 0, 1 ] [ 3, 7 ] [ 11, 23 ] [ 27, 100 ] RestrictionsNone. Literature_ReferencesNone. Author_and_InstitutionN.J. Bachman (JPL) J. Diaz del Rio (ODC Space) H.A. Neilan (JPL) W.L. Taber (JPL) I.M. Underwood (JPL) VersionSPICELIB Version 1.1.0, 06-JUL-2021 (JDR) (NJB) Added IMPLICIT NONE statement. Edited the header to comply with NAIF standard. Removed unnecessary $Revisions section. Added entry #2 in $Exceptions section. SPICELIB Version 1.0.1, 10-MAR-1992 (WLT) Comment section for permuted index source lines was added following the header. SPICELIB Version 1.0.0, 31-JAN-1990 (WLT) (IMU) (HAN) (NJB) |
Fri Dec 31 18:37:07 2021