tokenizer / README.md
transhumanist-already-exists's picture
Update README.md
45fc51f verified
---
inference: false
library_name: transformers
base_model: google/gemma-3-12b-it
language:
- uk
datasets:
- Goader/kobza
- QIRIM/crh_monocorpus
multilinguality:
- multililingual
tags:
- gemma-3-tokenizer
- ukraine
- corpus-linguistics
pretty_name: “gemma-3 - ukrainized gemma tokenizer”
---
### Using the same approach as [Tereshchenko Blue](https://huggingface.co/transhumanist-already-exists/tereshchenkoblue-tokenizer), now trained on the full [Kobza corpus](https://huggingface.co/datasets/Goader/kobza).
By adding more than 80K Ukrainian tokens **without removing any English or EU languages tokens**, Lapa Tokenizer makes Ukrainian the core language in the multilingual Gemma-3 tokenizer while keeping the vocabulary fixed at its original size of 256K tokens.
### How to possible
More than 16 of the most popular writing systems in the world were analyzed.
Roughly four-fifths of tokens in scripts geographically and culturally distant from Ukraine—for example Bengali, Thai, Chinese, Japanese, and Korean—were pruned.
### Replaced tokens
|Writing system|Tokens removed|Tokens retained|
|-|-|-|
|Han (Chinese)|16,488|4,122|
|Devanagari (Hindi)|10,976|2,743|
|Bengali|7,983|1,995|
|Arabic|6,730|1,682|
|Hiragana / Katakana (Japanese)|3,944|985|
|Hangul (Korean)|3,744|935|
|Tamil|3,080|770|
|Thai|1,740|435|
|Malayalam|1,566|391|
|Telugu|1,428|356|
|Gujarati|1,080|270|
|Kannada|1,016|253|
|Ethiopic|691|172|
|Hebrew|670|167|
|Khmer|481|119|
|Sinhala|435|108|
|Myanmar|410|102|
|Lao|243|60|
|Gurmukhi|215|53|
|Tibetan|107|26|
|Oriya|100|25|
|Cyrillic|13,398|0|
|Gemma-3 \<unused-*\>|6,139|102|
## Feature Overview:
1. +81,492 new Cyrillic BPE tokens trained on the full [Kobza corpus](https://huggingface.co/datasets/Goader/kobza) plus the Cyrillic slice of the [Crimean Tatar corpus](https://huggingface.co/datasets/QIRIM/crh_monocorpus).
2. Just tokens from `Replaced tokens` table was replaced, no any tokens from other Writing system was affected.
3. Unchanged tokens preserve their IDs, enabling direct reuse of Gemma-3 embeddings.
4. Vocab size, Special-token set, pre/post-tokenisation logic, and output formatting match Gemma-3 one-for-one.
5. Reasoning tokens <think></think>
## Simple example
```python
tokenizer = AutoTokenizer.from_pretrained("lapa-llm/tokenizer")
toks = tokenizer("Всі красиві зберігають оптимізм", add_special_tokens=False)
print(len(toks.input_ids)) -only 4 tokens 💪🏻
```
### "fixed" - means that we remove condition that allow to add empty `<think></think>` for hybrid approach. This significantly speeds up tokenization.