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.2.tar.gz (422.8 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.2-py3-none-any.whl (510.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ultimate_utils-0.10.2.tar.gz
  • Upload date:
  • Size: 422.8 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.2.tar.gz
Algorithm Hash digest
SHA256 d43347560e28d7422e8dc22fc561bc6c0fa51ef777ed3937378dbd814e2fa96a
MD5 7c855ed7f946c1faf1b3f5ef1210332f
BLAKE2b-256 2db2cf91422fbfbce76cedc3c728c495718dd3af6e239aca7b86d7d3da54db0f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ultimate_utils-0.10.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c422d72f41f3232547eb38da58792cda9a72fe483c20ede8554bf087a53f702f
MD5 1612fd6846289791ecff8b82581b5d54
BLAKE2b-256 c310f9ce8ffff07aaf56436b4d90e6a113c391d2760300fee8b48d595d567e7e

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