Files
gonum/lapack/testlapack/dptsv.go
2025-02-01 22:18:04 +10:30

55 lines
1.3 KiB
Go

// Copyright ©2023 The Gonum Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package testlapack
import (
"fmt"
"math/rand/v2"
"testing"
)
type Dptsver interface {
Dptsv(n, nrhs int, d, e []float64, b []float64, ldb int) (ok bool)
}
func DptsvTest(t *testing.T, impl Dptsver) {
rnd := rand.New(rand.NewPCG(1, 1))
for _, n := range []int{0, 1, 2, 3, 4, 5, 10, 20, 50, 51, 52, 53, 54, 100} {
for _, nrhs := range []int{0, 1, 2, 3, 4, 5, 10, 20, 50} {
for _, ldb := range []int{max(1, nrhs), nrhs + 3} {
dptsvTest(t, impl, rnd, n, nrhs, ldb)
}
}
}
}
func dptsvTest(t *testing.T, impl Dptsver, rnd *rand.Rand, n, nrhs, ldb int) {
const tol = 1e-15
name := fmt.Sprintf("n=%v", n)
// Generate a random diagonally dominant symmetric tridiagonal matrix A.
d, e := newRandomSymTridiag(n, rnd)
// Generate a random solution matrix X.
xWant := randomGeneral(n, nrhs, ldb, rnd)
// Compute the right-hand side.
b := zeros(n, nrhs, ldb)
dstmm(n, nrhs, d, e, xWant.Data, xWant.Stride, b.Data, b.Stride)
// Solve A*X=B.
ok := impl.Dptsv(n, nrhs, d, e, b.Data, b.Stride)
if !ok {
t.Errorf("%v: Dptsv failed", name)
return
}
resid := dpttrsResidual(b, xWant)
if resid > tol {
t.Errorf("%v: unexpected solution: |diff| = %v, want <= %v", name, resid, tol)
}
}