geometric_kernels.lab_extras

Custom extensions for LAB.

Package Contents

geometric_kernels.lab_extras.bool_like(reference)[source]

Return the type of the reference if it is of boolean type. Otherwise return bool dtype of a backend based on the reference.

Parameters:

reference (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.complex_conj(x)[source]

Return complex conjugate.

Parameters:

x (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.complex_like(reference)[source]

Return complex dtype of a backend based on the reference.

Parameters:

reference (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.cosh(x)[source]

Compute hyperbolic cosine using the formula

\[\textrm{cosh}(x) = \frac{\exp(x) + \exp(-x)}{2}.\]
Parameters:

x (lab.Numeric) – Array of any backend.

Return type:

lab.Numeric

geometric_kernels.lab_extras.count_nonzero(x, axis=None)[source]

Count non-zero elements in an array.

Parameters:

x (lab.Numeric) – Array of any backend and of any shape.

geometric_kernels.lab_extras.create_complex(real, imag)[source]

Return a complex number with the given real and imaginary parts.

Parameters:
  • real (lab.Numeric) – Array of any backend, real part of the complex number.

  • imag (lab.Numeric) – Array of any backend, imaginary part of the complex number.

geometric_kernels.lab_extras.cumsum(a, axis=None)[source]

Return cumulative sum (optionally along axis).

Parameters:
  • a (lab.Numeric) – Array of any backend.

  • axis – As in numpy.cumsum.

geometric_kernels.lab_extras.degree(a)[source]

Given an adjacency matrix a, return a diagonal matrix with the col-sums of a as main diagonal - this is the degree matrix representing the number of nodes each node is connected to.

Parameters:

a – Array of any backend or scipy.sparse array.

geometric_kernels.lab_extras.dtype_bool(reference)[source]

Return bool dtype of a backend based on the reference.

Parameters:

reference (lab.RandomState) – A random state to infer the backend from.

geometric_kernels.lab_extras.dtype_double(reference)[source]

Return double dtype of a backend based on the reference.

Parameters:

reference (lab.RandomState) – A random state to infer the backend from.

geometric_kernels.lab_extras.dtype_integer(reference)[source]

Return int dtype of a backend based on the reference.

Parameters:

reference (lab.RandomState) – A random state to infer the backend from.

geometric_kernels.lab_extras.eigenpairs(L, k)[source]

Obtain the eigenpairs that correspond to the k lowest eigenvalues of a symmetric positive semi-definite matrix L.

Parameters:
  • a – Array of any backend or scipy.sparse array.

  • k (int) – The number of eigenpairs to compute.

geometric_kernels.lab_extras.eigvalsh(x)[source]

Compute the eigenvalues of a Hermitian or real symmetric matrix x.

Parameters:

x (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.float_like(reference)[source]

Return the type of the reference if it is a floating point type. Otherwise return double dtype of a backend based on the reference.

Parameters:

reference (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.from_numpy(_, b)[source]

Converts the array b to a tensor of the same backend as _.

Parameters:
  • _ (lab.Numeric) – Array of any backend used to determine the backend.

  • b (plum.Union[beartype.typing.List, lab.Numeric]) – Array of any backend or list to be converted to the backend of _.

geometric_kernels.lab_extras.get_random_state(key)[source]

Return the random state of a random generator.

Parameters:

key (lab.RandomState) – The random generator.

geometric_kernels.lab_extras.int_like(reference)[source]

Return the type of the reference if it is integer type. Otherwise return int32 dtype of a backend based on the reference.

Parameters:

reference (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.is_complex(reference)[source]

Return True if reference of complex dtype.

Parameters:

reference (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.logical_xor(x1, x2)[source]

Return logical XOR of two arrays.

Parameters:
  • x1 (lab.Bool) – Array of any backend.

  • x2 (lab.Bool) – Array of any backend.

geometric_kernels.lab_extras.logspace(start, stop, num=50)[source]

Return numbers spaced evenly on a log scale.

Parameters:
  • start (lab.Numeric) – Array of any backend, as in numpy.logspace.

  • stop (lab.Numeric) – Array of any backend, as in numpy.logspace.

  • num (int) – As in numpy.logspace.

geometric_kernels.lab_extras.qr(x, mode='reduced')[source]

Return a QR decomposition of a matrix x.

Parameters:
  • x (lab.Numeric) – Array of any backend.

  • mode – As in numpy.linalg.qr.

geometric_kernels.lab_extras.reciprocal_no_nan(x)[source]

Return element-wise reciprocal (1/x). Whenever x = 0 puts 1/x = 0.

Parameters:

x (plum.Union[lab.Numeric, scipy.sparse.spmatrix]) – Array of any backend or scipy.sparse.spmatrix.

geometric_kernels.lab_extras.restore_random_state(key, state)[source]

Set the random state of a random generator. Return the new random generator with state state.

Parameters:
  • key (lab.RandomState) – The random generator.

  • state – The new random state of the random generator.

geometric_kernels.lab_extras.set_value(a, index, value)[source]

Set a[index] = value. This operation is not done in place and a new array is returned.

Parameters:
  • a – Array of any backend or scipy.sparse array.

  • index (int) – The index.

  • value (float) – The value to set at the given index.

geometric_kernels.lab_extras.sinh(x)[source]

Compute hyperbolic sine using the formula

\[\textrm{sinh}(x) = \frac{\exp(x) - \exp(-x)}{2}.\]
Parameters:

x (lab.Numeric) – Array of any backend.

Return type:

lab.Numeric

geometric_kernels.lab_extras.slogdet(x)[source]

Return the sign and log-determinant of a matrix x.

Parameters:

x (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.smart_cast(dtype, x)[source]

Return x cast to the dtype abstract data type.

Parameters:
  • dtype (plum.Union[lab.Bool, lab.Int, lab.Float, lab.Complex, lab.Numeric]) – An abstract DType of lab, one of B.Bool, B.Int, B.Float, B.Complex, B.Numeric.

  • x (lab.Numeric) – Array of any backend.

geometric_kernels.lab_extras.take_along_axis(a, index, axis=0)[source]

Gathers elements of a along axis at index locations.

Parameters:
  • a (lab.Numeric) – Array of any backend, as in numpy.take_along_axis.

  • index (lab.Numeric) – Array of any backend, as in numpy.take_along_axis.

  • axis (int) – As in numpy.take_along_axis.

geometric_kernels.lab_extras.trapz(y, x, dx=1.0, axis=-1)[source]

Integrate along the given axis using the trapezoidal rule.

Parameters:
  • y (lab.Numeric) – Array of any backend, as in numpy.trapz.

  • x (lab.Numeric) – Array of any backend, as in numpy.trapz.

  • dx (lab.Numeric) – Array of any backend, as in numpy.trapz.

  • axis (int) – As in numpy.trapz.