Skip to main content

Minimalist library to record values in a ML workflow

Project description

minrecord

CI Nightly Tests Nightly Package Tests Codecov
Documentation Documentation
Code style: black Doc style: google Ruff Doc style: google
PYPI version Python BSD-3-Clause
Downloads Monthly downloads

Overview

minrecord is a minimalist Python library to record values in a ML workflow. In particular, it provides functionalities to track the best value, or the most recent values by storing a limiting number of values. It is possible to customize the library e.g. it is possible to define a new logic to track the best value.

Key Features

  • 📊 Track Best Values: Automatically track the best value seen during training
  • 🔄 Recent History: Store only recent values to minimize memory usage
  • ✅ Improvement Detection: Easily check if your model is still improving
  • 🎯 Flexible Comparators: Define custom logic to determine what "better" means
  • 🗂️ Record Manager: Organize and manage multiple metrics efficiently
  • 💾 Serialization: Save and load record states for checkpointing
  • 🚀 Minimal Dependencies: Lightweight with only essential dependencies

Below is an example to show how to track the best scalar value when the best value is the maximum value and when the best value is the minimum value.

>>> from minrecord import MaxScalarRecord, MinScalarRecord
>>> record_max = MaxScalarRecord("accuracy")
>>> record_max.update([(0, 42), (None, 45), (2, 46)])
>>> record_max.add_value(40)
>>> record_max.get_best_value()
46
>>> record_min = MinScalarRecord("loss")
>>> record_min.update([(0, 42), (None, 45), (2, 46)])
>>> record_min.add_value(50)
>>> record_min.get_best_value()
42

Documentation

  • latest (stable): documentation from the latest stable release.
  • main (unstable): documentation associated to the main branch of the repo. This documentation may contain a lot of work-in-progress/outdated/missing parts.

Installation

We highly recommend installing a virtual environment. minrecord can be installed from pip using the following command:

pip install minrecord

To make the package as slim as possible, only the minimal packages required to use minrecord are installed. To include all the dependencies, you can use the following command:

pip install minrecord[all]

Please check the get started page to see how to install only some specific dependencies or other alternatives to install the library. The following is the corresponding minrecord versions and tested dependencies.

minrecord coola objectory python
main >=1.0,<2.0 >=0.3,<1.0* >=3.10
0.3.0 >=1.0,<2.0 >=0.3,<1.0* >=3.10
0.2.0 >=0.10,<1.0 >=0.3,<1.0* >=3.10
0.1.0 >=0.8.4,<1.0 >=0.2,<1.0* >=3.9,<3.14
0.0.2 >=0.7.2,<1.0 >=0.1,<1.0* >=3.9,<3.13
0.0.1 >=0.7,<1.0 >=0.1,<1.0 >=3.9,<3.13

* indicates an optional dependency

Contributing

Please check the instructions in CONTRIBUTING.md.

Suggestions and Communication

Everyone is welcome to contribute to the community. If you have any questions or suggestions, you can submit Github Issues. We will reply to you as soon as possible. Thank you very much.

API stability

:warning: While minrecord is in development stage, no API is guaranteed to be stable from one release to the next. In fact, it is very likely that the API will change multiple times before a stable 1.0.0 release. In practice, this means that upgrading minrecord to a new version will possibly break any code that was using the old version of minrecord.

License

minrecord is licensed under BSD 3-Clause "New" or "Revised" license available in LICENSE file.

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

minrecord-0.3.0.tar.gz (17.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

minrecord-0.3.0-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file minrecord-0.3.0.tar.gz.

File metadata

  • Download URL: minrecord-0.3.0.tar.gz
  • Upload date:
  • Size: 17.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for minrecord-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5d98888bca25a45271eb4b246daa8f7d672ca26e97c6d14a084a3aa3126f7f27
MD5 60ee329752e7a1c6867faf8656d4408f
BLAKE2b-256 5f7a7e5e06ecb2e12d464502563c0c9e435ac7c6244a2b870eab094b7f38e043

See more details on using hashes here.

File details

Details for the file minrecord-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: minrecord-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for minrecord-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 475a31cba3a537fd960a2c67825823e30162937f3fbb98e4195032e0a64fac6a
MD5 285db7d649fe9bb632892621917e5a4d
BLAKE2b-256 e79552274018ea73535dad82e17344017ad1ea0504a5051301abb0f7aa136676

See more details on using hashes here.

Supported by

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