mirror of
				https://github.com/gonum/gonum.git
				synced 2025-10-25 08:10:28 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			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)
 | |
| 	}
 | |
| }
 | 
