Lazy array programming in Python
Project description
Lappy is a fork of Sophia Lin’s lazyray that supports more operations beyond arithmetics.
In Lappy, everything computable is considered an array object (unlike numpy, it does not offer separate scalar types). An array object has six basic components: the shape, the dtype, the expression, the value, the formal argument list, and the environment (capture list). Scalars are special arrays with shape being an empty tuple. If the dtype is an integer type, there can be assumptions associated with the array elements represented by an integer set (for scalars) or map (for non-scalars).
Documentation
Please visit https://xiaoyu-wei.com/docs/lappy/ for the latest documentation.
Status
This is a list of things that can be achieved with lappy today:
✅ Arithmetic and scalar mathematics (lifted scalar functions / universal functions)
✅ Axis reordering / transpose
✅ Reshaping
✅ Broadcasting (semi-dynamic)
Scope
Roadmap
✅ Scan and fold
✅ Tensor contractions, like np.einsum (including dot products and matrix multiply)
✅ Slicing (static and dynamic)
✅ Fancy indexing (static and dynamic)
✅ Integration with Numpy’s dispatch mechanism like __array__ and __array_ufunc__
✅ Some linear algebra like svd, qr, lstsq
Anti-features
- ❌ Another array IR like APL. lappy is not an IR and does not intend to be.
It serves as a tool to build parametrized array expressions for lazy evaluation, and strives to provide numpy compatible APIs.
Lappy is licensed under the MIT license and free for commercial, academic, and private use.
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.