Small language model.
Project description
slangmod
small language model
Ever wondered how large language models (LLMs) like ChatGPT, Claude, LLama, Deepseek, etc., actually work, like, really work? I did. And I figured there is only one way to find out: Make one yourself. From scratch.
Of course, I wasn't expecting to beat the big players at their own game,
but I wanted to know what you can do on consumer hardware (meaning a
state-of-the art gaming PC with a single graphics card supported by
PyTorch). So, naturally, it was going to be a small
language model. These hardware limitations are reflected in software
design choices. Specifically, slangmod does not employ any type of
parallelization that would keep multiple GPUs busy at the same time, and all
training data are loaded into CPU RAM at once, to be drip-fed to the model
on the GPU from there (1 billion tokens take up about 7.5 GB worth of 64-bit
integer numbers).
Having said that, slangmod provides everything you need to
- preprocess and clean your text corpus;
- chose and train one of the HuggingFace tokenizers;
- specify a Transformer model including the type of positional encodings and the feedforward block;
- train your model with a choice of optimizers and learning-rate schedulers, employing early-stopping if you like;
- monitor convergence and experiment on hyperparameters;
- explore text-generation algorithms like top-k, top-p or beamsearch;
- and, finally, chat with your model.
To do all these things, slangmod provides a command-line interface (CLI)
with fine-grained configuration options on one hand, and the raw building
blocks it is made of on the other hand. Leveraging the foundational
functionalities provided by the swak package, any other workflow
can thus be quickly coded up.
Installation
Python package
- Create a new virtual environment running at least
python 3.12. - The easiest way of installing
slangmodis from the python package index PyPI, where it is hosted. Simply typepip install slangmod
or treat it like any other python package in your dependency management. - While it is, in principle, possible to run
slangmodon the CPU, this is only intended for debugging purposes. To get any results in finite time, you also need a decent graphics card, and you must have a working installation of PyTorch to make good use of it. Because there is no way of knowing which version of CUDA (or ROC) you have installed on your machine and how you installed it, PyTorch is not an explicit dependency ofslangmod. You will have to install it yourself, e.g., following these instructions. If you are usingpipenvfor dependency management, you can also have a look at the Pipfile in the root of theslangmodrepository and taylor it to your needs. Personally, I gopipenv sync --categories=cpu
for a CPU-only installation of PyTorch (for debugging only) andpipenv sync --categories=cuda
if I want GPU support. - Finally, with the virtual environment you just created active, open a console
and type
slagnmod -hto check that everything works.
Docker image
A docker image with GPU-enabled PyTorch and all other dependencies inside is available on the Docker Hub.
docker pull yedivanseven/slangmod
To use it, you must have a host machine that
- has an NVIDIA GPU,
- has the drivers for it installed, and
- exposes it via the container toolkit.
Change into a working directory, i.e., one where slangmod will read its
config file slangmod.toml from and where it will save outputs to, and mount
this directory to the path /workdir inside the container when you run it.
docker run --rm -v ./:/workdir yedivanseven/slangmod
This will invoke slangmod -h.
In the event that you still want to clean your raw text with the help of
slangmod, you will also have to mount the folder with those dirty files
when your start a docker container.
docker run --rm -v ./:/workdir -v /path/to/raw/docs:/raw yedivanseven/slangmod clean ...
For all other command-line options and to find out about this config TOML file, refer to the ...
Documentation
The documentation for both the CLI and the API of slangmod is hosted
on GitHub Pages.
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 slangmod-0.1.1.tar.gz.
File metadata
- Download URL: slangmod-0.1.1.tar.gz
- Upload date:
- Size: 57.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb407720eab0a166c4dc7a7f1d0f0ac4ec9aaaa1453b95376a9fcfb5ae74269b
|
|
| MD5 |
31e6a97b7fcea25d964864150ff83dcb
|
|
| BLAKE2b-256 |
2005cc73a4aeb83543c3ba937731c30610f783b56216aed89a6fb297ce2953f2
|
Provenance
The following attestation bundles were made for slangmod-0.1.1.tar.gz:
Publisher:
publish-package.yml on yedivanseven/slangmod
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
slangmod-0.1.1.tar.gz -
Subject digest:
cb407720eab0a166c4dc7a7f1d0f0ac4ec9aaaa1453b95376a9fcfb5ae74269b - Sigstore transparency entry: 169896809
- Sigstore integration time:
-
Permalink:
yedivanseven/slangmod@8580486042ce1c3912d0ccd1aa996c005b63171c -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/yedivanseven
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@8580486042ce1c3912d0ccd1aa996c005b63171c -
Trigger Event:
release
-
Statement type:
File details
Details for the file slangmod-0.1.1-py3-none-any.whl.
File metadata
- Download URL: slangmod-0.1.1-py3-none-any.whl
- Upload date:
- Size: 84.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
21a28c03c543efb88820750c97fde85d079c4b86b75101dbe13a5e135dcdcb45
|
|
| MD5 |
9c25ffa1d78871a84d61806d4425d0cb
|
|
| BLAKE2b-256 |
c71fcb6d5b9177f1dce932f3042cf4a04fcddeb4f0a5b3ffe904bf14e1bffc86
|
Provenance
The following attestation bundles were made for slangmod-0.1.1-py3-none-any.whl:
Publisher:
publish-package.yml on yedivanseven/slangmod
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
slangmod-0.1.1-py3-none-any.whl -
Subject digest:
21a28c03c543efb88820750c97fde85d079c4b86b75101dbe13a5e135dcdcb45 - Sigstore transparency entry: 169896810
- Sigstore integration time:
-
Permalink:
yedivanseven/slangmod@8580486042ce1c3912d0ccd1aa996c005b63171c -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/yedivanseven
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@8580486042ce1c3912d0ccd1aa996c005b63171c -
Trigger Event:
release
-
Statement type: