Documentation ¶
Overview ¶
Package la implements functions and structure for Linear Algebra computations. It defines a Vector and Matrix types for computations with dense data and also a Triplet and CCMatrix for sparse data.
Index ¶
- func CheckEigenVecL(tst *testing.T, A *Matrix, λ VectorC, u *MatrixC, tol float64)
- func CheckEigenVecR(tst *testing.T, A *Matrix, λ VectorC, v *MatrixC, tol float64)
- func Cholesky(L, a *Matrix)
- func DenSolve(x Vector, A *Matrix, b Vector, preserveA bool)
- func EigenVal(w VectorC, A *Matrix, preserveA bool)
- func EigenVecL(u *MatrixC, w VectorC, A *Matrix, preserveA bool)
- func EigenVecLR(u, v *MatrixC, w VectorC, A *Matrix, preserveA bool)
- func EigenVecR(v *MatrixC, w VectorC, A *Matrix, preserveA bool)
- func Jacobi(Q *Matrix, v Vector, A *Matrix)
- func MatCondNum(a *Matrix, normtype string) (res float64)
- func MatInv(ai, a *Matrix, calcDet bool) (det float64)
- func MatInvSmall(ai, a *Matrix, tol float64) (det float64)
- func MatMatMul(c *Matrix, α float64, a, b *Matrix)
- func MatMatMulAdd(c *Matrix, α float64, a, b *Matrix)
- func MatMatTrMul(c *Matrix, α float64, a, b *Matrix)
- func MatMatTrMulAdd(c *Matrix, α float64, a, b *Matrix)
- func MatSvd(s []float64, u, vt, a *Matrix, copyA bool)
- func MatTrMatMul(c *Matrix, α float64, a, b *Matrix)
- func MatTrMatMulAdd(c *Matrix, α float64, a, b *Matrix)
- func MatTrMatTrMul(c *Matrix, α float64, a, b *Matrix)
- func MatTrMatTrMulAdd(c *Matrix, α float64, a, b *Matrix)
- func MatTrVecMul(v Vector, α float64, a *Matrix, u Vector)
- func MatVecMul(v Vector, α float64, a *Matrix, u Vector)
- func MatVecMulAdd(v Vector, α float64, a *Matrix, u Vector)
- func MatVecMulAddC(v VectorC, α complex128, a *MatrixC, u VectorC)
- func MatVecMulC(v VectorC, α complex128, a *MatrixC, u VectorC)
- func SolveRealLinSysSPD(x Vector, a *Matrix, b Vector)
- func SolveTwoRealLinSysSPD(x, X Vector, a *Matrix, b, B Vector)
- func SpCheckDiag(a *CCMatrix) bool
- func SpInitRc(R *CCMatrix, C *CCMatrixC, J *CCMatrix)
- func SpInitSimilar(b *CCMatrix, a *CCMatrix)
- func SpInitSimilarR2C(b *CCMatrixC, a *CCMatrix)
- func SpMatAddI(r *CCMatrix, α float64, a *CCMatrix, β float64)
- func SpMatAddMat(c *CCMatrix, α float64, a *CCMatrix, β float64, b *CCMatrix, a2c, b2c []int)
- func SpMatAddMatC(C *CCMatrixC, R *CCMatrix, α, β, γ float64, a *CCMatrix, μ float64, ...)
- func SpMatMatTrMul(b *Matrix, α float64, a *CCMatrix)
- func SpMatTrVecMul(v Vector, α float64, a *CCMatrix, u Vector)
- func SpMatTrVecMulAdd(v Vector, α float64, a *CCMatrix, u Vector)
- func SpMatTrVecMulAddC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
- func SpMatTrVecMulC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
- func SpMatVecMul(v Vector, α float64, a *CCMatrix, u Vector)
- func SpMatVecMulAdd(v Vector, α float64, a *CCMatrix, u Vector)
- func SpMatVecMulAddC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
- func SpMatVecMulAddX(v Vector, a *CCMatrix, α float64, u Vector, β float64, w Vector)
- func SpMatVecMulC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
- func SpSetRc(R *CCMatrix, C *CCMatrixC, α, β, γ float64, J *CCMatrix)
- func SpTriAdd(c *Triplet, α float64, a *Triplet, β float64, b *Triplet)
- func SpTriAddR2C(c *TripletC, α, β float64, a *Triplet, μ float64, b *Triplet)
- func SpTriMatTrVecMul(y Vector, a *Triplet, x Vector)
- func SpTriMatVecMul(y Vector, a *Triplet, x Vector)
- func SpTriReduce(comm *mpi.Communicator, J *Triplet)
- func SpTriSetDiag(a *Triplet, n int, v float64)
- func TestSolverResidual(tst *testing.T, a *Matrix, x, b Vector, tolNorm float64)
- func TestSolverResidualC(tst *testing.T, a *MatrixC, x, b VectorC, tolNorm float64)
- func TestSpSolver(tst *testing.T, solverKind string, symmetric bool, t *Triplet, ...)
- func TestSpSolverC(tst *testing.T, solverKind string, symmetric bool, t *TripletC, ...)
- func VecAdd(res Vector, α float64, u Vector, β float64, v Vector)
- func VecDot(u, v Vector) (res float64)
- func VecMaxDiff(u, v Vector) (maxdiff float64)
- func VecRmsError(u, v Vector, a, m float64, s Vector) (rms float64)
- func VecScaleAbs(scale Vector, a, m float64, x Vector)
- type CCMatrix
- type CCMatrixC
- type Equations
- func (o *Equations) Alloc(nnz []int, kparts, vectors bool)
- func (o *Equations) AllocDense(kparts bool)
- func (o *Equations) JoinVector(b, bu, bk Vector)
- func (o *Equations) Print(full bool)
- func (o *Equations) Put(I, J int, value float64)
- func (o *Equations) SetDense(A *Matrix, kparts bool)
- func (o *Equations) SplitVector(bu, bk, b Vector)
- func (o *Equations) Start()
- type Matrix
- func (o *Matrix) Add(i, j int, val float64)
- func (o Matrix) Apply(α float64, another *Matrix)
- func (o *Matrix) ClearBry(diag float64)
- func (o *Matrix) ClearRC(rows, cols []int, diag float64)
- func (o *Matrix) Col(j int) Vector
- func (o *Matrix) CopyInto(result *Matrix, α float64)
- func (o *Matrix) Det() (det float64)
- func (o *Matrix) Fill(val float64)
- func (o *Matrix) Get(i, j int) float64
- func (o *Matrix) GetCol(j int) (col Vector)
- func (o *Matrix) GetComplex() (b *MatrixC)
- func (o *Matrix) GetCopy() (clone *Matrix)
- func (o *Matrix) GetDeep2() (M [][]float64)
- func (o *Matrix) GetRow(i int) (row Vector)
- func (o *Matrix) GetTranspose() (tran *Matrix)
- func (o *Matrix) Largest(den float64) (largest float64)
- func (o *Matrix) MaxDiff(another *Matrix) (maxdiff float64)
- func (o *Matrix) NormFrob() (nrm float64)
- func (o *Matrix) NormInf() (nrm float64)
- func (o *Matrix) Print(nfmt string) (l string)
- func (o *Matrix) PrintGo(nfmt string) (l string)
- func (o *Matrix) PrintPy(nfmt string) (l string)
- func (o *Matrix) Set(i, j int, val float64)
- func (o *Matrix) SetDiag(val float64)
- func (o *Matrix) SetFromDeep2(a [][]float64)
- type MatrixC
- func (o *MatrixC) Add(i, j int, val complex128)
- func (o MatrixC) Apply(α complex128, another *MatrixC)
- func (o *MatrixC) Col(j int) VectorC
- func (o *MatrixC) Fill(val complex128)
- func (o *MatrixC) Get(i, j int) complex128
- func (o *MatrixC) GetCol(j int) (col VectorC)
- func (o *MatrixC) GetColReal(j int, checkZeroImag bool) (col Vector)
- func (o *MatrixC) GetCopy() (clone *MatrixC)
- func (o *MatrixC) GetDeep2() (M [][]complex128)
- func (o *MatrixC) GetRow(i int) (row VectorC)
- func (o *MatrixC) GetTranspose() (tran *MatrixC)
- func (o *MatrixC) Print(nfmtR, nfmtI string) (l string)
- func (o *MatrixC) PrintGo(nfmtR, nfmtI string) (l string)
- func (o *MatrixC) PrintPy(nfmtR, nfmtI string) (l string)
- func (o *MatrixC) Set(i, j int, val complex128)
- func (o *MatrixC) SetFromDeep2c(a [][]complex128)
- type Mumps
- type MumpsC
- type SparseSolver
- type SparseSolverC
- type Triplet
- func (o *Triplet) Init(m, n, max int)
- func (o *Triplet) Len() int
- func (o *Triplet) Max() int
- func (o *Triplet) Put(i, j int, x float64)
- func (o *Triplet) PutCCMatAndMatT(a *CCMatrix)
- func (o *Triplet) PutMatAndMatT(a *Triplet)
- func (o *Triplet) ReadSmat(filename string)
- func (o *Triplet) Start()
- func (o *Triplet) ToDense() (a *Matrix)
- func (t *Triplet) ToMatrix(a *CCMatrix) *CCMatrix
- func (o *Triplet) WriteSmat(dirout, fnkey string, tol float64) (cmat *CCMatrix)
- type TripletC
- func (o *TripletC) Init(m, n, max int)
- func (o *TripletC) Len() int
- func (o *TripletC) Max() int
- func (o *TripletC) Put(i, j int, x complex128)
- func (o *TripletC) ReadSmat(filename string)
- func (o *TripletC) Start()
- func (o *TripletC) ToDense() (a *MatrixC)
- func (t *TripletC) ToMatrix(a *CCMatrixC) *CCMatrixC
- func (o *TripletC) WriteSmat(dirout, fnkey string, tol float64) (cmat *CCMatrixC)
- type Umfpack
- type UmfpackC
- type Vector
- func (o Vector) Accum() (sum float64)
- func (o Vector) Apply(α float64, another Vector)
- func (o Vector) ApplyFunc(f func(i int, x float64) float64)
- func (o Vector) Fill(val float64)
- func (o Vector) GetCopy() (clone Vector)
- func (o Vector) Largest(den float64) (largest float64)
- func (o Vector) Max() (max float64)
- func (o Vector) Min() (min float64)
- func (o Vector) MinMax() (min, max float64)
- func (o Vector) Norm() (nrm float64)
- func (o Vector) NormDiff(v Vector) (nrm float64)
- func (o Vector) Rms() (rms float64)
- type VectorC
- func (o VectorC) Apply(α complex128, another VectorC)
- func (o VectorC) ApplyFunc(f func(i int, x complex128) complex128)
- func (o VectorC) Fill(s complex128)
- func (o VectorC) GetCopy() (clone VectorC)
- func (o VectorC) JoinRealImag(xR, xI Vector)
- func (o VectorC) MaxDiff(b VectorC) float64
- func (o VectorC) Norm() (nrm complex128)
- func (o VectorC) SplitRealImag(xR, xI Vector)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CheckEigenVecL ¶
CheckEigenVecL checks left eigenvector:
H H u [j] ⋅ A = λ[j] ⋅ u [j] LEFT eigenvectors
func CheckEigenVecR ¶
CheckEigenVecR checks right eigenvector:
A ⋅ v[j] = λ[j] ⋅ v[j] RIGHT eigenvectors
func Cholesky ¶
func Cholesky(L, a *Matrix)
Cholesky returns the Cholesky decomposition of a symmetric positive-definite matrix
a = L * trans(L)
func DenSolve ¶
DenSolve solves dense linear system using LAPACK (OpemBLAS)
Given: A ⋅ x = b find x such that x = A⁻¹ ⋅ b
func EigenVal ¶
EigenVal computes eigenvalues of general matrix
A ⋅ v[j] = λ[j] ⋅ v[j] INPUT: a -- general matrix OUTPUT: w -- eigenvalues [pre-allocated]
func EigenVecL ¶
EigenVecL computes eigenvalues and LEFT eigenvectors of general matrix
H H u [j] ⋅ A = λ[j] ⋅ u [j] LEFT eigenvectors INPUT: a -- general matrix OUTPUT: u -- matrix with the eigenvectors; each column contains one eigenvector [pre-allocated] w -- eigenvalues [pre-allocated]
func EigenVecLR ¶
EigenVecLR computes eigenvalues and LEFT and RIGHT eigenvectors of general matrix
A ⋅ v[j] = λ[j] ⋅ v[j] RIGHT eigenvectors H H u [j] ⋅ A = λ[j] ⋅ u [j] LEFT eigenvectors INPUT: a -- general matrix OUTPUT: u -- matrix with the LEFT eigenvectors; each column contains one eigenvector [pre-allocated] v -- matrix with the RIGHT eigenvectors; each column contains one eigenvector [pre-allocated] w -- λ eigenvalues [pre-allocated]
func EigenVecR ¶
EigenVecR computes eigenvalues and RIGHT eigenvectors of general matrix
A ⋅ v[j] = λ[j] ⋅ v[j] INPUT: a -- general matrix OUTPUT: v -- matrix with the eigenvectors; each column contains one eigenvector [pre-allocated] w -- eigenvalues [pre-allocated]
func Jacobi ¶
Jacobi performs the Jacobi transformation of a symmetric matrix to find its eigenvectors and eigenvalues.
The Jacobi method consists of a sequence of orthogonal similarity transformations. Each transformation (a Jacobi rotation) is just a plane rotation designed to annihilate one of the off-diagonal matrix elements. Successive transformations undo previously set zeros, but the off-diagonal elements nevertheless get smaller and smaller. Accumulating the product of the transformations as you go gives the matrix of eigenvectors (Q), while the elements of the final diagonal matrix (A) are the eigenvalues.
The Jacobi method is absolutely foolproof for all real symmetric matrices.
A = Q ⋅ L ⋅ Qᵀ Input: A -- matrix to compute eigenvalues (SYMMETRIC and SQUARE) Output: A -- modified Q -- matrix which columns are the eigenvectors v -- vector with the eigenvalues NOTE: for matrices of order greater than about 10, say, the algorithm is slower, by a significant constant factor, than the QR method.
func MatCondNum ¶
MatCondNum returns the condition number of a square matrix using the inverse of this matrix; thus it is not as efficient as it could be, e.g. by using the SV decomposition.
normtype -- Type of norm to use: "F" or "" => Frobenius "I" => Infinite
func MatInv ¶
MatInv computes the inverse of a general matrix (square or not). It also computes the pseudo-inverse if the matrix is not square.
Input: a -- input matrix (M x N) Output: ai -- inverse matrix (N x M) det -- determinant of matrix (ONLY if calcDet == true and the matrix is square) NOTE: the dimension of the ai matrix must be N x M for the pseudo-inverse
func MatInvSmall ¶
MatInvSmall computes the inverse of small matrices of size 1x1, 2x2, or 3x3. It also returns the determinant.
Input: a -- the matrix tol -- tolerance to assume zero determinant Output: ai -- the inverse matrix det -- determinant of a
func MatMatMul ¶
MatMatMul returns the matrix multiplication (scaled)
c := α⋅a⋅b ⇒ cij := α * aik * bkj
func MatMatMulAdd ¶
MatMatMulAdd returns the matrix multiplication (scaled)
c += α⋅a⋅b ⇒ cij += α * aik * bkj
func MatMatTrMul ¶
MatMatTrMul returns the matrix multiplication (scaled) with transposed(b)
c := α⋅a⋅bᵀ ⇒ cij := α * aik * bjk
func MatMatTrMulAdd ¶
MatMatTrMulAdd returns the matrix multiplication (scaled) with transposed(b)
c += α⋅a⋅bᵀ ⇒ cij += α * aik * bjk
func MatSvd ¶
MatSvd performs the SVD decomposition
Input: a -- matrix a copyA -- creates a copy of a; otherwise 'a' is modified Output: s -- diagonal terms [must be pre-allocated] len(s) = imin(a.M, a.N) u -- left matrix [must be pre-allocated] u is (a.M x a.M) vt -- transposed right matrix [must be pre-allocated] vt is (a.N x a.N)
func MatTrMatMul ¶
MatTrMatMul returns the matrix multiplication (scaled) with transposed(a)
c := α⋅aᵀ⋅b ⇒ cij := α * aki * bkj
func MatTrMatMulAdd ¶
MatTrMatMulAdd returns the matrix multiplication (scaled) with transposed(a)
c += α⋅aᵀ⋅b ⇒ cij += α * aki * bkj
func MatTrMatTrMul ¶
MatTrMatTrMul returns the matrix multiplication (scaled) with transposed(a) and transposed(b)
c := α⋅aᵀ⋅bᵀ ⇒ cij := α * aki * bjk
func MatTrMatTrMulAdd ¶
MatTrMatTrMulAdd returns the matrix multiplication (scaled) with transposed(a) and transposed(b)
c += α⋅aᵀ⋅bᵀ ⇒ cij += α * aki * bjk
func MatTrVecMul ¶
MatTrVecMul returns the transpose(matrix)-vector multiplication
v = α⋅aᵀ⋅u ⇒ vi = α * aji * uj = α * uj * aji
func MatVecMulAdd ¶
MatVecMulAdd returns the matrix-vector multiplication with addition
v += α⋅a⋅u ⇒ vi += α * aij * uj
func MatVecMulAddC ¶
func MatVecMulAddC(v VectorC, α complex128, a *MatrixC, u VectorC)
MatVecMulAddC returns the matrix-vector multiplication with addition (complex version)
v += α⋅a⋅u ⇒ vi += α * aij * uj
func MatVecMulC ¶
func MatVecMulC(v VectorC, α complex128, a *MatrixC, u VectorC)
MatVecMulC returns the matrix-vector multiplication (complex version)
v = α⋅a⋅u ⇒ vi = α * aij * uj
func SolveRealLinSysSPD ¶
SolveRealLinSysSPD solves a linear system with real numbres and a Symmetric-Positive-Definite (SPD) matrix
x := inv(a) * b NOTE: this function uses Cholesky decomposition and should be used for small systems
func SolveTwoRealLinSysSPD ¶
SolveTwoRealLinSysSPD solves two linear systems with real numbres and Symmetric-Positive-Definite (SPD) matrices
x := inv(a) * b and X := inv(a) * B NOTE: this function uses Cholesky decomposition and should be used for small systems
func SpCheckDiag ¶
SpCheckDiag checks if all elements on the diagonal of "a" are present.
OUTPUT: ok -- true if all diagonal elements are present; otherwise, ok == false if any diagonal element is missing.
func SpInitRc ¶
SpInitRc initialises two complex sparse matrices (residual correction) according to:
Real: R := γ *I - J Complex: C := (α + βi)*I - J NOTE: "J" must include all diagonal elements
func SpInitSimilar ¶
SpInitSimilar initialises another matrix "b" with the same structure (Ap, Ai) of sparse matrix "a". The values Ax are not copied though.
func SpInitSimilarR2C ¶
SpInitSimilarR2C initialises another matrix "b" (complex) with the same structure (Ap, Ai) of sparse matrix "a" (real). The values Ax are not copied though (Bx and Bz are not set).
func SpMatAddI ¶
SpMatAddI adds an identity matrix I to "a", scaled by α and β according to:
r := α*a + β*I
func SpMatAddMat ¶
SpMatAddMat adds two sparse matrices. The 'c' matrix matrix and the 'a2c' and 'b2c' arrays must be pre-allocated by SpAllocMatAddMat. The result is:
c := α*a + β*b NOTE: this routine does not check for the correct sizes, since this is expect to be done by SpAllocMatAddMat
func SpMatAddMatC ¶
func SpMatAddMatC(C *CCMatrixC, R *CCMatrix, α, β, γ float64, a *CCMatrix, μ float64, b *CCMatrix, a2c, b2c []int)
SpMatAddMatC adds two real sparse matrices with two sets of coefficients in such a way that one real matrix (R) and another complex matrix (C) are obtained. The results are:
R := γ *a + μ*b C := (α+βi)*a + μ*b NOTE: the structure of R and C are the same and can be allocated with SpAllocMatAddMat, followed by one call to SpInitSimilarR2C. For example: R, a2c, b2c := SpAllocMatAddMat(a, b) SpInitSimilarR2C(C, R)
func SpMatMatTrMul ¶
SpMatMatTrMul computes the multiplication of sparse matrix with itself transposed:
b := α * a * aᵀ b_iq = α * a_ij * a_qj
/ Note: b is symmetric
func SpMatTrVecMul ¶
SpMatTrVecMul returns the (sparse) matrix-vector multiplication with "a" transposed (scaled):
v := α * transp(a) * u => vj = α * aij * ui NOTE: dense vector v will be first initialised with zeros
func SpMatTrVecMulAdd ¶
SpMatTrVecMulAdd returns the (sparse) matrix-vector multiplication with addition and "a" transposed (scaled):
v += α * transp(a) * u => vj += α * aij * ui
func SpMatTrVecMulAddC ¶
func SpMatTrVecMulAddC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
SpMatTrVecMulAddC returns the (sparse/complex) matrix-vector multiplication with addition and "a" transposed (scaled):
v += α * transp(a) * u => vj += α * aij * ui
func SpMatTrVecMulC ¶
func SpMatTrVecMulC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
SpMatTrVecMulC returns the (sparse/complex) matrix-vector multiplication with "a" transposed (scaled):
v := α * transp(a) * u => vj = α * aij * ui NOTE: dense vector v will be first initialised with zeros
func SpMatVecMul ¶
SpMatVecMul returns the (sparse) matrix-vector multiplication (scaled):
v := α * a * u => vi = α * aij * uj NOTE: dense vector v will be first initialised with zeros
func SpMatVecMulAdd ¶
SpMatVecMulAdd returns the (sparse) matrix-vector multiplication with addition (scaled):
v += α * a * u => vi += α * aij * uj
func SpMatVecMulAddC ¶
func SpMatVecMulAddC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
SpMatVecMulAddC returns the (sparse/complex) matrix-vector multiplication with addition (scaled):
v += α * a * u => vi += α * aij * uj
func SpMatVecMulAddX ¶
SpMatVecMulAddX returns the (sparse) matrix-vector multiplication with addition (scaled/extended):
v += a * (α*u + β*w) => vi += aij * (α*uj + β*wj)
func SpMatVecMulC ¶
func SpMatVecMulC(v VectorC, α complex128, a *CCMatrixC, u VectorC)
SpMatVecMulC returns the (sparse/complex) matrix-vector multiplication (scaled):
v := α * a * u => vi = α * aij * uj NOTE: dense vector v will be first initialised with zeros
func SpSetRc ¶
SpSetRc sets the values within two complex sparse matrices (residual correction) according to:
Real: R := γ *I - J Complex: C := (α + βi)*I - J NOTE: "J" must include all diagonal elements
func SpTriAdd ¶
SpTriAdd adds two matrices in Triplet format:
c := α*a + β*b NOTE: the output 'c' triplet must be able to hold all nonzeros of 'a' and 'b' actually the 'c' triplet is just expanded
func SpTriAddR2C ¶
SpTriAddR2C adds two real matrices in Triplet format generating a complex triplet according to:
c := (α+βi)*a + μ*b NOTE: the output 'c' triplet must be able to hold all nonzeros of 'a' and 'b'
func SpTriMatTrVecMul ¶
SpTriMatTrVecMul returns the matrix-vector multiplication with transposed matrix a in triplet format and two dense vectors x and y
y := transpose(a) * x or y_I := a_JI * x_J or y_j := a_ij * x_i
func SpTriMatVecMul ¶
SpTriMatVecMul returns the matrix-vector multiplication with matrix a in triplet format and two dense vectors x and y
y := a * x or y_i := a_ij * x_j
func SpTriReduce ¶
func SpTriReduce(comm *mpi.Communicator, J *Triplet)
SpTriReduce joins (MPI) parallel triplets to root (Rank == 0) processor.
NOTE: J in root is also joined into Jroot
func SpTriSetDiag ¶
SpTriSetDiag sets a (n x n) real triplet with diagonal values 'v'
func TestSolverResidual ¶
TestSolverResidual check the residual of a linear system solution
func TestSolverResidualC ¶
TestSolverResidualC check the residual of a linear system solution (complex version)
func TestSpSolver ¶
func TestSpSolver(tst *testing.T, solverKind string, symmetric bool, t *Triplet, b, xCorrect Vector, tolX, tolRes float64, verbose, bIsDistr bool, comm *mpi.Communicator)
TestSpSolver tests a sparse solver
func TestSpSolverC ¶
func TestSpSolverC(tst *testing.T, solverKind string, symmetric bool, t *TripletC, b, xCorrect VectorC, tolX, tolRes float64, verbose, bIsDistr bool, comm *mpi.Communicator)
TestSpSolverC tests a sparse solver (complex version)
func VecAdd ¶
VecAdd adds the scaled components of two vectors
res := α⋅u + β⋅v ⇒ result[i] := α⋅u[i] + β⋅v[i]
func VecMaxDiff ¶
VecMaxDiff returns the maximum absolute difference between two vectors
maxdiff = max(|u - v|)
func VecRmsError ¶
VecRmsError returns the scaled root-mean-square of the difference between two vectors with components normalised by a scaling factor
__________________________ / ———— 2 / 1 \ / error[i] \ rms = \ / ——— / | —————————— | \/ N ———— \ scale[i] / error[i] = |u[i] - v[i]| scale[i] = a + m*|s[i]|
func VecScaleAbs ¶
VecScaleAbs creates a "scale" vector using the absolute value of another vector
scale := a + m ⋅ |x| ⇒ scale[i] := a + m ⋅ |x[i]|
Types ¶
type CCMatrix ¶
type CCMatrix struct {
// contains filtered or unexported fields
}
CCMatrix represents a sparse matrix using the so-called "column-compressed format".
func SpAllocMatAddMat ¶
SpAllocMatAddMat allocates a matrix 'c' to hold the result of the addition of 'a' and 'b'. It also allocates the mapping arrays a2c and b2c, where:
a2c maps 'k' in 'a' to 'k' in 'c': len(a2c) = a.nnz b2c maps 'k' in 'b' to 'k' in 'c': len(b2c) = b.nnz
func (*CCMatrix) WriteSmat ¶
WriteSmat writes a ".smat" file that can be visualised with vismatrix
NOTE: CCMatrix must be used to generate the resulting values because duplicates must be added before saving file dirout -- directory for output. will be created fnkey -- filename key (filename without extension). ".smat" will be added tol -- tolerance to skip zero values
type CCMatrixC ¶
type CCMatrixC struct {
// contains filtered or unexported fields
}
CCMatrixC represents a sparse matrix using the so-called "column-compressed format". (complex version)
func (*CCMatrixC) WriteSmat ¶
WriteSmat writes a ".smat" file that can be visualised with vismatrix
NOTE: CCMatrix must be used to generate the resulting values because duplicates must be added before saving file dirout -- directory for output. will be created fnkey -- filename key (filename without extension). ".smat" will be added tol -- tolerance to skip zero values
func (*CCMatrixC) WriteSmatAbs ¶
WriteSmatAbs writes a ".smat" file that can be visualised with vismatrix (abs(complex) version)
NOTE: CCMatrix must be used to generate the resulting values because duplicates must be added before saving file tol -- tolerance to skip zero values
type Equations ¶
type Equations struct { // essential N int // total number of equations Nu int // number of unknowns (size of u-system) Nk int // number of known values (size of k-system) UtoF []int // reduced u-system to full-system FtoU []int // full-system to reduced u-system KtoF []int // reduced k-system to full system FtoK []int // full-system to reduced k-system // convenience Auu, Auk, Aku, Akk *Triplet // the partitioned system in sparse format Duu, Duk, Dku, Dkk *Matrix // the partitioned system in dense format Bu, Bk, Xu, Xk Vector // partitioned rhs and unknowns vector }
Equations organises the identification numbers (IDs) of equations in a linear system: [A] ⋅ {x} = {b}. Some of the components of the {x} vector may be known in advance—i.e. some {x} components are "prescribed"—therefore the system of equations must be reduced first before its solution. The equations corresponding to the known {x} values are called "known equations" whereas the equations corresponding to unknown {x} values are called "unknown equations".
The right-hand-side vector {b} will also be partitioned into two sets. However, the "unknown equations" part will have known values of {b}. If needed, the other {b} values can be computed from the "known equations".
The structure Equations will then hold the IDs of two sets of equations: "u" -- unknown {x} values with given {b} values "k" -- known {x} values (the corresponding {b} may be post-computed)
In summary: * We define the u-reduced system of equations with the unknown {x} (and known {b}) ┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄ ┄┄┄┄┄┄┄ i.e. the "effective" system that needs to be solved: [Auu] ⋅ {xu} = {bu} * We define the k-reduced system of equations with the known {x} values. ┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄ ┄┄┄┄┄ * We call the system [A] ⋅ {x} = {b} the "full" system, with all equations. The "full" linear system is: [A]⋅{x} = {b} or [ Auu Auk ]⋅{ xu ? } = { bu ✓ } [ Aku Akk ] { xk ✓ } { bk ? } NOTE: the {bu} part is known and the {bk} can be (post-)computed if needed. The partitioned system is symbolised as follows: Auu Auk u─────> unknown Aku Akk k─────> known u k │ └────────> known └────────────> unknown The Equations structure uses arrays to map the indices of equations from the "full" system to the reduced systems and vice-versa. We call these arrays "maps" but they are not Go maps; they are simple slices of integers and should give better performance than maps. Four "maps" (slices of integers) are built: * UtoF -- reduced u-system to full-system * FtoU -- full-system to reduced u-system * KtoF -- reduced k-system to full-system * FtoK -- full-system to reduced k-system EXAMPLE: N = 9 ⇒ total number of equations kx = [0 3 6] ⇒ known x-components (i.e. "prescribed" equations) 0 1 2 3 4 5 6 7 8 0 1 2 3 4 5 6 7 8 0 +--------+--------+------ 0 ◀ known ▶ 0 [kk] ku ku [kk] ku ku [kk] ku ku 0 1 | | | 1 1 uk ○ ○ uk ○ ○ uk ○ ○ 1 2 | | | 2 2 uk ○ ○ uk ○ ○ uk ○ ○ 2 3 +--------+--------+------ 3 ◀ known ▶ 3 [kk] ku ku [kk] ku ku [kk] ku ku 3 4 | | | 4 4 uk ○ ○ uk ○ ○ uk ○ ○ 4 5 | | | 5 5 uk ○ ○ uk ○ ○ uk ○ ○ 5 6 +--------+--------+------ 6 ◀ known ▶ 6 [kk] ku ku [kk] ku ku [kk] ku ku 6 7 | | | 7 7 uk ○ ○ uk ○ ○ uk ○ ○ 7 8 | | | 8 8 uk ○ ○ uk ○ ○ uk ○ ○ 8 0 1 2 3 4 5 6 7 8 0 1 2 3 4 5 6 7 8 ▲ ▲ ▲ known known known ○ means uu equations Nu = 6 => number of "unknown equations" Nk = 3 => number of "known equations" Nu + Nk = N reduced:0 1 2 3 4 5 Example: UtoF = [1 2 4 5 7 8] ⇒ UtoF[3] returns equation # 5 of full system 0 1 2 3 4 5 6 7 8 FtoU = [ 0 1 2 3 4 5] ⇒ FtoU[5] returns equation # 3 of reduced system -1 -1 -1 ⇒ -1 indicates 'value not set' reduced:0 1 2 KtoF = [0 3 6] ⇒ KtoF[1] returns equation # 3 of full system 0 1 2 3 4 5 6 7 8 FtoK = [0 1 2 ] ⇒ FtoK[3] returns equation # 1 of reduced system -1 -1 -1 -1 -1 -1 ⇒ -1 indicates 'value not set'
func NewEquations ¶
NewEquations creates a new Equations structure
n -- total number of equations; i.e. len({x}) in [A]⋅{x}={b} kx -- known x-components ⇒ "known equations" [may be unsorted]
func (*Equations) Alloc ¶
Alloc allocates the A matrices in triplet format
INPUT: nnz -- total number of nonzeros in each part [nnz(Auu), nnz(Auk), nnz(Aku), nnz(Akk)] nnz may be nil, in this case, the following values are assumed: nnz(Auu) = Nu ⋅ Nu nnz(Auk) = Nu ⋅ Nk nnz(Aku) = Nk ⋅ Nu nnz(Akk) = Nk ⋅ Nk Thus, memory is wasted as the size of a fully dense system is considered. kparts -- also allocates Aku and Akk vectors -- also allocates the partitioned vectors Bu, Bk, Xu, Xk
OUTPUT:
The partitioned system (Auu, Auk, Aku, Akk) is stored as member of this object
func (*Equations) AllocDense ¶
AllocDense allocates the A matrices in dense format
INPUT: kparts -- also allocates Aku and Akk OUTPUT: The partitioned system (Duu, Duk, Dku, Dkk) is stored as member of this object
func (*Equations) JoinVector ¶
JoinVector joins uknown with known parts of vector
INPUT: bu, bk -- partitioned vectors; e.g. o.Bu, and o.Bk or o.Xu, o.Xk OUTPUT: b -- pre-allocated b vector such that b = join(bu,bk)
func (*Equations) Put ¶
Put puts component into the right place in partitioned Triplet (Auu, Auk, Aku, Akk)
I and J are the equation numbers in the FULL system
func (*Equations) SetDense ¶
SetDense allocates and sets partitioned system in dense format
kparts -- also computes Aku and Akk
func (*Equations) SplitVector ¶
SplitVector splits full vector b into known and unknown parts
INPUT: b -- full b vector. b = join(bu,bk) OUTPUT: bu, bk -- partitioned vectors; e.g. o.Bu, and o.Bk or o.Xu, o.Xk
type Matrix ¶
Matrix implements a column-major representation of a matrix by using a linear array that can be passed to Fortran code
NOTE: the functions related to Matrix do not check for the limits of indices and dimensions. Panic may occur then. Example: _ _ | 0 3 | A = | 1 4 | |_ 2 5 _|(m x n) data[i+j*m] = A[i][j]
func NewMatrixDeep2 ¶
NewMatrixDeep2 allocates a new Matrix from given (Deep2) nested slice. NOTE: make sure to have at least 1x1 item
func (Matrix) Apply ¶
Apply sets this matrix with the scaled components of another matrix
this := α * another ⇒ this[i] := α * another[i] NOTE: "another" may be "this"
func (*Matrix) ClearBry ¶
ClearBry clears boundaries
_ _ _ _ Example: | 1 2 3 | | 1 0 0 | A = | 4 5 6 | ⇒ clear(1.0) ⇒ A = | 0 5 0 | |_ 7 8 9 _| |_ 0 0 1 _|
func (*Matrix) ClearRC ¶
ClearRC clear rows and columns and set diagonal components
_ _ _ _ Example: | 1 2 3 4 | | 1 2 3 4 | A = | 5 6 7 8 | ⇒ clear([1,2], [], 1.0) ⇒ A = | 0 1 0 0 | |_ 4 3 2 1 _| |_ 0 0 1 0 _|
func (*Matrix) Col ¶
Col access column j of this matrix. No copies are made since the internal data are in col-major format already. NOTE: this method can be used to modify the columns; e.g. with o.Col(0)[0] = 123
func (*Matrix) CopyInto ¶
CopyInto copies the scaled components of this matrix into another one (result)
result := α * this ⇒ result[ij] := α * this[ij]
func (*Matrix) Det ¶
Det computes the determinant of matrix using the LU factorization
NOTE: this method may fail due to overflow...
func (*Matrix) GetComplex ¶
GetComplex returns a complex version of this matrix
func (*Matrix) GetTranspose ¶
GetTranspose returns the tranpose matrix
func (*Matrix) Largest ¶
Largest returns the largest component |a[ij]| of this matrix, normalised by den
largest := |a[ij]| / den
func (*Matrix) MaxDiff ¶
MaxDiff returns the maximum difference between the components of this and another matrix
func (*Matrix) NormFrob ¶
NormFrob returns the Frobenious norm of this matrix
nrm := ‖a‖_F = sqrt(Σ_i Σ_j a[ij]⋅a[ij]) = ‖a‖_2
func (*Matrix) NormInf ¶
NormInf returns the infinite norm of this matrix
nrm := ‖a‖_∞ = max_i ( Σ_j a[ij] )
func (*Matrix) SetFromDeep2 ¶
SetFromDeep2 sets matrix with data from a nested slice (Deep2) structure
type MatrixC ¶
type MatrixC struct {
M, N int // dimensions
Data []complex128 // data array. column-major => Fortran
}
MatrixC implements a column-major representation of a matrix of complex numbers by using a linear array that can be passed to Fortran code.
NOTE: the functions related to MatrixC do not check for the limits of indices and dimensions. Panic may occur then. Example: _ _ | 0+0i 3+3i | A = | 1+1i 4+4i | |_ 2+2i 5+5i _|(m x n) data[i+j*m] = A[i][j]
func NewMatrixC ¶
NewMatrixC allocates a new (empty) MatrixC with given (m,n) (row/col sizes)
func NewMatrixDeep2c ¶
func NewMatrixDeep2c(a [][]complex128) (o *MatrixC)
NewMatrixDeep2c allocates a new MatrixC from given (Deep2c) nested slice. NOTE: make sure to have at least 1x1 items
func (*MatrixC) Add ¶
func (o *MatrixC) Add(i, j int, val complex128)
Add adds value to (i,j) location
func (MatrixC) Apply ¶
func (o MatrixC) Apply(α complex128, another *MatrixC)
Apply sets this matrix with the scaled components of another matrix
this := α * another ⇒ this[i] := α * another[i] NOTE: "another" may be "this"
func (*MatrixC) Col ¶
Col access column j of this matrix. No copies are made since the internal data are in col-major format already. NOTE: this method can be used to modify the columns; e.g. with o.Col(0)[0] = 123
func (*MatrixC) Fill ¶
func (o *MatrixC) Fill(val complex128)
Fill fills this matrix with a single number val
aij = val
func (*MatrixC) GetColReal ¶
GetColReal returns column j of this matrix considering that the imaginary part is zero
func (*MatrixC) GetDeep2 ¶
func (o *MatrixC) GetDeep2() (M [][]complex128)
GetDeep2 returns nested slice representation
func (*MatrixC) GetTranspose ¶
GetTranspose returns the tranpose matrix
func (*MatrixC) Print ¶
Print prints matrix (without commas or brackets). NOTE: if non-empty, nfmtI must have '+' e.g. %+g
func (*MatrixC) PrintGo ¶
PrintGo prints matrix in Go format NOTE: if non-empty, nfmtI must have '+' e.g. %+g
func (*MatrixC) PrintPy ¶
PrintPy prints matrix in Python format NOTE: if non-empty, nfmtI must have '+' e.g. %+g
func (*MatrixC) SetFromDeep2c ¶
func (o *MatrixC) SetFromDeep2c(a [][]complex128)
SetFromDeep2c sets matrix with data from a nested slice (Deep2c) structure
type Mumps ¶
type Mumps struct {
// contains filtered or unexported fields
}
Mumps wraps the MUMPS solver
type MumpsC ¶
type MumpsC struct {
// contains filtered or unexported fields
}
MumpsC wraps the MUMPS solver (complex version)
type SparseSolver ¶
type SparseSolver interface { Init(t *Triplet, symmetric, verbose bool, ordering, scaling string, comm *mpi.Communicator) Free() Fact() Solve(x, b Vector, bIsDistr bool) }
SparseSolver solves sparse linear systems using UMFPACK or MUMPS
Given: A ⋅ x = b find x such that x = A⁻¹ ⋅ b
func NewSparseSolver ¶
func NewSparseSolver(kind string) SparseSolver
NewSparseSolver finds a SparseSolver in database or panic
kind -- "umfpack" or "mumps" NOTE: remember to call Free() to release allocated resources
type SparseSolverC ¶
type SparseSolverC interface { Init(t *TripletC, symmetric, verbose bool, ordering, scaling string, comm *mpi.Communicator) Free() Fact() Solve(x, b VectorC, bIsDistr bool) }
SparseSolverC solves sparse linear systems using UMFPACK or MUMPS (complex version)
Given: A ⋅ x = b find x such that x = A⁻¹ ⋅ b
func NewSparseSolverC ¶
func NewSparseSolverC(kind string) SparseSolverC
NewSparseSolverC finds a SparseSolver in database or panic
NOTE: remember to call Free() to release allocated resources
type Triplet ¶
type Triplet struct {
// contains filtered or unexported fields
}
Triplet is a simple representation of a sparse matrix, where the indices and values of this matrix are stored directly.
func NewTriplet ¶
NewTriplet returns a new Triplet. This is a wrapper to new(Triplet) followed by Init()
func (*Triplet) PutCCMatAndMatT ¶
PutCCMatAndMatT adds the content of a compressed-column matrix "a" and its transpose "at" to triplet "o" ex: 0 1 2 3 4 5
[... ... ... a00 a10 ...] 0 [... ... ... a01 a11 ...] 1 [... ... ... a02 a12 ...] 2 [. at .] [a00 a01 a02 ... ... ...] 3 => [a . .] [a10 a11 a12 ... ... ...] 4 [. . .] [... ... ... ... ... ...] 5
func (*Triplet) PutMatAndMatT ¶
PutMatAndMatT adds the content of a matrix "a" and its transpose "at" to triplet "o" ex: 0 1 2 3 4 5
[... ... ... a00 a10 ...] 0 [... ... ... a01 a11 ...] 1 [... ... ... a02 a12 ...] 2 [. at .] [a00 a01 a02 ... ... ...] 3 => [a . .] [a10 a11 a12 ... ... ...] 4 [. . .] [... ... ... ... ... ...] 5
func (*Triplet) Start ¶
func (o *Triplet) Start()
Start (re)starts index for inserting items using the Put command
func (*Triplet) ToMatrix ¶
ToMatrix converts a sparse matrix in triplet form to column-compressed form using Umfpack's routines. "realloc_a" indicates whether the internal "a" matrix must be reallocated or not, for instance, in case the structure of the triplet has changed.
INPUT: a -- a previous CCMatrix to be filled in; otherwise, "nil" tells to allocate a new one OUTPUT: the previous "a" matrix or a pointer to a new one
func (*Triplet) WriteSmat ¶
WriteSmat writes a ".smat" file that can be visualised with vismatrix
NOTE: this method will create a CCMatrix first because duplicates must be added before saving the file dirout -- directory for output. will be created fnkey -- filename key (filename without extension). ".smat" will be added tol -- tolerance to skip zero values
type TripletC ¶
type TripletC struct {
// contains filtered or unexported fields
}
TripletC is a simple representation of a sparse matrix, where the indices and values of this matrix are stored directly. (complex version)
func NewTripletC ¶
NewTripletC returns a new TripletC. This is a wrapper to new(TripletC) followed by Init()
func (*TripletC) Init ¶
Init allocates all memory required to hold a sparse matrix in triplet (complex) form
func (*TripletC) Max ¶
Max returns the maximum number of items that can be inserted in the complex triplet
func (*TripletC) Put ¶
func (o *TripletC) Put(i, j int, x complex128)
Put inserts an element to a pre-allocated (with Init) triplet (complex) matrix
func (*TripletC) Start ¶
func (o *TripletC) Start()
Start (re)starts index for inserting items using the Put command
func (*TripletC) ToMatrix ¶
ToMatrix converts a sparse matrix in triplet form with complex numbers to column-compressed form. "realloc_a" indicates whether the internal "a" matrix must be reallocated or not, for instance, in case the structure of the triplet has changed.
INPUT: a -- a previous CCMatrixC to be filled in; otherwise, "nil" tells to allocate a new one OUTPUT: the previous "a" matrix or a pointer to a new one
func (*TripletC) WriteSmat ¶
WriteSmat writes a ".smat" file that can be visualised with vismatrix
NOTE: this method will create a CCMatrixC first because duplicates must be added before saving the file dirout -- directory for output. will be created fnkey -- filename key (filename without extension). ".smat" will be added tol -- tolerance to skip zero values
type Umfpack ¶
type Umfpack struct {
// contains filtered or unexported fields
}
Umfpack wraps the UMFPACK solver
type UmfpackC ¶
type UmfpackC struct {
// contains filtered or unexported fields
}
UmfpackC wraps the UMFPACK solver (complex version)
type Vector ¶
type Vector []float64
Vector defines the vector type for real numbers simply as a slice of float64
func NewVectorMapped ¶
NewVectorMapped returns a new vector after applying a function over all of its components
new: vi = f(i)
func SpSolve ¶
SpSolve solves a sparse linear system (using UMFPACK)
Given: A ⋅ x = b find x such that x = A⁻¹ ⋅ b
func (Vector) Apply ¶
Apply sets this vector with the scaled components of another vector
this := α * another ⇒ this[i] := α * another[i] NOTE: "another" may be "this"
func (Vector) Largest ¶
Largest returns the largest component |u[i]| of this vector, normalised by den
largest := |u[i]| / den
type VectorC ¶
type VectorC []complex128
VectorC defines the vector type for complex numbers simply as a slice of complex128
func NewVectorMappedC ¶
func NewVectorMappedC(m int, f func(i int) complex128) (o VectorC)
NewVectorMappedC returns a new vector after applying a function over all of its components
new: vi = f(i)
func SpSolveC ¶
SpSolveC solves a sparse linear system (using UMFPACK) (complex version)
Given: A ⋅ x = b find x such that x = A⁻¹ ⋅ b
func (VectorC) Apply ¶
func (o VectorC) Apply(α complex128, another VectorC)
Apply sets this vector with the scaled components of another vector
this := α * another ⇒ this[i] := α * another[i] NOTE: "another" may be "this"
func (VectorC) ApplyFunc ¶
func (o VectorC) ApplyFunc(f func(i int, x complex128) complex128)
ApplyFunc runs a function over all components of a vector
vi = f(i,vi)
func (VectorC) Fill ¶
func (o VectorC) Fill(s complex128)
Fill fills a vector with a single number s:
v := s*ones(len(v)) => vi = s
func (VectorC) JoinRealImag ¶
JoinRealImag sets this vector with two vectors having the real and imaginary parts
this := complex(xR, xI) NOTE: len(xR) == len(xI) == len(this)
func (VectorC) MaxDiff ¶
MaxDiff returns the maximum difference between the components of two vectors
func (VectorC) Norm ¶
func (o VectorC) Norm() (nrm complex128)
Norm returns the Euclidean norm of a vector:
nrm := ‖v‖
func (VectorC) SplitRealImag ¶
SplitRealImag splits this vector into two vectors with the real and imaginary parts
xR := real(this) xI := imag(this) NOTE: xR and xI must be pre-allocated with length = len(this)
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package data wraps test_mat from https://people.sc.fsu.edu/~jburkardt/f_src/test_mat/test_mat.html This package should be used in tests only
|
Package data wraps test_mat from https://people.sc.fsu.edu/~jburkardt/f_src/test_mat/test_mat.html This package should be used in tests only |
Package mkl implements lower-level linear algebra routines using MKL for maximum efficiency.
|
Package mkl implements lower-level linear algebra routines using MKL for maximum efficiency. |
Package oblas implements lower-level linear algebra routines using OpenBLAS for maximum efficiency.
|
Package oblas implements lower-level linear algebra routines using OpenBLAS for maximum efficiency. |