| unormg_c | 
| Table of contents Procedure
   unormg_c ( Unit vector and norm, general dimension ) 
   void unormg_c ( ConstSpiceDouble    v1     [],
                   SpiceInt            ndim,
                   SpiceDouble         vout   [],
                   SpiceDouble       * vmag    )
AbstractNormalize a double precision vector of arbitrary dimension and return its magnitude. Required_ReadingNone. KeywordsVECTOR Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- v1 I Vector to be normalized. ndim I Dimension of `v1' (and also `vout'). vout O Unit vector v1 / ||v1||. vmag O Magnitude of `v1', i.e. ||v1||. Detailed_Input
   v1          is an arbitrary double precision n-dimensional vector,
               including the zero vector.
   ndim        is the dimension of `v1' and `vout'.
Detailed_Output
   vout        is the double precision n-dimensional unit vector in the
               direction of `v1'. If `v1' is the zero vector, then `vout'
               will also be the zero vector.
   vmag        is the magnitude of `v1'.
ParametersNone. ExceptionsError free. FilesNone. Particularsunormg_c references a function called vnormg_c (which itself is numerically stable) to calculate the norm of the input vector `v1'. If the norm is equal to zero, then each component of the output vector `vout' is set to zero. Otherwise, `vout' is calculated by dividing `v1' by the norm. No error detection or correction is implemented. Examples
   The 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) Define a set of n-dimensional vectors and compute their
      corresponding unit vectors and magnitudes.
      Example code begins here.
      /.
         Program unormg_ex1
      ./
      #include <stdio.h>
      #include "SpiceUsr.h"
      int main( )
      {
         /.
         Local parameters.
         ./
         #define NDIM         4
         #define SETSIZ       2
         /.
         Local variables.
         ./
         SpiceDouble          vmag;
         SpiceDouble          vout   [NDIM];
         SpiceInt             i;
         /.
         Define the vector set.
         ./
         SpiceDouble          v1     [SETSIZ][NDIM] = {
                                   { 5.0,   12.0,   0.0,   4.0 },
                                   { 1.e-6,  2.e-6, 2.e-6, 0.0 } };
         /.
         Calculate the unit vectors and magnitudes.
         ./
         for ( i = 0; i < SETSIZ; i++ )
         {
            unormg_c ( v1[i], NDIM, vout, &vmag );
            printf( "Vector     : %11.7f %11.7f %11.7f %11.7f\n",
                           v1[i][0], v1[i][1], v1[i][2], v1[i][3] );
            printf( "Unit vector: %11.7f %11.7f %11.7f %11.7f\n",
                               vout[0], vout[1], vout[2], vout[3] );
            printf( "Magnitude  : %11.7f\n", vmag );
            printf( "\n" );
         }
         return ( 0 );
      }
      When this program was executed on a Mac/Intel/cc/64-bit
      platform, the output was:
      Vector     :   5.0000000  12.0000000   0.0000000   4.0000000
      Unit vector:   0.3676073   0.8822575   0.0000000   0.2940858
      Magnitude  :  13.6014705
      Vector     :   0.0000010   0.0000020   0.0000020   0.0000000
      Unit vector:   0.3333333   0.6666667   0.6666667   0.0000000
      Magnitude  :   0.0000030
Restrictions
   1)  No error checking is implemented in this function to guard
       against numeric overflow.
Literature_ReferencesNone. Author_and_InstitutionN.J. Bachman (JPL) J. Diaz del Rio (ODC Space) E.D. Wright (JPL) Version
   -CSPICE Version 1.3.0, 05-JUL-2021 (JDR)
       Edited the header to comply with NAIF standard. Added complete
       code example based on existing example.
       Updated wrapper to call f2c'ed SPICELIB version.
   -CSPICE Version 1.2.0, 06-FEB-2017 (EDW)
       Bug fix: eliminated spurious semi-colon on "for(...)" line.
       This caused the output vector not to be set when the input
       argument `v1' was the zero vector.
       Corrected section order.
   -CSPICE Version 1.1.0, 22-OCT-1998 (NJB)
       Made input vector const. Converted check-in style to discovery.
   -CSPICE Version 1.0.0, 31-MAR-1998 (EDW)
Index_Entriesn-dimensional unit vector and norm | 
Fri Dec 31 18:41:14 2021