-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtune_test.go
72 lines (54 loc) · 1.65 KB
/
tune_test.go
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
//go:build tuneparam
// +build tuneparam
/* Copyright (c) 2021, Serhat Şevki Dinçer.
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
package sorty
import (
"fmt"
"testing"
"time"
"github.com/jfcg/opt"
)
func printSec(_ string, d time.Duration) float64 {
return d.Seconds()
}
func optPrint(x, y int, v float64) {
fmt.Printf("%3d %3d %5.2fs\n", x, y, v)
}
var (
optName = [...]string{"sortU4/F4", "lsw-U4/F4", "sortS", "lsw-S"}
optFn = [...]func() float64{
// optimize for arithmetic types
func() float64 { return sumDurU4(false) + sumDurF4(false) },
// optimize for lesswap sort
func() float64 { return sumDurLswU4(false) + sumDurLswF4(false) },
// optimize for string
func() float64 { return sumDurS(false) },
// optimize for lesswap sort (string key)
func() float64 { return sumDurLswS(false) }}
optInd int
)
func optStep(x, y int) float64 {
if x <= 2*nsShort || y <= 2*x {
return 9e9 // keep parameters feasible
}
MaxLenIns, MaxLenInsFC, MaxLenRec, MaxLenRecFC = x, x, y, y
return optFn[optInd]()
}
func optRun(suffix string, ins0, rec0 int) {
fmt.Printf("\n%s\nMaxLenIns%s MaxLenRec%s:\n", optName[optInd], suffix, suffix)
_, _, _, n := opt.FindMinTri(2, ins0, rec0, ins0/4, rec0/4, optStep, optPrint)
fmt.Println(n, "calls")
}
// Optimize max slice lengths for insertion sort/recursion
// Takes a long time, run with -tags tuneparam
func TestOptimize(t *testing.T) {
tsPtr = t
optRun("", 80, 600)
for optInd = 1; optInd < len(optFn); optInd++ {
optRun("FC", 40, 300)
}
}