Skip to main content

miscellaneous python utilities

Project description

PyPI PyPI - Downloads

Checks Coverage

GitHub commit activity GitHub closed pull requests code size, bytes

muutils, stylized as "$\mu$utils" or "μutils", is a collection of miscellaneous python utilities, meant to be small and with no dependencies outside of standard python.

statcounter

an extension of collections.Counter that provides "smart" computation of stats (mean, variance, median, other percentiles) from the counter object without using Counter.elements()

dictmagic

has utilities for working with dictionaries, like:

  • converting dotlist-dictionaries to nested dictionaries and back:
    >>> dotlist_to_nested_dict({'a.b.c': 1, 'a.b.d': 2, 'a.e': 3})
    {'a': {'b': {'c': 1, 'd': 2}, 'e': 3}}
    >>> nested_dict_to_dotlist({'a': {'b': {'c': 1, 'd': 2}, 'e': 3}})
    {'a.b.c': 1, 'a.b.d': 2, 'a.e': 3}
    
  • DefaulterDict which works like a defaultdict but can generate the default value based on the key
  • condense_tensor_dict takes a dict of dotlist-tensors and gives a more human-readable summary:
    >>> model = MyGPT()
    >>> print(condense_tensor_dict(model.named_parameters(), 'yaml'))
    
    embed:
        W_E: (50257, 768)
    pos_embed:
        W_pos: (1024, 768)
    blocks:
      '[0-11]':
        attn:
        	'[W_Q, W_K, W_V]': (12, 768, 64)
        W_O: (12, 64, 768)
        	'[b_Q, b_K, b_V]': (12, 64)
        b_O: (768,)
    <...>
    

kappa

Anonymous gettitem, so you can do things like

>>> k = Kappa(lambda x: x**2)
>>> k[2]
4

sysinfo

utility for getting a bunch of system information. useful for logging.

misc:

contains a few utilities: - stable_hash() uses hashlib.sha256 to compute a hash of an object that is stable across runs of python - list_join and list_split which behave like str.join and str.split but for lists - sanitize_fname and dict_to_filename for simplifying the creation of unique filename - shorten_numerical_to_str() and str_to_numeric turns numbers like 123456789 into "123M" and back - freeze, which prevents an object from being modified. Also see gelidum

nbutils

contains utilities for working with jupyter notebooks, such as:

  • quickly converting notebooks to python scripts (and running those scripts) for testing in CI
  • configuring notebooks, to make it easier to switch between figure output formats, locations, and more
  • shorthand for displaying mermaid diagrams and TeX

json_serialize

a tool for serializing and loading arbitrary python objects into json. plays nicely with ZANJ

[tensor_utils]

contains minor utilities for working with pytorch tensors and numpy arrays, mostly for making type conversions easier

group_equiv

groups elements from a sequence according to a given equivalence relation, without assuming that the equivalence relation obeys the transitive property

jsonlines

an extremely simple utility for reading/writing jsonl files

ZANJ

is a human-readable and simple format for ML models, datasets, and arbitrary objects. It's build around having a zip file with json and npy files, and has been spun off into its own project.

There are a couple work-in-progress utilities in _wip that aren't ready for anything, but nothing in this repo is suitable for production. Use at your own risk!

installation

PyPi: muutils

pip install muutils

Note that for using mlutils, tensor_utils, nbutils.configure_notebook, or the array serialization features of json_serialize, you will need to install with optional array dependencies:

pip install muutils[array]

todos:

  • option to have notebook conversion create pytest-compatible tests

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

muutils-0.6.8.tar.gz (96.1 kB view details)

Uploaded Source

Built Distribution

muutils-0.6.8-py3-none-any.whl (112.5 kB view details)

Uploaded Python 3

File details

Details for the file muutils-0.6.8.tar.gz.

File metadata

  • Download URL: muutils-0.6.8.tar.gz
  • Upload date:
  • Size: 96.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for muutils-0.6.8.tar.gz
Algorithm Hash digest
SHA256 a5aed51626b40b3bc5ff6fc4c01ec5289859c095ad1cfa54351991452e797fec
MD5 f0fd65bc2b4c640f2f783c64b06ea183
BLAKE2b-256 7ed15de573355037d394b01be66fa96cfb886a16e310f39eb86252c9d7adcb61

See more details on using hashes here.

File details

Details for the file muutils-0.6.8-py3-none-any.whl.

File metadata

  • Download URL: muutils-0.6.8-py3-none-any.whl
  • Upload date:
  • Size: 112.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for muutils-0.6.8-py3-none-any.whl
Algorithm Hash digest
SHA256 bbabb8c5865a3cfedcb0dc12df00326e438c05358164c71f71f633894757d648
MD5 cc393b35561676ef06cd5ba2fe0d9eab
BLAKE2b-256 d6e7777f461276b22b098a088798ed2bc9e9dc479fbb11bf4f427c41412031a2

See more details on using hashes here.

Supported by

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