# minrecord
<p align="center">
<a href="https://github.com/durandtibo/minrecord/actions">
<img alt="CI" src="https://github.com/durandtibo/minrecord/workflows/CI/badge.svg">
</a>
<a href="https://github.com/durandtibo/minrecord/actions">
<img alt="Nightly Tests" src="https://github.com/durandtibo/minrecord/workflows/Nightly%20Tests/badge.svg">
</a>
<a href="https://github.com/durandtibo/minrecord/actions">
<img alt="Nightly Package Tests" src="https://github.com/durandtibo/minrecord/workflows/Nightly%20Package%20Tests/badge.svg">
</a>
<br/>
<a href="https://durandtibo.github.io/minrecord/">
<img alt="Documentation" src="https://github.com/durandtibo/minrecord/workflows/Documentation%20(stable)/badge.svg">
</a>
<a href="https://durandtibo.github.io/minrecord/">
<img alt="Documentation" src="https://github.com/durandtibo/minrecord/workflows/Documentation%20(unstable)/badge.svg">
</a>
<br/>
<a href="https://codecov.io/gh/durandtibo/minrecord">
<img alt="Codecov" src="https://codecov.io/gh/durandtibo/minrecord/branch/main/graph/badge.svg">
</a>
<a href="https://codeclimate.com/github/durandtibo/minrecord/maintainability">
<img src="https://api.codeclimate.com/v1/badges/d6e3047eedfd2e1e0d86/maintainability" />
</a>
<a href="https://codeclimate.com/github/durandtibo/minrecord/test_coverage">
<img src="https://api.codeclimate.com/v1/badges/d6e3047eedfd2e1e0d86/test_coverage" />
</a>
<br/>
<a href="https://github.com/psf/black">
<img alt="Code style: black" src="https://img.shields.io/badge/code%20style-black-000000.svg">
</a>
<a href="https://google.github.io/styleguide/pyguide.html#s3.8-comments-and-docstrings">
<img alt="Doc style: google" src="https://img.shields.io/badge/%20style-google-3666d6.svg">
</a>
<a href="https://github.com/astral-sh/ruff">
<img src="https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json" alt="Ruff" style="max-width:100%;">
</a>
<a href="https://github.com/guilatrova/tryceratops">
<img alt="Doc style: google" src="https://img.shields.io/badge/try%2Fexcept%20style-tryceratops%20%F0%9F%A6%96%E2%9C%A8-black">
</a>
<br/>
<a href="https://pypi.org/project/minrecord/">
<img alt="PYPI version" src="https://img.shields.io/pypi/v/minrecord">
</a>
<a href="https://pypi.org/project/minrecord/">
<img alt="Python" src="https://img.shields.io/pypi/pyversions/minrecord.svg">
</a>
<a href="https://opensource.org/licenses/BSD-3-Clause">
<img alt="BSD-3-Clause" src="https://img.shields.io/pypi/l/minrecord">
</a>
<br/>
<a href="https://pepy.tech/project/minrecord">
<img alt="Downloads" src="https://static.pepy.tech/badge/minrecord">
</a>
<a href="https://pepy.tech/project/minrecord">
<img alt="Monthly downloads" src="https://static.pepy.tech/badge/minrecord/month">
</a>
<br/>
</p>
## 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.
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.
```pycon
>>> 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)](https://durandtibo.github.io/minrecord/): documentation from the latest stable
release.
- [main (unstable)](https://durandtibo.github.io/minrecord/main/): 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](https://packaging.python.org/guides/installing-using-pip-and-virtual-environments/).
`minrecord` can be installed from pip using the following command:
```shell
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:
```shell
pip install minrecord[all]
```
Please check the [get started page](https://durandtibo.github.io/minrecord/get_started) 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` | `>=0.8.4,<1.0` | `>=0.2,<1.0`<sup>*</sup> | `>=3.9,<3.14` |
| `0.1.0` | `>=0.8.4,<1.0` | `>=0.2,<1.0`<sup>*</sup> | `>=3.9,<3.14` |
| `0.0.2` | `>=0.7.2,<1.0` | `>=0.1,<1.0`<sup>*</sup> | `>=3.9,<3.13` |
| `0.0.1` | `>=0.7,<1.0` | `>=0.1,<1.0` | `>=3.9,<3.13` |
<sup>*</sup> indicates an optional dependency
## Contributing
Please check the instructions in [CONTRIBUTING.md](.github/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](https://github.com/durandtibo/minrecord/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](LICENSE)
file.
Raw data
{
"_id": null,
"home_page": "https://github.com/durandtibo/minrecord",
"name": "minrecord",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.14,>=3.9",
"maintainer_email": null,
"keywords": "record, machine learning",
"author": "Thibaut Durand",
"author_email": "durand.tibo+gh@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/7f/3b/a5799ee4fc9fa47d041e74f565de42f3948a5fce0f4d496fc817945971ed/minrecord-0.1.0.tar.gz",
"platform": null,
"description": "# minrecord\n\n<p align=\"center\">\n <a href=\"https://github.com/durandtibo/minrecord/actions\">\n <img alt=\"CI\" src=\"https://github.com/durandtibo/minrecord/workflows/CI/badge.svg\">\n </a>\n <a href=\"https://github.com/durandtibo/minrecord/actions\">\n <img alt=\"Nightly Tests\" src=\"https://github.com/durandtibo/minrecord/workflows/Nightly%20Tests/badge.svg\">\n </a>\n <a href=\"https://github.com/durandtibo/minrecord/actions\">\n <img alt=\"Nightly Package Tests\" src=\"https://github.com/durandtibo/minrecord/workflows/Nightly%20Package%20Tests/badge.svg\">\n </a>\n <br/>\n <a href=\"https://durandtibo.github.io/minrecord/\">\n <img alt=\"Documentation\" src=\"https://github.com/durandtibo/minrecord/workflows/Documentation%20(stable)/badge.svg\">\n </a>\n <a href=\"https://durandtibo.github.io/minrecord/\">\n <img alt=\"Documentation\" src=\"https://github.com/durandtibo/minrecord/workflows/Documentation%20(unstable)/badge.svg\">\n </a>\n <br/>\n <a href=\"https://codecov.io/gh/durandtibo/minrecord\">\n <img alt=\"Codecov\" src=\"https://codecov.io/gh/durandtibo/minrecord/branch/main/graph/badge.svg\">\n </a>\n <a href=\"https://codeclimate.com/github/durandtibo/minrecord/maintainability\">\n <img src=\"https://api.codeclimate.com/v1/badges/d6e3047eedfd2e1e0d86/maintainability\" />\n </a>\n <a href=\"https://codeclimate.com/github/durandtibo/minrecord/test_coverage\">\n <img src=\"https://api.codeclimate.com/v1/badges/d6e3047eedfd2e1e0d86/test_coverage\" />\n </a>\n <br/>\n <a href=\"https://github.com/psf/black\">\n <img alt=\"Code style: black\" src=\"https://img.shields.io/badge/code%20style-black-000000.svg\">\n </a>\n <a href=\"https://google.github.io/styleguide/pyguide.html#s3.8-comments-and-docstrings\">\n <img alt=\"Doc style: google\" src=\"https://img.shields.io/badge/%20style-google-3666d6.svg\">\n </a>\n <a href=\"https://github.com/astral-sh/ruff\">\n <img src=\"https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json\" alt=\"Ruff\" style=\"max-width:100%;\">\n </a>\n <a href=\"https://github.com/guilatrova/tryceratops\">\n <img alt=\"Doc style: google\" src=\"https://img.shields.io/badge/try%2Fexcept%20style-tryceratops%20%F0%9F%A6%96%E2%9C%A8-black\">\n </a>\n <br/>\n <a href=\"https://pypi.org/project/minrecord/\">\n <img alt=\"PYPI version\" src=\"https://img.shields.io/pypi/v/minrecord\">\n </a>\n <a href=\"https://pypi.org/project/minrecord/\">\n <img alt=\"Python\" src=\"https://img.shields.io/pypi/pyversions/minrecord.svg\">\n </a>\n <a href=\"https://opensource.org/licenses/BSD-3-Clause\">\n <img alt=\"BSD-3-Clause\" src=\"https://img.shields.io/pypi/l/minrecord\">\n </a>\n <br/>\n <a href=\"https://pepy.tech/project/minrecord\">\n <img alt=\"Downloads\" src=\"https://static.pepy.tech/badge/minrecord\">\n </a>\n <a href=\"https://pepy.tech/project/minrecord\">\n <img alt=\"Monthly downloads\" src=\"https://static.pepy.tech/badge/minrecord/month\">\n </a>\n <br/>\n</p>\n\n## Overview\n\n`minrecord` is a minimalist Python library to record values in a ML workflow.\nIn particular, it provides functionalities to track the best value, or the most recent values by\nstoring a limiting number of values.\nIt is possible to customize the library e.g. it is possible to define a new logic to track the best\nvalue.\nBelow is an example to show how to track the best scalar value when the best value is the maximum\nvalue and when the best value is the minimum value.\n\n```pycon\n\n>>> from minrecord import MaxScalarRecord, MinScalarRecord\n>>> record_max = MaxScalarRecord(\"accuracy\")\n>>> record_max.update([(0, 42), (None, 45), (2, 46)])\n>>> record_max.add_value(40)\n>>> record_max.get_best_value()\n46\n>>> record_min = MinScalarRecord(\"loss\")\n>>> record_min.update([(0, 42), (None, 45), (2, 46)])\n>>> record_min.add_value(50)\n>>> record_min.get_best_value()\n42\n\n```\n\n## Documentation\n\n- [latest (stable)](https://durandtibo.github.io/minrecord/): documentation from the latest stable\n release.\n- [main (unstable)](https://durandtibo.github.io/minrecord/main/): documentation associated to the\n main branch of the repo. This documentation may contain a lot of work-in-progress/outdated/missing\n parts.\n\n## Installation\n\nWe highly recommend installing\na [virtual environment](https://packaging.python.org/guides/installing-using-pip-and-virtual-environments/).\n`minrecord` can be installed from pip using the following command:\n\n```shell\npip install minrecord\n```\n\nTo make the package as slim as possible, only the minimal packages required to use `minrecord` are\ninstalled.\nTo include all the dependencies, you can use the following command:\n\n```shell\npip install minrecord[all]\n```\n\nPlease check the [get started page](https://durandtibo.github.io/minrecord/get_started) to see how\nto\ninstall only some specific dependencies or other alternatives to install the library.\nThe following is the corresponding `minrecord` versions and tested dependencies.\n\n| `minrecord` | `coola` | `objectory` | `python` |\n|-------------|----------------|--------------------------|---------------|\n| `main` | `>=0.8.4,<1.0` | `>=0.2,<1.0`<sup>*</sup> | `>=3.9,<3.14` |\n| `0.1.0` | `>=0.8.4,<1.0` | `>=0.2,<1.0`<sup>*</sup> | `>=3.9,<3.14` |\n| `0.0.2` | `>=0.7.2,<1.0` | `>=0.1,<1.0`<sup>*</sup> | `>=3.9,<3.13` |\n| `0.0.1` | `>=0.7,<1.0` | `>=0.1,<1.0` | `>=3.9,<3.13` |\n\n<sup>*</sup> indicates an optional dependency\n\n## Contributing\n\nPlease check the instructions in [CONTRIBUTING.md](.github/CONTRIBUTING.md).\n\n## Suggestions and Communication\n\nEveryone is welcome to contribute to the community.\nIf you have any questions or suggestions, you can\nsubmit [Github Issues](https://github.com/durandtibo/minrecord/issues).\nWe will reply to you as soon as possible. Thank you very much.\n\n## API stability\n\n:warning: While `minrecord` is in development stage, no API is guaranteed to be stable from one\nrelease to the next.\nIn fact, it is very likely that the API will change multiple times before a stable 1.0.0 release.\nIn practice, this means that upgrading `minrecord` to a new version will possibly break any code\nthat\nwas using the old version of `minrecord`.\n\n## License\n\n`minrecord` is licensed under BSD 3-Clause \"New\" or \"Revised\" license available\nin [LICENSE](LICENSE)\nfile.\n",
"bugtrack_url": null,
"license": "BSD-3-Clause",
"summary": "Minimalist library to record values in a ML workflow",
"version": "0.1.0",
"project_urls": {
"Homepage": "https://github.com/durandtibo/minrecord",
"Repository": "https://github.com/durandtibo/minrecord"
},
"split_keywords": [
"record",
" machine learning"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "f36b125fbe68b5d0ff938d264c128d91dd6ca25b00deb01042f6ac9b62f8cae7",
"md5": "97862b0ff6d8aa484dacc8aa7b35f1d2",
"sha256": "bd81022f3ec21ff82a9bef632dfa56f2daa05eca54ec5c6f99445ba9ea71c460"
},
"downloads": -1,
"filename": "minrecord-0.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "97862b0ff6d8aa484dacc8aa7b35f1d2",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.14,>=3.9",
"size": 18446,
"upload_time": "2024-10-22T20:25:48",
"upload_time_iso_8601": "2024-10-22T20:25:48.496506Z",
"url": "https://files.pythonhosted.org/packages/f3/6b/125fbe68b5d0ff938d264c128d91dd6ca25b00deb01042f6ac9b62f8cae7/minrecord-0.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "7f3ba5799ee4fc9fa47d041e74f565de42f3948a5fce0f4d496fc817945971ed",
"md5": "1b2e45ca40bdebe539e4aea60d29bdc9",
"sha256": "b96f6d455b62b3022bd0527c3ec20971be78fc638ef84790a9c5c3414d745805"
},
"downloads": -1,
"filename": "minrecord-0.1.0.tar.gz",
"has_sig": false,
"md5_digest": "1b2e45ca40bdebe539e4aea60d29bdc9",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<3.14,>=3.9",
"size": 16755,
"upload_time": "2024-10-22T20:25:49",
"upload_time_iso_8601": "2024-10-22T20:25:49.676289Z",
"url": "https://files.pythonhosted.org/packages/7f/3b/a5799ee4fc9fa47d041e74f565de42f3948a5fce0f4d496fc817945971ed/minrecord-0.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-22 20:25:49",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "durandtibo",
"github_project": "minrecord",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "minrecord"
}