-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathreverse_bit_order_test.go
64 lines (58 loc) · 1.44 KB
/
reverse_bit_order_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
package kzg
import (
"fmt"
"math/rand"
"testing"
)
func TestReverseBitOrder(t *testing.T) {
for s := 2; s < 2048; s *= 2 {
t.Run(fmt.Sprintf("size_%d", s), func(t *testing.T) {
data := make([]uint32, s, s)
for i := 0; i < s; i++ {
data[i] = uint32(i)
}
reverseBitOrder(uint32(s), func(i, j uint32) {
data[i], data[j] = data[j], data[i]
})
for i := 0; i < s; i++ {
if got := reverseBitsLimited(uint32(s), uint32(i)); got != data[i] {
t.Errorf("bad reversal at %d", i)
}
expected := fmt.Sprintf("%0"+fmt.Sprintf("%d", s)+"b", i)
got := fmt.Sprintf("%0"+fmt.Sprintf("%d", s)+"b", data[i])
if len(expected) != len(got) {
t.Fatalf("bad length: %d, expected %d", len(got), len(expected))
}
for j := 0; j < len(expected); j++ {
}
}
})
}
}
func TestRevBitorderBitIndex(t *testing.T) {
for i := 0; i < 32; i++ {
got := bitIndex(uint32(1 << i))
if got != uint8(i) {
t.Errorf("bit index %d is wrong: %d", i, got)
}
}
}
func TestReverseBits(t *testing.T) {
rng := rand.New(rand.NewSource(1234))
for i := 0; i < 10000; i++ {
v := rng.Uint32()
expected := revStr(fmt.Sprintf("%032b", v))
out := reverseBits(v)
got := fmt.Sprintf("%032b", out)
if expected != got {
t.Errorf("bit mismatch: expected: %s, got: %s ", expected, got)
}
}
}
func revStr(v string) string {
out := make([]byte, len(v))
for i := 0; i < len(v); i++ {
out[i] = v[len(v)-1-i]
}
return string(out)
}