mirror of
https://github.com/gonum/gonum.git
synced 2025-10-05 15:16:59 +08:00

This is not intended to be a completed transition since it leaves the libraries unusable to external client code, but rather as a step towards use of math/rand/v2. This initial step allows repair of sequence change failures without having to worry about API difference.
56 lines
1.4 KiB
Go
56 lines
1.4 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"
|
|
"testing"
|
|
|
|
"gonum.org/v1/gonum/internal/rand"
|
|
)
|
|
|
|
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.NewSource(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)
|
|
}
|
|
}
|