64 lines
1.0 KiB
Go
Raw Normal View History

2022-10-25 15:25:08 +01:00
package smetrics
import (
"strings"
)
// The Soundex encoding. It is a phonetic algorithm that considers how the words sound in English. Soundex maps a string to a 4-byte code consisting of the first letter of the original string and three numbers. Strings that sound similar should map to the same code.
func Soundex(s string) string {
2024-05-15 19:15:00 -04:00
b := strings.Builder{}
b.Grow(4)
2022-10-25 15:25:08 +01:00
p := s[0]
2024-05-15 19:15:00 -04:00
if p <= 'z' && p >= 'a' {
p -= 32 // convert to uppercase
}
b.WriteByte(p)
n := 0
for i := 1; i < len(s); i++ {
2022-10-25 15:25:08 +01:00
c := s[i]
2024-05-15 19:15:00 -04:00
if c <= 'z' && c >= 'a' {
c -= 32 // convert to uppercase
} else if c < 'A' || c > 'Z' {
continue
}
if c == p {
2022-10-25 15:25:08 +01:00
continue
}
p = c
2024-05-15 19:15:00 -04:00
switch c {
case 'B', 'P', 'F', 'V':
c = '1'
case 'C', 'S', 'K', 'G', 'J', 'Q', 'X', 'Z':
c = '2'
case 'D', 'T':
c = '3'
case 'L':
c = '4'
case 'M', 'N':
c = '5'
case 'R':
c = '6'
default:
continue
}
b.WriteByte(c)
n++
if n == 3 {
break
2022-10-25 15:25:08 +01:00
}
}
2024-05-15 19:15:00 -04:00
for i := n; i < 3; i++ {
b.WriteByte('0')
2022-10-25 15:25:08 +01:00
}
2024-05-15 19:15:00 -04:00
return b.String()
2022-10-25 15:25:08 +01:00
}