NumPy multiply()
The numpy.multiply()
function performs element-wise multiplication of two input arrays.
If the input arrays have different shapes, they must be broadcastable to a common shape.
Syntax
</>
Copy
numpy.multiply(x1, x2, /, out=None, *, where=True, casting='same_kind', order='K', dtype=None, subok=True)
Parameters
Parameter | Type | Description |
---|---|---|
x1, x2 | array_like | Input arrays to be multiplied. If they have different shapes, they must be broadcastable. |
out | ndarray, None, or tuple of ndarray and None, optional | Optional output array to store the result. If None, a new array is created. |
where | array_like, optional | Boolean mask specifying where to apply the multiplication. Elements where where=False retain their original value. |
casting | str, optional | Defines the casting behavior when performing the multiplication. |
order | str, optional | Memory layout order of the output array. |
dtype | data-type, optional | Specifies the data type of the output array. |
subok | bool, optional | Determines if subclasses of ndarray are preserved in the output. |
Return Value
Returns an array with the element-wise product of x1
and x2
. If both inputs are scalars, a scalar is returned.
Examples
1. Multiplying Two Arrays Element-wise
In this example, we perform element-wise multiplication on two arrays of the same shape.
</>
Copy
import numpy as np
# Define two arrays of the same shape
x1 = np.array([1, 2, 3, 4])
x2 = np.array([5, 6, 7, 8])
# Perform element-wise multiplication
result = np.multiply(x1, x2)
# Print the result
print("Element-wise multiplication result:", result)
Output:
Element-wise multiplication result: [ 5 12 21 32]
data:image/s3,"s3://crabby-images/71784/7178490fe35fc4ec93de01458c9cdfc2e960fd70" alt=""
2. Multiplying Arrays with Broadcasting
When the input arrays have different shapes, broadcasting is applied.
</>
Copy
import numpy as np
# Define an array with shape (3,)
x1 = np.array([1, 2, 3])
# Define a scalar (broadcasted to match x1's shape)
x2 = 10
# Perform element-wise multiplication
result = np.multiply(x1, x2)
# Print the result
print("Broadcasted multiplication result:", result)
Output:
Broadcasted multiplication result: [10 20 30]
data:image/s3,"s3://crabby-images/b82c0/b82c0425d6e559aeaa3df6fd287557c36467bef9" alt=""
3. Using the out
Parameter
Storing the result in a preallocated output array instead of creating a new one.
</>
Copy
import numpy as np
# Define two arrays
x1 = np.array([2, 4, 6])
x2 = np.array([3, 3, 3])
# Create an output array with the same shape
output_array = np.empty_like(x1)
# Perform multiplication and store result in output_array
np.multiply(x1, x2, out=output_array)
# Print the result
print("Stored result in output array:", output_array)
Output:
Stored result in output array: [ 6 12 18]
data:image/s3,"s3://crabby-images/cba46/cba46c4f45ba0c420acba80101ff0ef6e0695228" alt=""
4. Using the where
Parameter
The where
parameter allows conditional multiplication.
</>
Copy
import numpy as np
# Define two arrays
x1 = np.array([2, 4, 6, 8])
x2 = np.array([1, 2, 3, 4])
# Define a mask (multiply only where mask is True)
mask = np.array([True, False, True, False])
# Perform multiplication with condition
result = np.multiply(x1, x2, where=mask)
# Print the result
print("Conditional multiplication result:", result)
Output:
Conditional multiplication result: [ 2 0 18 0]
data:image/s3,"s3://crabby-images/a797a/a797a8d6f197dbff68c7bba186e6e49b62c8be4f" alt=""
Only the elements where mask=True
are multiplied. The other values remain unchanged.