-
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
/
Copy pathhuffmancoding_test.go
55 lines (48 loc) · 1.67 KB
/
huffmancoding_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
// huffmancoding_test.go
// description: Tests the compression, encoding and decoding algorithms of huffmancoding.go.
// author(s) [pedromsrocha](https://github.com/pedromsrocha)
// see huffmancoding.go
package compression_test
import (
"sort"
"testing"
"github.com/TheAlgorithms/Go/compression"
)
// SymbolCountOrd computes sorted symbol-frequency list of input message
func SymbolCountOrd(message string) []compression.SymbolFreq {
runeCount := make(map[rune]int)
for _, s := range message {
runeCount[s]++
}
listfreq := make([]compression.SymbolFreq, len(runeCount))
i := 0
for s, n := range runeCount {
listfreq[i] = compression.SymbolFreq{Symbol: s, Freq: n}
i++
}
sort.Slice(listfreq, func(i, j int) bool { return listfreq[i].Freq < listfreq[j].Freq })
return listfreq
}
func TestHuffman(t *testing.T) {
messages := []string{
"hello world \U0001F600",
"colorless green ideas sleep furiously",
"the quick brown fox jumps over the lazy dog",
`Lorem ipsum dolor sit amet, consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.`,
}
for _, message := range messages {
t.Run("huffman: "+message, func(t *testing.T) {
tree, _ := compression.HuffTree(SymbolCountOrd(message))
codes := make(map[rune][]bool)
compression.HuffEncoding(tree, nil, codes)
messageCoded := compression.HuffEncode(codes, message)
messageHuffDecoded := compression.HuffDecode(tree, tree, messageCoded, "")
if messageHuffDecoded != message {
t.Errorf("got: %q\nbut expected: %q", messageHuffDecoded, message)
}
})
}
}