numpy.ufunc.at — NumPy v2.3.dev0 Manual (original) (raw)

method

ufunc.at(a, indices, b=None, /)#

Performs unbuffered in place operation on operand ‘a’ for elements specified by ‘indices’. For addition ufunc, this method is equivalent toa[indices] += b, except that results are accumulated for elements that are indexed more than once. For example, a[[0,0]] += 1 will only increment the first element once because of buffering, whereasadd.at(a, [0,0], 1) will increment the first element twice.

Parameters:

aarray_like

The array to perform in place operation on.

indicesarray_like or tuple

Array like index object or slice object for indexing into first operand. If first operand has multiple dimensions, indices can be a tuple of array like index objects or slice objects.

barray_like

Second operand for ufuncs requiring two operands. Operand must be broadcastable over first operand after indexing or slicing.

Examples

Set items 0 and 1 to their negative values:

import numpy as np a = np.array([1, 2, 3, 4]) np.negative.at(a, [0, 1]) a array([-1, -2, 3, 4])

Increment items 0 and 1, and increment item 2 twice:

a = np.array([1, 2, 3, 4]) np.add.at(a, [0, 1, 2, 2], 1) a array([2, 3, 5, 4])

Add items 0 and 1 in first array to second array, and store results in first array:

a = np.array([1, 2, 3, 4]) b = np.array([1, 2]) np.add.at(a, [0, 1], b) a array([2, 4, 3, 4])