Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/valentingol/my_ml_template
Personal template for machine learning (and more).
https://github.com/valentingol/my_ml_template
actions badges clean github-actions linter template testing-tools tools workflow yaecs
Last synced: 7 days ago
JSON representation
Personal template for machine learning (and more).
- Host: GitHub
- URL: https://github.com/valentingol/my_ml_template
- Owner: valentingol
- License: mit
- Created: 2022-06-11T23:26:39.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-11-24T18:01:08.000Z (about 1 year ago)
- Last Synced: 2023-11-25T16:44:34.535Z (about 1 year ago)
- Topics: actions, badges, clean, github-actions, linter, template, testing-tools, tools, workflow, yaecs
- Language: Python
- Homepage:
- Size: 380 KB
- Stars: 6
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Personal ML template
[data:image/s3,"s3://crabby-images/dc103/dc103ef0d2e91e4e77fa421cf8fc6f6ccfe0fe4c" alt="Release"](https://github.com/valentingol/my_ml_template/releases)
data:image/s3,"s3://crabby-images/eaeeb/eaeeb2a7fefc7df71ad5e574e46edbbdbbc175ea" alt="PythonVersion"
data:image/s3,"s3://crabby-images/d13e6/d13e6eb2adb15b89ef865e9364aa0bb43ddf309f" alt="PytorchVersion"
[data:image/s3,"s3://crabby-images/e3abb/e3abbe3f796cf52b37d67cc8915646c4f11619b7" alt="License"](https://stringfixer.com/fr/MIT_license)data:image/s3,"s3://crabby-images/aa2f0/aa2f0ce138909c8429d97ccc691d336c5063247d" alt="GitHub Release Date"
data:image/s3,"s3://crabby-images/92aa0/92aa01552e4a0a0c2f63e537635dc9a7107d11e2" alt="GitHub last commit"
[data:image/s3,"s3://crabby-images/051c3/051c36119716174af58f5cad1391b066326adfed" alt="GitHub User followers"](https://github.com/valentingol)
[data:image/s3,"s3://crabby-images/74623/746239ad4f82972e92d158cd89dbd9e2cef92646" alt="GitHub User's User stars"](https://github.com/valentingol)[data:image/s3,"s3://crabby-images/6362d/6362dbc1ef7a7f58b8a38f1092af11189914c234" alt="Torch_logo"](https://pytorch.org/)
[data:image/s3,"s3://crabby-images/e3a25/e3a25a672a9fa48d8855a2ab45128b6f9e2469ba" alt="Wandb_logo"](https://wandb.ai/site)[data:image/s3,"s3://crabby-images/ef6f2/ef6f2e0b2690ac24aa85b0bbb2b688996b5040f1" alt="Ruff_logo"](https://github.com/charliermarsh/ruff)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Black_logo"](https://github.com/psf/black)[data:image/s3,"s3://crabby-images/578f1/578f1e2240001800eb45ce8a2722a3ee0e4fd3a3" alt="Ruff"](https://github.com/valentingol/my_ml_template/actions/workflows/ruff.yaml)
[data:image/s3,"s3://crabby-images/c1c8b/c1c8b7e14e39f9d2c404e87459ab7b9e4917eada" alt="Flake8"](https://github.com/valentingol/my_ml_template/actions/workflows/flake.yaml)
[data:image/s3,"s3://crabby-images/4e320/4e320f7961d24b410b21b8ad078131436e2743e2" alt="Pydocstyle"](https://github.com/valentingol/my_ml_template/actions/workflows/pydocstyle.yaml)
[data:image/s3,"s3://crabby-images/20db1/20db1aa1b60d1e80f212a139ea26d1b617dc9a8d" alt="MyPy"](https://github.com/valentingol/my_ml_template/actions/workflows/mypy.yaml)
[data:image/s3,"s3://crabby-images/05452/05452d2222488083b4a4d0bb0180a4a8e6aa6622" alt="PyLint"](https://github.com/valentingol/my_ml_template/actions/workflows/pylint.yaml)[data:image/s3,"s3://crabby-images/a0990/a09903fc6fb94ee8cae7b6699494d6c542b81d8d" alt="Tests"](https://github.com/valentingol/my_ml_template/actions/workflows/tests.yaml)
[data:image/s3,"s3://crabby-images/340b2/340b2031871e079124b3ad54534a8941051b7443" alt="Coverage"](https://github.com/valentingol/my_ml_template/actions/workflows/tests.yaml)
[data:image/s3,"s3://crabby-images/18e31/18e31280a01f8472c9086fdd5b56d3edc8a80fd9" alt="Bandit"](https://github.com/valentingol/my_ml_template/actions/workflows/bandit.yaml)**Disclaimer**: Even if it is a personal project, everybody can use it freely
and modify it for their own needs.This repository is a template for using in ML projects. It includes:
- Inference and training template scripts
- ⚙️ [YAECS](https://github.com/valentingol/yaecs) as configuration manager
(compatible with WandB, ClearML, ...)
- ✅ `pytest-cov` to check unit tests and get coverage (including an optional
minimum coverage to pass)
- 🎨 `ruff` to check the style and auto-format it, including:
- `pycodestyle` and `flake` to check overall Python scripts style (PEP8)
- `isort` to check the import order of Python scripts
- `pydocstyle` to check Python docstrings style (Numpy convention)
- 🎨 `pylint` to have an overall grade of the style (including an optional minimum
grade to pass)
- 🎨 `black` to auto-format Python scripts
- 🏷️ `mypy` to check typing and type hintsSome GitHub actions 🏭 are provided:
- 🔒 `bandit` for security
- 🎨 `flake8`, `mypy`, `pydocstyle`, `pylint`, `ruff` for style
- Cache is preserved between GH action runs (useful for heavy requirements packages)And finally, some badges:
- 🆙 Release, last commit and release date
- 🧑🤝🧑 Github stats
- 📑 licenses
- 🔖 python version (and pytorch version)
- Pytorch and Wandb badges
- And more...All workflows create a badge available, for instance, in README.
This repository provides also a pre-commit configuration to check end-of-file,
trailing whitespace, flake8 and pydocstyle (numpy).data:image/s3,"s3://crabby-images/49340/493407613f3400beec3c25da7ff609baf4582e7f" alt="alt text"
## HowTo
All feature of this template is easy to adapt on your project by changing names
or versions on the `.github/workflows/` directory and on the badge paths on your
markdown/rst files. All the worflows are independent and can be used individually.
You can also remove any workflow you don't need.Before all, you need to create a [gist](https://gist.github.com/) The id of the
gist is required for pylint and test/coverage badges. Then, you must add a secret
in your repository (*Settings > Secrets > New repository secret*) that is a personal
token with gist scope with name GIST_SECRET (details
[here](https://github.com/Schneegans/dynamic-badges-action)).## Notes
By default, there is no maximum unit test coverage but you can set the minimum
coverage you want in `utils/github_actions/pytest_manager.py`. There is also a
minimum grade for pylint that is 7.0/10 and can be set in
`utils/github_actions/pylint_manager.py`. Details of pylint options are in
`.pylintrc` and can also be changed at will.## Contributing
Even if it is a personal template, feel free to contribute via issues or pull
requests 🤗.See [CONTRIBUTING.md](CONTRIBUTING.md) for more details.