170 lines
5.7 KiB
Python
Raw Normal View History

2020-05-14 15:57:35 -07:00
"""Manipulate numeric data similar to numpy
2020-02-04 10:24:37 -06:00
`ulab` is a numpy-like module for micropython, meant to simplify and
speed up common mathematical operations on arrays. The primary goal was to
implement a small subset of numpy that might be useful in the context of a
microcontroller. This means low-level data processing of linear (array) and
two-dimensional (matrix) data.
`ulab` is adapted from micropython-ulab, and the original project's
documentation can be found at
https://micropython-ulab.readthedocs.io/en/latest/
`ulab` is modeled after numpy, and aims to be a compatible subset where
possible. Numpy's documentation can be found at
2020-05-14 15:57:35 -07:00
https://docs.scipy.org/doc/numpy/index.html"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
class array:
"""1- and 2- dimensional array"""
def __init__(self, values, *, dtype=float):
""":param sequence values: Sequence giving the initial content of the array.
:param dtype: The type of array values, ``int8``, ``uint8``, ``int16``, ``uint16``, or ``float``
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
The `values` sequence can either be another ~ulab.array, sequence of numbers
(in which case a 1-dimensional array is created), or a sequence where each
subsequence has the same length (in which case a 2-dimensional array is
created).
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
Passing a ~ulab.array and a different dtype can be used to convert an array
from one dtype to another.
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
In many cases, it is more convenient to create an array from a function
like `zeros` or `linspace`.
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
`ulab.array` implements the buffer protocol, so it can be used in many
places an `array.array` can be used."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
shape: tuple = ...
"""The size of the array, a tuple of length 1 or 2"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
size: int = ...
"""The number of elements in the array"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
itemsize: int = ...
"""The number of elements in the array"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def flatten(self, *, order='C'):
""":param order: Whether to flatten by rows ('C') or columns ('F')
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
Returns a new `ulab.array` object which is always 1 dimensional.
If order is 'C' (the default", then the data is ordered in rows;
If it is 'F', then the data is ordered in columns. "C" and "F" refer
to the typical storage organization of the C and Fortran languages."""
...
2020-04-13 20:10:02 -05:00
2020-05-14 15:57:35 -07:00
def sort(self, *, axis=1):
""":param axis: Whether to sort elements within rows (0), columns (1), or elements (None)"""
...
2020-04-13 20:10:02 -05:00
2020-05-14 15:57:35 -07:00
def transpose(self):
"""Swap the rows and columns of a 2-dimensional array"""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __add__(self):
"""Adds corresponding elements of the two arrays, or adds a number to all
elements of the array. If both arguments are arrays, their sizes must match."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __sub__(self):
"""Subtracts corresponding elements of the two arrays, or adds a number to all
elements of the array. If both arguments are arrays, their sizes must match."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __mul__(self):
"""Multiplies corresponding elements of the two arrays, or multiplies
all elements of the array by a number. If both arguments are arrays,
their sizes must match."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __div__(self):
"""Multiplies corresponding elements of the two arrays, or divides
all elements of the array by a number. If both arguments are arrays,
their sizes must match."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __pow__():
"""Computes the power (x**y) of corresponding elements of the the two arrays,
or one number and one array. If both arguments are arrays, their sizes
must match."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __getitem__():
"""Retrieve an element of the array."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def __setitem__():
"""Set an element of the array."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
int8 = ...
"""Type code for signed integers in the range -128 .. 127 inclusive, like the 'b' typecode of `array.array`"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
int16 = ...
"""Type code for signed integers in the range -32768 .. 32767 inclusive, like the 'h' typecode of `array.array`"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
float = ...
"""Type code for floating point values, like the 'f' typecode of `array.array`"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
uint8 = ...
"""Type code for unsigned integers in the range 0 .. 255 inclusive, like the 'H' typecode of `array.array`"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
uint16 = ...
"""Type code for unsigned integers in the range 0 .. 65535 inclusive, like the 'h' typecode of `array.array`"""
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def ones(shape, *, dtype=float):
"""
.. param: shape
Shape of the array, either an integer (for a 1-D array) or a tuple of 2 integers (for a 2-D array)
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
.. param: dtype
Type of values in the array
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
Return a new array of the given shape with all elements set to 1."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def zeros(shape, *, dtype):
"""
.. param: shape
Shape of the array, either an integer (for a 1-D array) or a tuple of 2 integers (for a 2-D array)
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
.. param: dtype
Type of values in the array
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
Return a new array of the given shape with all elements set to 0."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def eye(size, *, dtype=float):
"""Return a new square array of size, with the diagonal elements set to 1
and the other elements set to 0."""
...
2020-02-04 10:24:37 -06:00
2020-05-14 15:57:35 -07:00
def linspace(start, stop, *, dtype=float, num=50, endpoint=True):
"""
.. param: start
2020-02-27 14:14:05 -06:00
First value in the array
2020-05-14 15:57:35 -07:00
.. param: stop
2020-02-27 14:14:05 -06:00
Final value in the array
2020-05-14 15:57:35 -07:00
.. param int: num
2020-02-27 14:14:05 -06:00
Count of values in the array
2020-05-14 15:57:35 -07:00
.. param: dtype
2020-02-27 14:14:05 -06:00
Type of values in the array
2020-05-14 15:57:35 -07:00
.. param bool: endpoint
2020-02-27 14:14:05 -06:00
Whether the ``stop`` value is included. Note that even when
endpoint=True, the exact ``stop`` value may not be included due to the
inaccuracy of floating point arithmetic.
2020-05-14 15:57:35 -07:00
Return a new 1-D array with ``num`` elements ranging from ``start`` to ``stop`` linearly."""
...