vprjpi |
Table of contents
ProcedureVPRJPI ( Vector projection onto plane, inverted ) SUBROUTINE VPRJPI ( VIN, PROJPL, INVPL, VOUT, FOUND ) AbstractFind the vector in a specified plane that maps to a specified vector in another plane under orthogonal projection. Required_ReadingPLANES KeywordsGEOMETRY MATH PLANE VECTOR DeclarationsIMPLICIT NONE INTEGER UBPL PARAMETER ( UBPL = 4 ) DOUBLE PRECISION VIN ( 3 ) DOUBLE PRECISION PROJPL ( UBPL ) DOUBLE PRECISION INVPL ( UBPL ) DOUBLE PRECISION VOUT ( 3 ) LOGICAL FOUND Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- VIN I The projected vector. PROJPL I Plane containing VIN. INVPL I Plane containing inverse image of VIN. VOUT O Inverse projection of VIN. FOUND O Flag indicating whether VOUT could be calculated. UBPL P SPICE plane upper bound. Detailed_InputVIN, PROJPL, INVPL are, respectively, a 3-vector, a SPICE plane containing the vector, and a SPICE plane containing the inverse image of the vector under orthogonal projection onto PROJPL. Detailed_OutputVOUT is the inverse orthogonal projection of VIN. This is the vector lying in the plane INVPL whose orthogonal projection onto the plane PROJPL is VIN. VOUT is valid only when FOUND (defined below) is .TRUE. Otherwise, VOUT is undefined. FOUND indicates whether the inverse orthogonal projection of VIN could be computed. FOUND is .TRUE. if so, .FALSE. otherwise. ParametersUBPL is the upper bound of a SPICE plane array. Exceptions1) If the normal vector of either input plane does not have unit length (allowing for round-off error), the error SPICE(NONUNITNORMAL) is signaled. 2) If the geometric planes defined by PROJPL and INVPL are orthogonal, or nearly so, the inverse orthogonal projection of VIN may be undefined or have magnitude too large to represent with double precision numbers. In either such case, FOUND will be set to .FALSE. 3) Even when FOUND is .TRUE., VOUT may be a vector of extremely large magnitude, perhaps so large that it is impractical to compute with it. It's up to you to make sure that this situation does not occur in your application of this routine. FilesNone. ParticularsProjecting a vector orthogonally onto a plane can be thought of as finding the closest vector in the plane to the original vector. This "closest vector" always exists; it may be coincident with the original vector. Inverting an orthogonal projection means finding the vector in a specified plane whose orthogonal projection onto a second specified plane is a specified vector. The vector whose projection is the specified vector is the inverse projection of the specified vector, also called the "inverse image under orthogonal projection" of the specified vector. This routine finds the inverse orthogonal projection of a vector onto a plane. Related routines are VPRJP, which projects a vector onto a plane orthogonally, and VPROJ, which projects a vector onto another vector orthogonally. Examples1) Suppose VIN = ( 0.0, 1.0, 0.0 ), and that PROJPL has normal vector PROJN = ( 0.0, 0.0, 1.0 ). Also, let's suppose that INVPL has normal vector and constant INVN = ( 0.0, 2.0, 2.0 ) INVC = 4.0. Then VIN lies on the y-axis in the x-y plane, and we want to find the vector VOUT lying in INVPL such that the orthogonal projection of VOUT the x-y plane is VIN. Let the notation < a, b > indicate the inner product of vectors a and b. Since every point X in INVPL satisfies the equation < X, (0.0, 2.0, 2.0) > = 4.0, we can verify by inspection that the vector ( 0.0, 1.0, 1.0 ) is in INVPL and differs from VIN by a multiple of PROJN. So ( 0.0, 1.0, 1.0 ) must be VOUT. To find this result using SPICELIB, we can create the SPICE planes PROJPL and INVPL using the code fragment CALL NVP2PL ( PROJN, VIN, PROJPL ) CALL NVC2PL ( INVN, INVC, INVPL ) and then perform the inverse projection using the call CALL VPRJPI ( VIN, PROJPL, INVPL, VOUT ) VPRJPI will return the value VOUT = ( 0.0, 1.0, 1.0 ) Restrictions1) It is recommended that the input planes be created by one of the SPICELIB routines NVC2PL ( Normal vector and constant to plane ) NVP2PL ( Normal vector and point to plane ) PSV2PL ( Point and spanning vectors to plane ) In any case each input plane must have a unit length normal vector and a plane constant consistent with the normal vector. Literature_References[1] G. Thomas and R. Finney, "Calculus and Analytic Geometry," 7th Edition, Addison Wesley, 1988. Author_and_InstitutionN.J. Bachman (JPL) J. Diaz del Rio (ODC Space) W.L. Taber (JPL) VersionSPICELIB Version 2.1.0, 25-AUG-2021 (NJB) (JDR) Added error checks for non-unit plane normal vectors. Changed check-in style to discovery. Added IMPLICIT NONE statement. Edited the header to comply with NAIF standard. Added documentation of the parameter UBPL. SPICELIB Version 2.0.0, 17-FEB-2004 (NJB) Computation of LIMIT was re-structured to avoid run-time underflow warnings on some platforms. 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, 01-NOV-1990 (NJB) |
Fri Dec 31 18:37:06 2021