Packages

class Fac_QR_H3 extends Fac_QR[MatrixD]

The Fac_QR_H3 class provides methods to factor an 'm-by-n' matrix 'a' into the product of two matrices:

'q' - an 'm-by-n' orthogonal matrix and 'r' - an 'n-by-n' right upper triangular matrix

such that 'a = q * r'. It uses Householder orthogonalization. Note, orthogonal means that 'q.t * q = I'.

See also

www.stat.wisc.edu/~larget/math496/qr.html ------------------------------------------------------------------------------ This implementation is the easiest to understandard, but the least efficient. Caveat: for m < n use Fac_LQ. FIX: change 'aa: MatrixD' to 'aa: MatriD', requires 'times_ip_pre' in trait ------------------------------------------------------------------------------

QRDecomposition.java in Jama

5.1 and 5.2 in Matrix Computations

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Fac_QR_H3
  2. Fac_QR
  3. Error
  4. Factorization
  5. AnyRef
  6. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Fac_QR_H3(aa: MatrixD, needQ: Boolean = true)

    needQ

    whether the full q matrix is need, e.g., Regression does not

Value Members

  1. def computeQ(): Unit

    Compute the full 'q' orthogonal matrix based on updated values in 'a'.

    Compute the full 'q' orthogonal matrix based on updated values in 'a'.

    Definition Classes
    Fac_QR_H3Fac_QR
  2. def factor(): Fac_QR_H3

    Factor matrix 'a' into the product of two matrices 'a = q * r', where 'q' is an orthogonal matrix and 'r' is a right upper triangular matrix.

    Factor matrix 'a' into the product of two matrices 'a = q * r', where 'q' is an orthogonal matrix and 'r' is a right upper triangular matrix.

    Definition Classes
    Fac_QR_H3Factorization
  3. def factor1(): MatriD

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t', returning only the first matrix.

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t', returning only the first matrix.

    Definition Classes
    Factorization
  4. def factor12(): (MatriD, MatriD)

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t' or a = q * r, returning both the first and second matrices.

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t' or a = q * r, returning both the first and second matrices.

    Definition Classes
    Factorization
  5. def factor2(): MatriD

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t', returning only the second matrix.

    Factor a matrix into the product of two matrices, e.g., 'a = l * l.t', returning only the second matrix.

    Definition Classes
    Factorization
  6. def factors: (MatriD, MatriD)

    Return both the orthogonal 'q' matrix and the right upper triangular 'r' matrix.

    Return both the orthogonal 'q' matrix and the right upper triangular 'r' matrix.

    Definition Classes
    Fac_QRFactorization
  7. final def flaw(method: String, message: String): Unit

    Show the flaw by printing the error message.

    Show the flaw by printing the error message.

    method

    the method where the error occurred

    message

    the error message

    Definition Classes
    Error
  8. def hReflect(v: VectoD): MatrixD

    Return the Householder reflection matrix 'h' computed from Householder vector 'v'.

    Return the Householder reflection matrix 'h' computed from Householder vector 'v'.

    v

    the Householder vector

  9. def houseV(x: VectoD, α: Double): VectoD

    Return the Householder vector 'v' computed from vector 'x'.

    Return the Householder vector 'v' computed from vector 'x'.

    x

    the given vector for calculating the Householder vector

    α

    the sign adjusted norm of x

  10. def nullspace(rank: Int): MatriD

    Compute the nullspace of matrix 'a': basis { x | a*x = 0 }' using 'QR' Factorization 'q*r*x = 0'.

    Compute the nullspace of matrix 'a': basis { x | a*x = 0 }' using 'QR' Factorization 'q*r*x = 0'. Gives a basis of dimension 'n - rank' for the nullspace.

    rank

    the rank of the matrix (number of linearly independent column vectors)

    Definition Classes
    Fac_QR_H3Fac_QR
  11. def nullspaceV: VectorD

    Compute the nullspace of matrix 'a: { x | a*x = 0 }' using 'QR' Factorization 'q*r*x = 0'.

    Compute the nullspace of matrix 'a: { x | a*x = 0 }' using 'QR' Factorization 'q*r*x = 0'. Gives only one vector in the nullspace.

  12. def solve(b: VectoD): VectoD

    Solve for 'x' in 'aa*x = b' using the QR Factorization 'aa = q*r' via 'r*x = q.t * b'.

    Solve for 'x' in 'aa*x = b' using the QR Factorization 'aa = q*r' via 'r*x = q.t * b'. Requires calculating 'q' matrix first.

    b

    the constant vector@param y the constant vector

    Definition Classes
    Fac_QRFactorization