Files
gonum/graph/encoding/dot/bench_test.go
2025-02-01 22:18:04 +10:30

117 lines
3.5 KiB
Go

// Copyright ©2024 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 dot
import (
"fmt"
"math/rand/v2"
"testing"
"gonum.org/v1/gonum/graph"
"gonum.org/v1/gonum/graph/graphs/gen"
"gonum.org/v1/gonum/graph/multi"
"gonum.org/v1/gonum/graph/simple"
)
var (
gnpDirected_10_tenth = gnpDirected(10, 0.1)
gnpDirected_100_tenth = gnpDirected(100, 0.1)
gnpDirected_1000_tenth = gnpDirected(1000, 0.1)
gnpDirected_10_half = gnpDirected(10, 0.5)
gnpDirected_100_half = gnpDirected(100, 0.5)
gnpDirected_1000_half = gnpDirected(1000, 0.5)
powerLawMultiDirected_10_tenth = powerLawMultiDirected(10, 1)
powerLawMultiDirected_100_tenth = powerLawMultiDirected(100, 10)
powerLawMultiDirected_1000_tenth = powerLawMultiDirected(1000, 100)
powerLawMultiDirected_10_half = powerLawMultiDirected(10, 5)
powerLawMultiDirected_100_half = powerLawMultiDirected(100, 50)
powerLawMultiDirected_1000_half = powerLawMultiDirected(1000, 500)
)
func gnpDirected(n int, p float64) graph.Directed {
g := simple.NewDirectedGraph()
err := gen.Gnp(g, n, p, rand.NewPCG(1, 1))
if err != nil {
panic(fmt.Sprintf("dot: bad test: %v", err))
}
return g
}
func powerLawMultiDirected(n, d int) graph.DirectedMultigraph {
g := multi.NewDirectedGraph()
err := gen.PowerLaw(g, n, d, rand.NewPCG(1, 1))
if err != nil {
panic(fmt.Sprintf("dot: bad test: %v", err))
}
return g
}
func benchmarkUnmarshal(b *testing.B, g graph.Directed) {
marshalled, err := Marshal(g, "g", "", "")
if err != nil {
b.Fatalf("dot: bad Marshal input: %v", err)
}
b.ResetTimer()
for i := 0; i < b.N; i++ {
if err := Unmarshal(marshalled, simple.NewDirectedGraph()); err != nil {
b.Fatalf("dot: bad Unmarshal input: %v", err)
}
}
}
func BenchmarkUnmarshalGnp_10_tenth(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_10_tenth)
}
func BenchmarkUnmarshalGnp_100_tenth(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_100_tenth)
}
func BenchmarkUnmarshalGnp_1000_tenth(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_1000_tenth)
}
func BenchmarkUnmarshalGnp_10_half(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_10_half)
}
func BenchmarkUnmarshalGnp_100_half(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_100_half)
}
func BenchmarkUnmarshalGnp_1000_half(b *testing.B) {
benchmarkUnmarshal(b, gnpDirected_1000_half)
}
func benchmarkUnmarshalMulti(b *testing.B, g graph.DirectedMultigraph) {
marshalled, err := MarshalMulti(g, "g", "", "")
if err != nil {
b.Fatalf("dot: bad Marshal input: %v", err)
}
b.ResetTimer()
for i := 0; i < b.N; i++ {
if err := UnmarshalMulti(marshalled, multi.NewDirectedGraph()); err != nil {
b.Fatalf("dot: bad Unmarshal input: %v", err)
}
}
}
func BenchmarkUnmarshalMultiPowerLaw_10_tenth(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_10_tenth)
}
func BenchmarkUnmarshalMultiPowerLaw_100_tenth(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_100_tenth)
}
func BenchmarkUnmarshalMultiPowerLaw_1000_tenth(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_1000_tenth)
}
func BenchmarkUnmarshalMultiPowerLaw_10_half(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_10_half)
}
func BenchmarkUnmarshalMultiPowerLaw_100_half(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_100_half)
}
func BenchmarkUnmarshalMultiPowerLaw_1000_half(b *testing.B) {
benchmarkUnmarshalMulti(b, powerLawMultiDirected_1000_half)
}