void mxmtg_c ( const void * m1,
const void * m2,
SpiceInt nrow1,
SpiceInt nc1c2,
SpiceInt nrow2,
void * mout )
Multiply a matrix and the transpose of a matrix, both of
arbitrary size.
None.
MATRIX
VARIABLE I/O DESCRIPTION
-------- --- --------------------------------------------------
m1 I Left-hand matrix to be multiplied.
m2 I Right-hand matrix whose transpose is to be multiplied
nrow1 I Row dimension of m1 and row dimension of mout.
nc1c2 I Column dimension of m1 and column dimension of m2.
nrow2 I Row dimension of m2 and column dimension of mout.
mout O Product matrix.
m1 may be any double precision matrix of arbitrary size.
m2 may be any double precision matrix of arbitrary size.
The number of columns in m2 must match the number of
columns in m1.
nrow1 is the number of rows in both m1 and mout.
nc1c2 i the number of columns in m1 and (by necessity) the
number of columns of m2.
nrow2 is the number of rows in both m2 and the number of columns
in mout.
mout is the product matrix given by
t
mout = (m1) x (m2)
where the superscript "t" denotes the transpose matrix.
This is a double precision matrix of dimension nrow1 x
nrow2.
mout may overwrite m1 or m2. Note that this capability
does not exist in the Fortran version of SPICELIB; in the
Fortran version, the output must not overwrite either
input.
None.
Error free.
None.
The code reflects precisely the following mathematical expression
For each value of the subscript i from 1 to nrow1, and j from 1
to nrow2:
mout(i,j) = summation from k=1 to nc1c2 of ( m1(i,k) * m2(j,k) )
Notice that the order of the subscripts of m2 are reversed from
what they would be if this routine merely multiplied m1 and m2.
It is this transposition of subscripts that makes this routine
multiply m1 and the TRANPOSE of m2.
1) Let m1 =
| 1.0 2.0 3.0 |
| |
| 3.0 2.0 1.0 |
Let m2 =
| 1.0 2.0 0.0 |
| |
| 2.0 1.0 2.0 |
| |
| 1.0 2.0 0.0 |
| |
| 2.0 1.0 2.0 |
Here
nrow1 = 2
nc1c2 = 3
nrow2 = 4
so the call
mxmtg_c ( m1, m2, nrow1, nc1c2, nrow2, mout );
produces the matrix
mout = | 5.0 10.0 5.0 10.0 |
| |
| 7.0 10.0 7.0 10.0 |
No error checking is performed to prevent numeric overflow or
underflow.
No error checking is performed to determine if the input and
output matrices have, in fact, been correctly dimensioned.
The user is responsible for checking the magnitudes of the
elements of m1 and m2 so that a floating point overflow does
not occur.
None.
N.J. Bachman (JPL)
W.M. Owen (JPL)
-CSPICE Version 1.2.0, 28-AUG-2001 (NJB)
Const-qualified input arrays.
-CSPICE Version 1.1.0, 08-FEB-1998 (NJB)
Corrected a comment describing the local macro INDEX. Made
miscellaneous code format corrections.
-CSPICE Version 1.0.0, 25-OCT-1997 (NJB)
Based on SPICELIB Version 1.0.1, 10-MAR-1992 (WLT)
matrix times matrix_transpose n-dimensional_case
Link to routine mxmtg_c source file mxmtg_c.c
|