A library to check if two complex/nested objects are equal or not
Project description
coola
Overview
coola is a Python library that provides simple functions to check in a single line if two
complex/nested objects are equal or not.
coola was initially designed to work
with PyTorch Tensors
and NumPy ndarray, but it
is possible to extend it
to support other data structures.
Motivation
Let's imagine you have the following dictionaries that contain both a PyTorch Tensor and a
NumPy ndarray.
You want to check if the two dictionaries are equal or not.
By default, Python does not provide an easy way to check if the two dictionaries are equal or not.
It is not possible to use the default equality operator == because it will raise an error.
The coola library was developed to fill this gap. coola provides a function objects_are_equal
that can indicate if two complex/nested objects are equal or not.
import numpy
import torch
from coola import objects_are_equal
data1 = {"torch": torch.ones(2, 3), "numpy": numpy.zeros((2, 3))}
data2 = {"torch": torch.zeros(2, 3), "numpy": numpy.ones((2, 3))}
objects_are_equal(data1, data2)
coola also provides a function objects_are_allclose that can indicate if two complex/nested
objects are equal within a tolerance or not.
from coola import objects_are_allclose
objects_are_allclose(data1, data2, atol=1e-6)
Please check the quickstart page to learn more on
how to use coola.
Installation
We highly recommend installing
a virtual environment.
coola can be installed from pip using the following command:
pip install coola
To make the package as slim as possible, only the minimal packages required to use coola are
installed.
To include all the packages, you can use the following command:
pip install coola[all]
Please check the get started page to see how to install only some specific packages or other alternatives to install the library.
Contributing
Please check the instructions in CONTRIBUTING.md.
API stability
:warning: While coola 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 coola to a new version will possibly break any code that
was using the old version of coola.
License
coola is licensed under BSD 3-Clause "New" or "Revised" license available in LICENSE
file.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file coola-0.0.13.tar.gz.
File metadata
- Download URL: coola-0.0.13.tar.gz
- Upload date:
- Size: 15.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.10.12 Linux/5.15.0-1041-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f04712a47436f276de63b055ae605c6b9019df38ce4f11663fd8d185b171a03
|
|
| MD5 |
e25cc7b73088d1ac1d7618f6e5132bf1
|
|
| BLAKE2b-256 |
e8c5cb4e102741abdfe8c5327b1490ed2599743636ec02a574cbba000cfb802c
|
File details
Details for the file coola-0.0.13-py3-none-any.whl.
File metadata
- Download URL: coola-0.0.13-py3-none-any.whl
- Upload date:
- Size: 20.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.10.12 Linux/5.15.0-1041-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a15082b97cc81be4eaeb760534f83e2738f02b0b4c3803be14bff862837a7d2
|
|
| MD5 |
2363965bdd4ba66394eedc1fd5eded3d
|
|
| BLAKE2b-256 |
9963f7db425934857c4c6abc91c54c25e8344605e2aadd95606e9b707fb15039
|