A Frequency-Quantized HyperLogLog Autocorrection algorithm that also is dyslexia-friendly.
Project description
FQ-HLL
An improved Frequency-Quantized HyperLogLog (FQ-HLL) Autocorrection Library
For theoretical value, there is nothing in my algorithm that uses any information about the English language or the QWERTY keyboard, to do any of the corrections. It is a NON-ML algorithm too.
Usage
The library defaults to searching within its own folder before searching in your local directory. Visit my GitHub Repo for more details, but there are two text files offered as base dictionaries: 20k_shun4midx.txt and database.txt, with around 20000 and 400 words respectively. The below code would only visit the local directory. If no dictionary is specified, 20k_shun4midx.txt would be used instead.
# ======== SAMPLE USAGE ======== #
if __name__ == "__main__":
ac = Autocorrector()
# File
ans1 = ac.autocorrect("test_files/typo_file.txt", "test_files/class_suggestions.txt")
print(ans1)
ans2 = ac.top3("test_files/typo_file.txt", "test_files/class_suggestions.txt")
# Optionally, you can not want it to output it into a file, then:
# Individual strings
ans3 = ac.autocorrect("hillo")
ans4 = ac.top3("hillo")
# Arrays
ans5 = ac.autocorrect(["tsetign", "hillo", "goobye", "haedhpoesn"])
ans6 = ac.top3(["tsetign", "hillo", "goobye", "haedhpoesn"])
# You can even have a custom dictionary!
dictionary = ["apple", "banana", "grape", "orange"]
custom_ac = Autocorrector(dictionary)
ans7 = custom_ac.autocorrect(["applle", "banana", "banan", "orenge", "grap", "pineapple"])
ans8 = custom_ac.top3(["applle", "banana", "banan", "orenge", "grap", "pineapple"])
print(ans7)
print(ans8)
Results
More detail can be found in my GitHub Repo.
TL;DR it is way more accurate than traditional non-ML, non-language-specific algorithms such as BK-Tree and SymSpell and it also quite fast.
Notes
- HLL naturally doesn't have Local Differential Privacy (LDP) yet, but has natural obfuscation.
- This library does not collect personal data. However, still use it at your own discretion.
Dyslexia
Personally, I've always had an interest in autocorrect because I'm dyslexic and often unintentionally scramble or reverse letters when I read. Here are my thoughts about this algorithm based on my dyslexia.
- Reasoning would be more detailed in the
algo_description/description.pdffile in my GitHub Repo, but I find this algorithm's autocorrection suggestions are sometimes more intuitive (e.g. "klof" -> "folk") to my dyslexia than other Levenshtein distance-based autocorrection models. - As a side note, as a dyslexic person, I naturally process words similar to how the FQ-HLL algorithm processes words, and that was my intuition in terms of how to create this algorithm in the first place.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fq_hll-1.0.2.tar.gz.
File metadata
- Download URL: fq_hll-1.0.2.tar.gz
- Upload date:
- Size: 83.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb0f4c9e3717804366cf9b1649eee1b3451604fd934c5830bf5b77f073f13380
|
|
| MD5 |
0bfdb86b8de72bdb025f11a684e86345
|
|
| BLAKE2b-256 |
f5afed70ebc33ac3252f779fedfd6a288dc144b7f32d4d140fbb8a3c93140c66
|
File details
Details for the file fq_hll-1.0.2-py3-none-any.whl.
File metadata
- Download URL: fq_hll-1.0.2-py3-none-any.whl
- Upload date:
- Size: 87.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3279f9b6a5ef122df008f29e058b7135eed0552d9122d5c6276ba84045d45c67
|
|
| MD5 |
492badc7e9c244e09106b0bab0f3d251
|
|
| BLAKE2b-256 |
46e6ff164f90ce74837ff78990c55a2cac9d32493c5c15803efb91cbdf50043a
|