Class LUSOLEP
- java.lang.Object
-
- gov.nih.mipav.model.structures.jama.LUSOLEP
-
- All Implemented Interfaces:
java.io.Serializable
public class LUSOLEP extends java.lang.Object implements java.io.Serializable
LUSOL maintains LU factors of a square or rectangular sparse matrix. LUSOL is maintained by Michael Saunders, Systems Optimization Laboratory, Dept of Management Science & Engineering, Stanford University. (saunders@stanford.edu) Professor Michael Saunders has kindly granted the NIH MIPAV project permission to port LUSOL from FORTRAN to Java under a BSD license. Porting performed by William Gandler. The website for LUSOL is: [http://www.stanford.edu/group/SOL/software/lusol.html][LUSOL] LUSOL: Sparse LU for Ax = b AUTHOR: Michael Saunders CONTRIBUTORS: Philip Gill, Walter Murray, Margaret Wright, Michael O'Sullivan, Kjell Eikland, Yin Zhang, Nick Henderson, Ding Ma CONTENTS: A sparse LU factorization for square and rectangular matrices A, with Bartels-Golub-Reid updates for column replacement and other rank-1 modifications. Typically used for a sequence of linear equations as in the simplex method: Solve Ax = b and/or A'y = c Replace a column of A Repeat with different b, c The matrix A may have any shape and rank. Rectangular LU factors may be used to form a sparse null-space matrix operator. Special feature 1: Three sparse pivoting options in the Factor routine: Threshold partial pivoting (TPP) Threshold rook pivoting (TRP) Threshold complete pivoting (TCP) All options choose row and column permutations as they go, balancing sparsity and stability according to different rules. TPP is normally most efficient for solving Ax = b. TRP and TCP are rank-revealing factorizations. In practice, TRP is an effective method for estimating rank(A). TCP tends to be too dense and expensive to be useful, although MINOS and SNOPT switch from TPP to TRP and even TCP if necessary in case of persistent numerical difficulty. Special feature 2: Multiple update routines: Add, delete, or replace a column of A Add, delete, or replace a row of A Add a general (sparse) rank-1 matrix to A Numerical stability: LUSOL maintains LU factors with row and column permutations P, Q such that A = LU with PLP' lower triangular (with unit diagonals) and PUQ upper triangular. The condition of L is controlled throughout by maintaining |Lij| <= factol (= 10 or 5 or 2 or 1.1, ...), so that U tends to reflect the condition of A. This is essential for subsequent Bartels-Golub-type updates (which are implemented in a manner similar to John Reid's LA05 and LA15 packages in the HSL library). If a fresh factorization is thought of as A = LDU (with unit diagonals on PLP' and PUQ), then TRP and TCP control the condition of both L and U by maintaining |Lij| <= factol and |Uij| <= factol, so that D reflects the condition of A. This is why TRP and TCP have rank-revealing properties. Proven applications: LUSOL is the basis factorization package (BFP) for MINOS, SQOPT, SNOPT, lp_solve, AMPL/PATH, GAMS/PATH. Shortcomings: Factor: No special handling of dense columns. Solve: No special treatment of sparse right-hand sides. Documentation: No user's manual. Primary documentation is in-line comments within the f77 source code (and the more recent f90 version). REFERENCES: J. K. Reid (1982). A sparsity-exploiting variant of the Bartels-Golub decomposition for linear programming bases, Mathematical Programming 24, 55-69. P. E. Gill, W. Murray, M. A. Saunders and M. H. Wright (1987). Maintaining LU factors of a general sparse matrix, Linear Algebra and its Applications 88/89, 239-270. P. E. Gill, W. Murray and M. A. Saunders (2005). SNOPT: An SQP algorithm for large-scale constrained optimization, SIGEST article, SIAM Review 47(1), 99-131. (See sections 4 and 5.) ## Basic usage In Matlab: ``` % get L and U factors [L U P Q] = lusol(A); ``` See `>>> help lusol`. ## Advanced usage In Matlab: ``` % create lusol object mylu = lusol_obj(A); % solve with lusol object (ie x = A\b) x = mylu.solveA(b); % update factorization to replace a column mylu.repcol(v,1); % solve again with updated factorization x1 = mylu.solveA(b); ``` See `>>> help lusol_obj`. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description (package private) java.util.Random
rn
(package private) long
seed
private ViewUserInterface
UI
-
Constructor Summary
Constructors Constructor Description LUSOLEP()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description private void
Aprod(int m, int n, int nnzero, int[] indc, int[] indr, DoubleDouble[] a, DoubleDouble[] x, DoubleDouble[] y)
private DoubleDouble
dnormj(int n, DoubleDouble[] x, int incx)
private void
Hbuild(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int[] hops)
private void
Hchange(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int k, DoubleDouble v, int jv, int[] hops)
private void
Hdelete(DoubleDouble[] Ha, int[] Hj, int[] Hk, int Nin, int[] N, int Nk, int k, int[] hops)
private void
Hdown(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int kk, int[] hops)
private void
Hinsert(DoubleDouble[] Ha, int[] Hj, int[] Hk, int[] N, int Nk, DoubleDouble v, int jv, int[] hops)
private void
Hup(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int kk, int[] hops)
private int
jdamax(int n, DoubleDouble[] x, int incx)
private void
lu1DCP(DoubleDouble[][] a, int lda, int m, int n, DoubleDouble small, int[] nsing, int[] ipvt, int[] q)
private void
lu1DPP(DoubleDouble[][] a, int lda, int m, int n, DoubleDouble small, int[] nsing, int[] ipvt, int[] q)
void
lu1fac(int m, int n, int nelem, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv, DoubleDouble[] w, int[] inform)
private void
lu1fad(int m, int n, int nelem, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv, DoubleDouble[] w, int lenH, DoubleDouble[] Ha, int[] Hj, int[] Hk, DoubleDouble[] Amaxr, int[] inform, int[] lenL, int[] lenU, int[] minlen, int[] mersum, int[] nUtri, int[] nLtri, int[] ndens1, int[] ndens2, int[] nrank, DoubleDouble[] Lmax, DoubleDouble[] Umax, DoubleDouble[] DUmax, DoubleDouble[] DUmin, DoubleDouble[] Akmax)
private void
lu1ful(int m, int n, int lena, int lenD, int lu1, boolean TPP, int mleft, int nleft, int nrank, int nrowu, int[] lenL, int[] lenU, int[] nsing, boolean keepLU, DoubleDouble small, DoubleDouble[] a, int lDInput, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] ipinv, int[] ipvt)
private void
lu1gau(int m, int melim, int ncold, int nspare, DoubleDouble small, int lpivc1, int lpivc2, int[] lfirst, int lpivr2, int lfree, int minfre, int[] ilast, int[] jlast, int[] lrow, int[] lcol, int[] lu, int[] nfill, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] mark, int ll1, int lu1)
private void
lu1mar(int m, int n, int lena, int maxmn, boolean TCP, DoubleDouble aijtol, DoubleDouble Ltol, int maxcol, int maxrow, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc)
private void
lu1mRP(int m, int n, int lena, int maxmn, DoubleDouble Ltol, int maxcol, int maxrow, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, DoubleDouble[] Amaxr)
private void
lu1mSP(int m, int n, int lena, int maxmn, DoubleDouble Ltol, int maxcol, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] q, int[] locc, int[] iqloc)
private void
lu1mxc(int k1, int k2, int[] q, DoubleDouble[] a, int[] indc, int[] lenc, int[] locc)
private void
lu1mxr(int mark, int k1, int k2, int m, int n, int lena, DoubleDouble[] a, int[] indc, int[] lenc, int[] locc, int[] indr, int[] lenr, int[] locr, int[] p, int[] markc, int[] markr, DoubleDouble[] Amaxr)
private void
lu1or1(int m, int n, int nelem, int lena, DoubleDouble small, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] lenr, DoubleDouble[] Amax, int[] numnz, int[] lerr, int[] inform)
private void
lu1or2(int n, int numa, int lena, DoubleDouble[] a, int[] inum, int[] jnum, int[] lenc, int[] locc)
private void
lu1or3(int m, int n, int lena, int[] indc, int[] lenc, int[] locc, int[] iw, int[] lerr, int[] inform)
private void
lu1or4(int m, int n, int nelem, int lena, int[] indc, int[] indr, int[] lenc, int[] lenr, int[] locc, int[] locr)
private void
lu1pen(int m, int melim, int ncold, int nspare, int[] ilast, int lpivc1, int lpivc2, int lpivr1, int lpivr2, int[] lrow, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] indc, int[] indr, int ll1, int lu1)
private void
lu1pq1(int m, int n, int[] len, int[] iperm, int[] loc, int[] inv, int[] num)
private void
lu1pq2(int nzpiv, int[] nzchng, int[] indr, int[] lenold, int[] lennew, int[] iqloc, int[] q, int[] iqinv)
private void
lu1pq3(int n, int[] len, int[] iperm, int[] iw, int[] nrank)
private void
lu1rec(int n, boolean reals, int[] luparm, int[] ltop, int lena, DoubleDouble[] a, int[] ind, int[] lenc, int[] locc)
private void
lu1slk(int m, int n, int lena, int[] q, int[] iqloc, DoubleDouble[] a, int[] locc, DoubleDouble[] w)
private void
lu6chk(int mode, int m, int n, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform)
private void
lu6L(int[] inform, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc)
private void
lu6LD(int[] inform, int mode, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] locr)
private void
lu6Lt(int[] inform, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc)
private void
lu6mul(int mode, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr)
private void
lu6sol(int mode, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform)
private void
lu6U(int[] inform, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
private void
lu6Ut(int[] inform, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
private void
lu7add(int m, int n, int jadd, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indr, int[] p, int[] lenr, int[] locr, int[] inform, int[] klast, DoubleDouble[] vnorm)
private void
lu7cyc(int kfirst, int klast, int[] p)
private void
lu7elm(int m, int n, int jelm, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
private void
lu7for(int m, int n, int kfirst, int klast, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
private void
lu7rnk(int m, int n, int jsing, int lena, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, int[] nrank, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
private void
lu7zap(int m, int n, int jzap, int[] kzap, int lena, int[] lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
private void
lu8rpc(int mode1, int mode2, int m, int n, int jrep, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag, DoubleDouble[] vnorm)
private void
luchek(int m, int n, int nrowb, DoubleDouble[][] B, int[] kb, DoubleDouble[] emax, DoubleDouble[] v, DoubleDouble[] w, DoubleDouble[] x, DoubleDouble[] y, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr)
private void
luinit(int m, int n, int nrowb, DoubleDouble[][] B, int[] kb, int lena, int[] luparm, DoubleDouble[] parmlu, int[] nelem, DoubleDouble[] a, int[] indc, int[] indr)
private void
lutest(int m, int n, int nrowb, int ncolb, int mtest, int[] inform, int[] kb, DoubleDouble[][] B, DoubleDouble[] d, DoubleDouble[] v, DoubleDouble[] w, DoubleDouble[] x, DoubleDouble[] y, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv)
void
lutest_driver()
private DoubleDouble
random()
private void
setmat(int m, int n, int nrowb, DoubleDouble[][] B, DoubleDouble[] d, DoubleDouble[] v, DoubleDouble[] w)
void
testflat()
-
-
-
Field Detail
-
UI
private ViewUserInterface UI
-
seed
long seed
-
rn
java.util.Random rn
-
-
Method Detail
-
testflat
public void testflat()
-
Aprod
private void Aprod(int m, int n, int nnzero, int[] indc, int[] indr, DoubleDouble[] a, DoubleDouble[] x, DoubleDouble[] y)
-
dnormj
private DoubleDouble dnormj(int n, DoubleDouble[] x, int incx)
-
random
private DoubleDouble random()
-
lutest_driver
public void lutest_driver()
-
lutest
private void lutest(int m, int n, int nrowb, int ncolb, int mtest, int[] inform, int[] kb, DoubleDouble[][] B, DoubleDouble[] d, DoubleDouble[] v, DoubleDouble[] w, DoubleDouble[] x, DoubleDouble[] y, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv)
-
setmat
private void setmat(int m, int n, int nrowb, DoubleDouble[][] B, DoubleDouble[] d, DoubleDouble[] v, DoubleDouble[] w)
-
luinit
private void luinit(int m, int n, int nrowb, DoubleDouble[][] B, int[] kb, int lena, int[] luparm, DoubleDouble[] parmlu, int[] nelem, DoubleDouble[] a, int[] indc, int[] indr)
-
luchek
private void luchek(int m, int n, int nrowb, DoubleDouble[][] B, int[] kb, DoubleDouble[] emax, DoubleDouble[] v, DoubleDouble[] w, DoubleDouble[] x, DoubleDouble[] y, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr)
-
lu1fac
public void lu1fac(int m, int n, int nelem, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv, DoubleDouble[] w, int[] inform)
-
lu1or1
private void lu1or1(int m, int n, int nelem, int lena, DoubleDouble small, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] lenr, DoubleDouble[] Amax, int[] numnz, int[] lerr, int[] inform)
-
lu1or2
private void lu1or2(int n, int numa, int lena, DoubleDouble[] a, int[] inum, int[] jnum, int[] lenc, int[] locc)
-
lu1or3
private void lu1or3(int m, int n, int lena, int[] indc, int[] lenc, int[] locc, int[] iw, int[] lerr, int[] inform)
-
lu1or4
private void lu1or4(int m, int n, int nelem, int lena, int[] indc, int[] indr, int[] lenc, int[] lenr, int[] locc, int[] locr)
-
lu1pq1
private void lu1pq1(int m, int n, int[] len, int[] iperm, int[] loc, int[] inv, int[] num)
-
lu1fad
private void lu1fad(int m, int n, int nelem, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, int[] ipinv, int[] iqinv, DoubleDouble[] w, int lenH, DoubleDouble[] Ha, int[] Hj, int[] Hk, DoubleDouble[] Amaxr, int[] inform, int[] lenL, int[] lenU, int[] minlen, int[] mersum, int[] nUtri, int[] nLtri, int[] ndens1, int[] ndens2, int[] nrank, DoubleDouble[] Lmax, DoubleDouble[] Umax, DoubleDouble[] DUmax, DoubleDouble[] DUmin, DoubleDouble[] Akmax)
-
lu1ful
private void lu1ful(int m, int n, int lena, int lenD, int lu1, boolean TPP, int mleft, int nleft, int nrank, int nrowu, int[] lenL, int[] lenU, int[] nsing, boolean keepLU, DoubleDouble small, DoubleDouble[] a, int lDInput, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] ipinv, int[] ipvt)
-
lu1DCP
private void lu1DCP(DoubleDouble[][] a, int lda, int m, int n, DoubleDouble small, int[] nsing, int[] ipvt, int[] q)
-
lu1DPP
private void lu1DPP(DoubleDouble[][] a, int lda, int m, int n, DoubleDouble small, int[] nsing, int[] ipvt, int[] q)
-
jdamax
private int jdamax(int n, DoubleDouble[] x, int incx)
-
lu1gau
private void lu1gau(int m, int melim, int ncold, int nspare, DoubleDouble small, int lpivc1, int lpivc2, int[] lfirst, int lpivr2, int lfree, int minfre, int[] ilast, int[] jlast, int[] lrow, int[] lcol, int[] lu, int[] nfill, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] mark, int ll1, int lu1)
-
lu1mar
private void lu1mar(int m, int n, int lena, int maxmn, boolean TCP, DoubleDouble aijtol, DoubleDouble Ltol, int maxcol, int maxrow, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc)
-
lu1mRP
private void lu1mRP(int m, int n, int lena, int maxmn, DoubleDouble Ltol, int maxcol, int maxrow, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] iploc, int[] iqloc, DoubleDouble[] Amaxr)
-
lu1mSP
private void lu1mSP(int m, int n, int lena, int maxmn, DoubleDouble Ltol, int maxcol, int[] ibest, int[] jbest, int[] mbest, DoubleDouble[] a, int[] indc, int[] q, int[] locc, int[] iqloc)
-
lu1mxc
private void lu1mxc(int k1, int k2, int[] q, DoubleDouble[] a, int[] indc, int[] lenc, int[] locc)
-
lu1pen
private void lu1pen(int m, int melim, int ncold, int nspare, int[] ilast, int lpivc1, int lpivc2, int lpivr1, int lpivr2, int[] lrow, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] indc, int[] indr, int ll1, int lu1)
-
lu1pq2
private void lu1pq2(int nzpiv, int[] nzchng, int[] indr, int[] lenold, int[] lennew, int[] iqloc, int[] q, int[] iqinv)
-
lu1pq3
private void lu1pq3(int n, int[] len, int[] iperm, int[] iw, int[] nrank)
-
lu1rec
private void lu1rec(int n, boolean reals, int[] luparm, int[] ltop, int lena, DoubleDouble[] a, int[] ind, int[] lenc, int[] locc)
-
lu1slk
private void lu1slk(int m, int n, int lena, int[] q, int[] iqloc, DoubleDouble[] a, int[] locc, DoubleDouble[] w)
-
lu1mxr
private void lu1mxr(int mark, int k1, int k2, int m, int n, int lena, DoubleDouble[] a, int[] indc, int[] lenc, int[] locc, int[] indr, int[] lenr, int[] locr, int[] p, int[] markc, int[] markr, DoubleDouble[] Amaxr)
-
Hbuild
private void Hbuild(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int[] hops)
-
Hchange
private void Hchange(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int k, DoubleDouble v, int jv, int[] hops)
-
Hdelete
private void Hdelete(DoubleDouble[] Ha, int[] Hj, int[] Hk, int Nin, int[] N, int Nk, int k, int[] hops)
-
Hdown
private void Hdown(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int kk, int[] hops)
-
Hinsert
private void Hinsert(DoubleDouble[] Ha, int[] Hj, int[] Hk, int[] N, int Nk, DoubleDouble v, int jv, int[] hops)
-
Hup
private void Hup(DoubleDouble[] Ha, int[] Hj, int[] Hk, int N, int Nk, int kk, int[] hops)
-
lu6chk
private void lu6chk(int mode, int m, int n, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform)
-
lu8rpc
private void lu8rpc(int mode1, int mode2, int m, int n, int jrep, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag, DoubleDouble[] vnorm)
-
lu7zap
private void lu7zap(int m, int n, int jzap, int[] kzap, int lena, int[] lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
-
lu6sol
private void lu6sol(int mode, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenc, int[] lenr, int[] locc, int[] locr, int[] inform)
-
lu6L
private void lu6L(int[] inform, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc)
-
lu6Lt
private void lu6Lt(int[] inform, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc)
-
lu6U
private void lu6U(int[] inform, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
-
lu6Ut
private void lu6Ut(int[] inform, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indr, int[] p, int[] q, int[] lenr, int[] locr)
-
lu6LD
private void lu6LD(int[] inform, int mode, int m, int n, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] lenc, int[] locr)
-
lu7add
private void lu7add(int m, int n, int jadd, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indr, int[] p, int[] lenr, int[] locr, int[] inform, int[] klast, DoubleDouble[] vnorm)
-
lu7elm
private void lu7elm(int m, int n, int jelm, DoubleDouble[] v, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int lenU, int[] lrow, int nrank, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
-
lu7cyc
private void lu7cyc(int kfirst, int klast, int[] p)
-
lu7for
private void lu7for(int m, int n, int kfirst, int klast, int lena, int[] luparm, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
-
lu7rnk
private void lu7rnk(int m, int n, int jsing, int lena, DoubleDouble[] parmlu, int[] lenL, int[] lenU, int[] lrow, int[] nrank, DoubleDouble[] a, int[] indc, int[] indr, int[] p, int[] q, int[] lenr, int[] locc, int[] locr, int[] inform, DoubleDouble[] diag)
-
lu6mul
private void lu6mul(int mode, int m, int n, DoubleDouble[] v, DoubleDouble[] w, int lena, int[] luparm, DoubleDouble[] parmlu, DoubleDouble[] a, int[] indc, int[] indr, int[] ip, int[] iq, int[] lenc, int[] lenr, int[] locc, int[] locr)
-
-