forked from glaslos/tlsh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdistance.go
62 lines (54 loc) · 1.18 KB
/
distance.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
package tlsh
// modDiff calculates steps from x to y in circular queue of size R.
func modDiff(x, y byte, R int) int {
var dl, dr int
if y > x {
dl = int(y) - int(x)
dr = int(x) + R - int(y)
} else {
dl = int(x) - int(y)
dr = int(y) + R - int(x)
}
if dl > dr {
return dr
}
return dl
}
// digestDistance calculates distance between two hash digests.
func digestDistance(x [codeSize]byte, y [codeSize]byte) (diff int) {
for i := 0; i < codeSize; i++ {
diff += bitPairsDiffTable[x[i]][y[i]]
}
return
}
// diffTotal calculates diff between two Tlsh hashes for hash header and body.
func diffTotal(a, b *Tlsh, lenDiff bool) (diff int) {
if lenDiff {
lDiff := modDiff(a.lValue, b.lValue, 256)
if lDiff == 0 {
diff = 0
} else if lDiff == 1 {
diff = 1
} else {
diff += lDiff * 12
}
}
q1Diff := modDiff(a.q1Ratio, b.q1Ratio, 16)
if q1Diff <= 1 {
diff += q1Diff
} else {
diff += (q1Diff - 1) * 12
}
q2Diff := modDiff(a.q2Ratio, b.q2Ratio, 16)
if q2Diff <= 1 {
diff += q2Diff
} else {
diff += (q2Diff - 1) * 12
}
// currently we only support 1 byte checksum
if a.checksum != b.checksum {
diff++
}
diff += digestDistance(a.code, b.code)
return diff
}