mirror of
https://github.com/gonum/gonum.git
synced 2025-09-27 03:26:04 +08:00
44 lines
1.1 KiB
Go
44 lines
1.1 KiB
Go
// Copyright ©2016 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 optimize
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"gonum.org/v1/gonum/mat"
|
|
"gonum.org/v1/gonum/optimize/functions"
|
|
"gonum.org/v1/gonum/stat/distmv"
|
|
)
|
|
|
|
func TestGuessAndCheck(t *testing.T) {
|
|
t.Parallel()
|
|
dim := 30
|
|
problem := Problem{
|
|
Func: functions.ExtendedRosenbrock{}.Func,
|
|
}
|
|
mu := make([]float64, dim)
|
|
sigma := mat.NewSymDense(dim, nil)
|
|
for i := 0; i < dim; i++ {
|
|
sigma.SetSym(i, i, 1)
|
|
}
|
|
d, ok := distmv.NewNormal(mu, sigma, nil)
|
|
if !ok {
|
|
panic("bad test")
|
|
}
|
|
initX := make([]float64, dim)
|
|
_, err := Minimize(problem, initX, nil, &GuessAndCheck{Rander: d})
|
|
if err != nil {
|
|
t.Errorf("unexpected error running Minimize with nil settings: %v", err)
|
|
}
|
|
|
|
settings := &Settings{}
|
|
settings.Concurrent = 5
|
|
settings.MajorIterations = 15
|
|
_, err = Minimize(problem, initX, settings, &GuessAndCheck{Rander: d})
|
|
if err != nil {
|
|
t.Errorf("unexpected error running Minimize with settings %+v: %v", settings, err)
|
|
}
|
|
}
|