Class GMatrixd
- java.lang.Object
- 
- WildMagic.LibFoundation.Mathematics.GMatrixd
 
- 
- All Implemented Interfaces:
- java.io.Serializable
 
 public class GMatrixd extends java.lang.Object implements java.io.SerializableMatrix operations are applied on the left. For example, given a matrix M and a vector V, matrix-times-vector is M*V. That is, V is treated as a column vector. Some graphics APIs use V*M where V is treated as a row vector. In this context the "M" matrix is really a transpose of the M as represented in Wild Magic. Similarly, to apply two matrix operations M0 and M1, in that order, you compute M1*M0 so that the transform of a vector is (M1*M0)*V = M1*(M0*V). Some graphics APIs use M0*M1, but again these matrices are the transpose of those as represented in Wild Magic. You must therefore be careful about how you interface the transformation code with graphics APIS. Matrices are stored in row-major order, matrix[row][col].- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description private double[]m_adDatathe matrix is stored in row-major form as a 1-dimensional arrayprivate intm_iColsrows, columns, and size:private intm_iQuantityrows, columns, and size:private intm_iRowsrows, columns, and size:private static longserialVersionUID
 - 
Constructor SummaryConstructors Constructor Description GMatrixd()Construct a general matrix of size 0,0.GMatrixd(int iRows, int iCols)Construct a general matrix of size iRows,iCols.GMatrixd(int iRows, int iCols, double[] adEntry)Construct a general matrix of size iRows,iCols.GMatrixd(int iRows, int iCols, double[][] aadMatrix)Construct a general matrix of size iRows,iCols.GMatrixd(int iRows, int iCols, float[][] aafMatrix)Construct a general matrix of size iRows,iCols.GMatrixd(GMatrixd rkM)Construct a general matrix that is the copy of the input matrix.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description private voidAllocate(boolean bSetToZero)Support for allocation and deallocation.voidCopy(GMatrixd rkM)Set this to the copy of the input matrix.private voidDeallocate()Delete the matrix data.voiddispose()Deallocate the matrix.doubleGet(int iRow, int iCol)Get the value of the matrix at the location iRow, iCol.GVectordGetColumn(int iCol)Get the value of the matrix for the iCol th column.intGetColumns()Get the number of columns in the matrix.double[]GetData()Get the matrix values in double[] format.voidGetData(double[][] aadMatrix)intGetQuantity()Get the size of the matrix rows*columns.GVectordGetRow(int iRow)Get the value of the matrix for the iRow th row.intGetRows()Get the number of rows in the matrix.booleanInverse()GMatrixdMult(GMatrixd rkM)voidSet(int iRow, int iCol, double dValue)Set the value of the matrix at the location iRow, iCol.voidSetColumn(int iCol, GVectord rkV)Set the value of the matrix for the iCol th column.voidSetMatrix(int iRows, int iCols, double[] adEntry)voidSetMatrix(int iRows, int iCols, double[][] aadMatrix)Construct a general matrix of size iRows,iCols.voidSetMatrix(int iRows, int iCols, float[][] aafMatrix)Construct a general matrix of size iRows,iCols.voidSetRow(int iRow, GVectord rkV)Set the value of the matrix for the iRow th row.voidSetSize(int iRows, int iCols)Set the matrix size.voidSwapRows(int iRow0, int iRow1)Swap the iRow0 and iRow1 in the matrix.java.lang.StringtoString()
 
- 
- 
- 
Field Detail- 
serialVersionUIDprivate static final long serialVersionUID - See Also:
- Constant Field Values
 
 - 
m_iRowsprivate int m_iRows rows, columns, and size:
 - 
m_iColsprivate int m_iCols rows, columns, and size:
 - 
m_iQuantityprivate int m_iQuantity rows, columns, and size:
 - 
m_adDataprivate double[] m_adData the matrix is stored in row-major form as a 1-dimensional array
 
- 
 - 
Constructor Detail- 
GMatrixdpublic GMatrixd() Construct a general matrix of size 0,0.
 - 
GMatrixdpublic GMatrixd(GMatrixd rkM) Construct a general matrix that is the copy of the input matrix.- Parameters:
- rkM- input matrix.
 
 - 
GMatrixdpublic GMatrixd(int iRows, int iCols)Construct a general matrix of size iRows,iCols.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
 
 - 
GMatrixdpublic GMatrixd(int iRows, int iCols, double[] adEntry)Construct a general matrix of size iRows,iCols. Copy the adEntry array into the new matrix.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
- adEntry- matrix values.
 
 - 
GMatrixdpublic GMatrixd(int iRows, int iCols, float[][] aafMatrix)Construct a general matrix of size iRows,iCols. Copy the aafMatrix into the new matrix.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
- aafMatrix- matrix values.
 
 - 
GMatrixdpublic GMatrixd(int iRows, int iCols, double[][] aadMatrix)Construct a general matrix of size iRows,iCols. Copy the aadMatrix into the new matrix.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
- aadMatrix- matrix values.
 
 
- 
 - 
Method Detail- 
Copypublic void Copy(GMatrixd rkM) Set this to the copy of the input matrix.- Parameters:
- rkM- input matrix.
 
 - 
disposepublic void dispose() Deallocate the matrix.
 - 
Getpublic double Get(int iRow, int iCol)Get the value of the matrix at the location iRow, iCol.- Parameters:
- iRow- row position.
- iCol- column position.
- Returns:
- the matrix value at the location iRow, iCol.
 
 - 
GetColumnpublic GVectord GetColumn(int iCol) Get the value of the matrix for the iCol th column.- Parameters:
- iCol- column to get.
- Returns:
- a general vector containing the column values.
 
 - 
GetColumnspublic int GetColumns() Get the number of columns in the matrix.- Returns:
- the number of rows in the matrix.
 
 - 
GetDatapublic double[] GetData() Get the matrix values in double[] format.- Returns:
- the matrix values.
 
 - 
GetDatapublic void GetData(double[][] aadMatrix) 
 - 
GetQuantitypublic int GetQuantity() Get the size of the matrix rows*columns.- Returns:
- the size of the matrix rows*columns.
 
 - 
GetRowpublic GVectord GetRow(int iRow) Get the value of the matrix for the iRow th row.- Parameters:
- iRow- row to get.
- Returns:
- a general vector containing the row values.
 
 - 
GetRowspublic int GetRows() Get the number of rows in the matrix.- Returns:
- the number of rows in the matrix.
 
 - 
Inversepublic boolean Inverse() 
 - 
Setpublic void Set(int iRow, int iCol, double dValue)Set the value of the matrix at the location iRow, iCol.- Parameters:
- iRow- row position.
- iCol- column position.
- dValue- new value.
 
 - 
SetColumnpublic void SetColumn(int iCol, GVectord rkV)Set the value of the matrix for the iCol th column.- Parameters:
- iCol- column to set.
- rkV- general vector containing the new values.
 
 - 
SetMatrixpublic void SetMatrix(int iRows, int iCols, double[] adEntry)
 - 
SetMatrixpublic void SetMatrix(int iRows, int iCols, float[][] aafMatrix)Construct a general matrix of size iRows,iCols. Copy the aafMatrix into the new matrix.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
- aafMatrix- matrix values.
 
 - 
SetMatrixpublic void SetMatrix(int iRows, int iCols, double[][] aadMatrix)Construct a general matrix of size iRows,iCols. Copy the aadMatrix into the new matrix.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
- aadMatrix- matrix values.
 
 - 
SetRowpublic void SetRow(int iRow, GVectord rkV)Set the value of the matrix for the iRow th row.- Parameters:
- iRow- row to set.
- rkV- general vector containing the new values.
 
 - 
SetSizepublic void SetSize(int iRows, int iCols)Set the matrix size.- Parameters:
- iRows- number of rows in the matrix.
- iCols- number of columns in the matrix.
 
 - 
SwapRowspublic void SwapRows(int iRow0, int iRow1)Swap the iRow0 and iRow1 in the matrix.- Parameters:
- iRow0- first row to swap.
- iRow1- second row to swap.
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 - 
Allocateprivate void Allocate(boolean bSetToZero) Support for allocation and deallocation. The allocation call requires m_iRows, m_iCols, and m_iQuantity to have already been correctly initialized.- Parameters:
- bSetToZero- when true set the matrix to all 0-values.
 
 - 
Deallocateprivate void Deallocate() Delete the matrix data.
 
- 
 
-