Skip to main content

Numpy arrays with labeled axes, similar to xarray but with support for uncertainties

Project description

named-arrays

tests codecov Ruff Documentation Status PyPI version

named-arrays is an implementation of a named tensor, which assigns names to each axis of an n-dimensional array such as a numpy array.

When using a Numpy n-dimensional array, the programmer must manually keep track of the physical meaning of each axis in the array. Furthermore, it is often necessary to insert singleton dimensions at the end of the array to allow it to broadcastable against other arrays. Named tensors solve this problem by giving each axis a name, which allows for automatic axis alignment without the need for inserting extra dimensions. named-arrays provides a very unapologetic implementation of a named tensor, since axes can only be accessed using their names, unlike xarray which allows for both name and index.

Features

Installation

named-arrays is available on PyPi and can be installed using pip

pip install named-arrays

Examples

ScalarArray

The fundamental type of named-arrays is the ScalarArray, which is a composition of a numpy ndarray-like object and a tuple of axis names which must have the same length as the number of dimensions in the array.

import numpy as np
import named_arrays as na

a = na.ScalarArray(np.array([1, 2, 3]), axes=('x',))

If we create another array with a different axis name, it will be broadcasted automatically against the first array if we add them together

b = na.ScalarArray(np.array([4, 5]), axes=('y',))
c = a + b
c
ScalarArray(
    ndarray=[[5, 6],
             [6, 7],
             [7, 8]],
    axes=('x', 'y'),
)

All the usual numpy reduction operations use the axis name instead of the axis index

c.mean('x')
ScalarArray(
    ndarray=[6., 7.],
    axes=('y',),
)

To index the array we can use a dictionary with the axis names as the keys

c[dict(x=0)]
ScalarArray(
    ndarray=[5, 6],
    axes=('y',),
)

ScalarLinearSpace

We recommend that you rarely directly create instances of ScalarArray directly. Instead, you can use the implicit array classes: ScalarLinearSpace, ScalarLogarithmicSpace, and ScalarGeometricSpace to create arrays in a similar fashion to numpy.linspace(), numpy.logspace(), and numpy.geomspace() with the advantage of being able to access the inputs to these functions at a later point.

d = na.ScalarLinearSpace(0, 1, axis='z', num=4)
d
ScalarLinearSpace(start=0, stop=1, axis='z', num=4, endpoint=True)

Thses implicit array classes work just like ScalarArray and can be used with any of the usual array operations.

a + d
ScalarArray(
    ndarray=[[1.        , 1.33333333, 1.66666667, 2.        ],
             [2.        , 2.33333333, 2.66666667, 3.        ],
             [3.        , 3.33333333, 3.66666667, 4.        ]],
    axes=('x', 'z'),
)

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

named_arrays-1.4.0.tar.gz (237.4 kB view details)

Uploaded Source

Built Distribution

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

named_arrays-1.4.0-py3-none-any.whl (243.9 kB view details)

Uploaded Python 3

File details

Details for the file named_arrays-1.4.0.tar.gz.

File metadata

  • Download URL: named_arrays-1.4.0.tar.gz
  • Upload date:
  • Size: 237.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for named_arrays-1.4.0.tar.gz
Algorithm Hash digest
SHA256 354d6a76a22cfc0979ec8b821dd059823a19d5d2a8a8df508a9197d1886fe683
MD5 0d2792b859c6bd2cce263d857f96c0f1
BLAKE2b-256 1e839e473a3a42694e78e4209b126a11ecc35d2df3e5fc7f40e94be7e83b8f80

See more details on using hashes here.

File details

Details for the file named_arrays-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: named_arrays-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 243.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for named_arrays-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5b78e84d463830ceea0d396bcd90f68c71bdc99bee100835aa394ce5ac9eacd4
MD5 a600bd49b500fabf4e979b728dc5bea8
BLAKE2b-256 ebf7a9952dff509c74aa00182c9ca58a186b7c3d3dcf7adeb8f99f26a4c33d1d

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