Pro models [pretrain]
Collection
Frozen-embedding LMs for English, Russian, Chinese; demonstration & comparison with standard LM.
β’
6 items
β’
Updated
Description
Experimental 200M parameter language model jointly trained on an English-Russian (EN-RU) corpus with frozen, visually-motivated token embeddings. Designed for demonstration of cross-lingual learning without updating embeddings.
Training details
Evaluation
Task | pro_bvv_ru |
---|---|
MMLU | 22.63% Β± 0.19% |
ARC-e | 23.63% Β± 0.95% |
ARC-c | 22.91% Β± 1.52% |
C-SENSE | 20.26% Β± 0.44% |
BLEU [en-ru] | 6.14% Β± 0.21% |
BLEU [ru-en] | 8.07% Β± 0.43% |
β οΈ Limitations Research use only. Trained on a small subset. Quality, robustness, and reasoning are much lower than SOTA models. SFT was only lightly applied; not intended for real world use.
If you use this model or the underlying concepts in your research, please cite our work:
@misc{bochkov2025emergentsemanticstokenembeddings,
title={Emergent Semantics Beyond Token Embeddings: Transformer LMs with Frozen Visual Unicode Representations},
author={A. Bochkov},
year={2025},
eprint={2507.04886},
archivePrefix={arXiv},
primaryClass={cs.CL},
url={https://arxiv.org/abs/2507.04886},
}
@misc{bochkov2025growingtransformersmodularcomposition,
title={Growing Transformers: Modular Composition and Layer-wise Expansion on a Frozen Substrate},
author={A. Bochkov},
year={2025},
eprint={2507.07129},
archivePrefix={arXiv},
primaryClass={cs.LG},
url={https://arxiv.org/abs/2507.07129},
}
This work demonstrates that transformer blocks, not token embeddings, carry the semantic burden in LLMs β a step toward modular, fusable, multilingual LMs.
Usage
from transformers import AutoTokenizer, AutoModelForCausalLM
import torch
tokenizer = AutoTokenizer.from_pretrained('Bochkov/pro_bvv_ru')
model = AutoModelForCausalLM.from_pretrained('Bochkov/pro_bvv_ru', trust_remote_code=True).to('cuda')
inputs = torch.tensor([tokenizer.encode("Example input: ")], device='cuda')
outputs = model.generate(inputs, max_new_tokens=100)
print(tokenizer.decode(outputs[0]))