1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
// 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 distmv
import (
"log"
"testing"
"golang.org/x/exp/rand"
"gonum.org/v1/gonum/mat"
)
func BenchmarkMarginalNormal10(b *testing.B) {
sz := 10
rnd := rand.New(rand.NewSource(1))
normal := randomNormal(sz, rnd)
normal.CovarianceMatrix(&mat.SymDense{}) // pre-compute sigma
b.ResetTimer()
for i := 0; i < b.N; i++ {
marg, ok := normal.MarginalNormal([]int{1}, nil)
if !ok {
b.Error("bad test")
}
_ = marg
}
}
func BenchmarkMarginalNormalReset10(b *testing.B) {
sz := 10
rnd := rand.New(rand.NewSource(1))
normal := randomNormal(sz, rnd)
b.ResetTimer()
for i := 0; i < b.N; i++ {
marg, ok := normal.MarginalNormal([]int{1}, nil)
if !ok {
b.Error("bad test")
}
_ = marg
}
}
func BenchmarkMarginalNormalSingle10(b *testing.B) {
sz := 10
rnd := rand.New(rand.NewSource(1))
normal := randomNormal(sz, rnd)
b.ResetTimer()
for i := 0; i < b.N; i++ {
marg := normal.MarginalNormalSingle(1, nil)
_ = marg
}
}
func randomNormal(sz int, rnd *rand.Rand) *Normal {
mu := make([]float64, sz)
for i := range mu {
mu[i] = rnd.Float64()
}
data := make([]float64, sz*sz)
for i := range data {
data[i] = rnd.Float64()
}
dM := mat.NewDense(sz, sz, data)
var sigma mat.SymDense
sigma.SymOuterK(1, dM)
normal, ok := NewNormal(mu, &sigma, nil)
if !ok {
log.Fatal("bad test, not pos def")
}
return normal
}
|