Skip to main content

Brando's Ultimate Utils for Science, Machine Learning, and AI

Project description

ultimate-utils (uutils)

PyPI License Python 3.10+

A comprehensive Python utility library for machine learning research, spanning PyTorch training infrastructure, statistical analysis, meta-learning, LLM evaluation, and experiment management.

Built and maintained by Brando Miranda (Stanford, MIT, UIUC).

pip install ultimate-utils
import uutils
uutils.hello()

What's Inside

Module Description
uutils Core utilities — file I/O, argument parsing, serialization (dill/pickle/JSON), git helpers, seed management, progress bars
uutils.torch_uu PyTorch training loops, distributed training, checkpointing, optimizers, learning rate schedulers
uutils.torch_uu.models Model utilities and HuggingFace integrations
uutils.torch_uu.dataloaders Dataloaders for meta-learning (miniImageNet, CIFAR-FS), standard vision, and multi-dataset sampling
uutils.torch_uu.metrics CCA/PWCCA/DCCA similarity, model complexity, task diversity (Task2Vec), accuracy with confidence intervals
uutils.torch_uu.meta_learners Meta-learning algorithms (MAML, Prototypical Networks, etc.)
uutils.stats_uu Hypothesis testing, p-values, effect sizes (Cohen's d), power analysis, confidence intervals, ANOVA, regression
uutils.plot Plotting with error bands, heatmaps, bar charts, LaTeX table export
uutils.hf_uu HuggingFace training utilities — full fine-tuning, QLoRA/Unsloth, causal and seq2seq LM training
uutils.evals LLM evaluation — math benchmarks (MATH, Putnam, OlympiadBench), API inference (Claude, OpenAI, vLLM), answer extraction
uutils.dspy_uu DSPy-based synthetic data generation for in-context learning and fine-tuning
uutils.jax_uu JAX multi-head attention, layer norm, flash attention implementations
uutils.numpy_uu Statistical moments, confidence intervals, matrix utilities
uutils.logging_uu Weights & Biases integration — setup, logging, sweeps, model watching
uutils.emailing SMTP email notifications with attachments

Installation

Note: PyTorch must be installed separately (with CUDA if you need GPU support).

Development install (recommended)

conda create -n uutils python=3.11 -y
conda activate uutils
pip install -e ~/ultimate-utils

pip install from PyPI

pip install ultimate-utils

Verify installation

python -c "import uutils; uutils.hello()"
python -c "import uutils; uutils.torch_uu.gpu_test_torch_any_device()"

Quick Examples

Seed everything for reproducibility

from uutils import seed_everything
seed_everything(42)

Save and load with dill

from uutils import save_with_dill, load_with_dill
save_with_dill(my_object, '~/data/my_object.pkl')
obj = load_with_dill('~/data/my_object.pkl')

Plot with error bands

from uutils.plot import plot_with_error_bands
plot_with_error_bands(x, y, yerr, xlabel='Steps', ylabel='Loss', title='Training Loss')

Statistical testing with effect size

from uutils.stats_uu.effect_size import stat_test_with_effect_size_as_emphasis
stat_test_with_effect_size_as_emphasis(group1_data, group2_data)

W&B logging

from uutils.logging_uu.wandb_logging.common import setup_wandb, log_2_wandb
setup_wandb(args)
log_2_wandb(metrics_dict, step=step)

Publishing to PyPI

# Bump version in setup.py, then:
cd ~/ultimate-utils && bash scripts/publish_to_pypi.sh

Citation

If you use ultimate-utils in your research, please cite:

@software{miranda2024uutils,
  author       = {Brando Miranda},
  title        = {ultimate-utils: A Comprehensive Utility Library for Machine Learning Research},
  year         = {2024},
  publisher    = {PyPI},
  url          = {https://github.com/brando90/ultimate-utils},
  note         = {Available at \url{https://pypi.org/project/ultimate-utils/}}
}

You can also find the author's publications on Google Scholar.

Related Publications

This library has supported research in the following publications (among others):

License

Apache-2.0

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

ultimate_utils-0.10.4.tar.gz (653.3 kB view details)

Uploaded Source

Built Distribution

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

ultimate_utils-0.10.4-py3-none-any.whl (589.9 kB view details)

Uploaded Python 3

File details

Details for the file ultimate_utils-0.10.4.tar.gz.

File metadata

  • Download URL: ultimate_utils-0.10.4.tar.gz
  • Upload date:
  • Size: 653.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.6

File hashes

Hashes for ultimate_utils-0.10.4.tar.gz
Algorithm Hash digest
SHA256 3796b0be419a3e6b3a2080d71968471de94a49acd9a9e3b5d9be1813c9c96163
MD5 41aaf40f0b7b3ce45324856623b29ccb
BLAKE2b-256 447d70dab703deda0034d44e8a84b974414b8afcfcf34707b35e0c22b7b09a05

See more details on using hashes here.

File details

Details for the file ultimate_utils-0.10.4-py3-none-any.whl.

File metadata

File hashes

Hashes for ultimate_utils-0.10.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3bb7e0725c9318d38981d8c95a896ebd78c52393dc03e4fea05decf07ff2f258
MD5 8efc872449cc89173452dae159cb476d
BLAKE2b-256 8d41d874c3fe2b61dd8fdad53d5af334c30bcb15531e076b875ea3c868c1b4ac

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