mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-04 01:57:53 +01:00
34b0a08207
* gguf-py: Refactor and add file reading support * Replay changes from #3871 Credit to @cebtenzzre for that pull * Various type annotation fixes. * sort imports with isort (again) * Fix missing return statement in add_tensor * style cleanup with flake8 * fix NamedTuple and Enum usage * Fix an issue with state init in GGUFReader Move examples to an examples/ directory Clean up examples Add an example of modifying keys in a GGUF file Update documentation with info on examples Try to support people importing gguf/gguf.py directly * Damagage is not a word. * Clean up gguf-py/examples/modify_gguf.py whitespace Co-authored-by: Jared Van Bortel <cebtenzzre@gmail.com> * Update gguf-py/examples/modify_gguf.py formatting Co-authored-by: Jared Van Bortel <cebtenzzre@gmail.com> * Update gguf-py/gguf/gguf_reader.py type hint Co-authored-by: Jared Van Bortel <cebtenzzre@gmail.com> * Make examples executable, formatting changes * Add more information to GGUFReader and examples comments * Include a gguf Python package version bump * Add convert-gguf-endian.py script * cleanup * gguf-py : bump minor version * Reorganize scripts * Make GGUFReader endian detection less arbitrary * Add JSON dumping support to gguf-dump.py Which I kind of regret now * A few for gguf-dump.py cleanups * Murder accidental tuple in gguf-py/scripts/gguf-dump.py Co-authored-by: Jared Van Bortel <cebtenzzre@gmail.com> * cleanup * constants : remove unneeded type annotations * fix python 3.8 compat * Set up gguf- scripts in pyproject.toml * And include scripts/__init__.py, derp * convert.py: We can't currently support Q8_0 on big endian. * gguf-py: SpecialVocab: Always try available sources for special token ids gguf-py: SpecialVocab: Try to load merges from merges.txt if not in tokenizer.json gguf-py: SpecialVocab: Add 'add_bos_token' type bools to GGUF metadata u * cleanup * Promote add_X_token to GGUF metadata for BOS and EOS --------- Co-authored-by: Jared Van Bortel <jared@nomic.ai> Co-authored-by: Jared Van Bortel <cebtenzzre@gmail.com>
82 lines
2.3 KiB
Markdown
82 lines
2.3 KiB
Markdown
## gguf
|
|
|
|
This is a Python package for writing binary files in the [GGUF](https://github.com/ggerganov/ggml/pull/302)
|
|
(GGML Universal File) format.
|
|
|
|
See [convert-llama-hf-to-gguf.py](https://github.com/ggerganov/llama.cpp/blob/master/convert-llama-hf-to-gguf.py)
|
|
as an example for its usage.
|
|
|
|
## Installation
|
|
```sh
|
|
pip install gguf
|
|
```
|
|
|
|
## API Examples/Simple Tools
|
|
|
|
[examples/writer.py](https://github.com/ggerganov/llama.cpp/blob/master/gguf-py/examples/writer.py) — Generates `example.gguf` in the current directory to demonstrate generating a GGUF file. Note that this file cannot be used as a model.
|
|
|
|
[scripts/gguf-dump.py](https://github.com/ggerganov/llama.cpp/blob/master/gguf-py/scripts/gguf-dump.py) — Dumps a GGUF file's metadata to the console.
|
|
|
|
[scripts/gguf-set-metadata.py](https://github.com/ggerganov/llama.cpp/blob/master/gguf-py/scripts/gguf-set-metadata.py) — Allows changing simple metadata values in a GGUF file by key.
|
|
|
|
[scripts/gguf-convert-endian.py](https://github.com/ggerganov/llama.cpp/blob/master/gguf-py/scripts/gguf-convert-endian.py) — Allows converting the endianness of GGUF files.
|
|
|
|
## Development
|
|
Maintainers who participate in development of this package are advised to install it in editable mode:
|
|
|
|
```sh
|
|
cd /path/to/llama.cpp/gguf-py
|
|
|
|
pip install --editable .
|
|
```
|
|
|
|
**Note**: This may require to upgrade your Pip installation, with a message saying that editable installation currently requires `setup.py`.
|
|
In this case, upgrade Pip to the latest:
|
|
|
|
```sh
|
|
pip install --upgrade pip
|
|
```
|
|
|
|
## Automatic publishing with CI
|
|
|
|
There's a GitHub workflow to make a release automatically upon creation of tags in a specified format.
|
|
|
|
1. Bump the version in `pyproject.toml`.
|
|
2. Create a tag named `gguf-vx.x.x` where `x.x.x` is the semantic version number.
|
|
|
|
```sh
|
|
git tag -a gguf-v1.0.0 -m "Version 1.0 release"
|
|
```
|
|
|
|
3. Push the tags.
|
|
|
|
```sh
|
|
git push origin --tags
|
|
```
|
|
|
|
## Manual publishing
|
|
If you want to publish the package manually for any reason, you need to have `twine` and `build` installed:
|
|
|
|
```sh
|
|
pip install build twine
|
|
```
|
|
|
|
Then, folow these steps to release a new version:
|
|
|
|
1. Bump the version in `pyproject.toml`.
|
|
2. Build the package:
|
|
|
|
```sh
|
|
python -m build
|
|
```
|
|
|
|
3. Upload the generated distribution archives:
|
|
|
|
```sh
|
|
python -m twine upload dist/*
|
|
```
|
|
|
|
## TODO
|
|
- [ ] Add tests
|
|
- [ ] Include conversion scripts as command line entry points in this package.
|