Skip to main content

Core training module for the Open Language Model (OLMo)

Project description

OLMo-core

Building blocks for OLMo modeling and training

Examples || Docs || PyPI || Beaker Images || License || Changelog

Installation

First install PyTorch according to the instructions specific to your operating system. Then you can install from PyPI with:

pip install ai2-olmo-core

API stability

Even though this library is under rapid development we are trying hard to adhere to Semantic Versioning with every release except for features that are explicitly marked as beta features. Those features will be tagged like this in the API docs:

image

Official training scripts

Official training scripts for various model sizes can be found in src/scripts/train/. To see the exact usage for each script, run the script without any arguments.

Throughput numbers from these scripts with various different configuration settings are reported below, measured on a cluster with NVIDIA H100 GPUs.

Model size Context length Precision Throughput[^1] Training script Commandline overrides                                   
1B 4096 BF16 44,000 TPS OLMo-1B.py
4096 BF16/FP8[^2] 51,000 TPS OLMo-1B.py --model.float8_config.enabled=true
7B 4096 BF16 10,000 TPS OLMo-7B.py
4096 BF16/FP8 13,000 TPS OLMo-7B.py --model.float8_config.enabled=true
13B 4096 BF16 4,600 TPS OLMo-13B.py
4096 BF16/FP8 5,500 TPS OLMo-13B.py --model.float8_config.enabled=true

[^1]: Throughput reported in tokens per second per device. [^2]: In this setup most matrix multiplications are computed in float8, everything else is in bfloat16.

Development

After cloning OLMo-core and setting up a Python virtual environment, install the codebase from source with:

pip install -e .[all]

The Python library source code is located in src/olmo_core. The corresponding tests are located in src/test. The library docs are located in docs. You can build the docs locally with make docs.

Code checks:

  • We use pytest to run tests. You can run all tests with pytest -v src/test. You can also point pytest at a specific test file to run it individually.
  • We use isort and black for code formatting. Ideally you should integrate these into your editor, but you can also run them manually or configure them with a pre-commit hook. To validate that all files are formatted correctly, run make style-check.
  • We use ruff as our primary linter. You can run it with make lint-check.
  • We use mypy as our type checker. You can run it with make type-check.

Citing

@article{OLMo,
  title={OLMo: Accelerating the Science of Language Models},
  author={Dirk Groeneveld and Iz Beltagy and Pete Walsh and Akshita Bhagia and Rodney Kinney and Oyvind Tafjord and A. Jha and Hamish Ivison and Ian Magnusson and Yizhong Wang and Shane Arora and David Atkinson and Russell Authur and Khyathi Raghavi Chandu and Arman Cohan and Jennifer Dumas and Yanai Elazar and Yuling Gu and Jack Hessel and Tushar Khot and William Merrill and Jacob Daniel Morrison and Niklas Muennighoff and Aakanksha Naik and Crystal Nam and Matthew E. Peters and Valentina Pyatkin and Abhilasha Ravichander and Dustin Schwenk and Saurabh Shah and Will Smith and Emma Strubell and Nishant Subramani and Mitchell Wortsman and Pradeep Dasigi and Nathan Lambert and Kyle Richardson and Luke Zettlemoyer and Jesse Dodge and Kyle Lo and Luca Soldaini and Noah A. Smith and Hanna Hajishirzi},
  year={2024},
  url={https://api.semanticscholar.org/CorpusID:267365485},
  journal={arXiv preprint},
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ai2_olmo_core-1.5.0.tar.gz (146.6 kB view details)

Uploaded Source

Built Distribution

ai2_olmo_core-1.5.0-py3-none-any.whl (172.6 kB view details)

Uploaded Python 3

File details

Details for the file ai2_olmo_core-1.5.0.tar.gz.

File metadata

  • Download URL: ai2_olmo_core-1.5.0.tar.gz
  • Upload date:
  • Size: 146.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.15

File hashes

Hashes for ai2_olmo_core-1.5.0.tar.gz
Algorithm Hash digest
SHA256 4cdbcfb9db89e9f57235a07b69a4025fb1bbd30139759be482b1637a2aa85cbd
MD5 75dd333dbf731d4354f66a0d48c0a208
BLAKE2b-256 d5960aa87a3c73a06dc8587acfa6b80995ee0129b3b8c868f918bf6cea7a4344

See more details on using hashes here.

File details

Details for the file ai2_olmo_core-1.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ai2_olmo_core-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9b7aaeb0fb48c4023a163181bffc04d69ee0ac5393f61dff8483d215aaf27281
MD5 7d0dc7df7bfaeb7bb26fddaaaa59cf57
BLAKE2b-256 c765823f2b7cffca262b4701a5af692dafdc89b1dda0098a6eb034c2f136fe69

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page