NumPy fmod()
The numpy.fmod()
function computes the element-wise remainder of division. Unlike the Python modulus operator (%
),
the remainder retains the same sign as the dividend (x1
).
Syntax
</>
Copy
numpy.fmod(x1, x2, /, out=None, *, where=True, casting='same_kind', order='K', dtype=None, subok=True)
Parameters
Parameter | Type | Description |
---|---|---|
x1 | array_like | Dividend (numerator). |
x2 | array_like | Divisor (denominator). Must be broadcastable with x1 to a common shape. |
out | ndarray, None, or tuple of ndarray and None, optional | Optional output array where the result is stored. If None, a new array is created. |
where | array_like, optional | Boolean mask specifying which elements to compute. Elements where where=False retain their original value. |
casting | str, optional | Defines the casting behavior when computing the remainder. |
order | str, optional | Memory layout order of the output array. |
dtype | data-type, optional | Defines 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 remainder of the division of x1
by x2
. If both inputs are scalars, a scalar is returned.
Examples
1. Computing the Remainder of Two Scalars
Computing the remainder of two numbers using numpy.fmod()
.
</>
Copy
import numpy as np
# Define dividend and divisor
x1 = 7
x2 = 3
# Compute the remainder using numpy.fmod()
result = np.fmod(x1, x2)
# Print the result
print("Remainder of 7 / 3:", result)
Output:
Remainder of 7 / 3: 1
data:image/s3,"s3://crabby-images/1c1a3/1c1a3a26b94844b75255232d4719461a9bb3a5d5" alt=""
2. Computing fmod for an Array
Using numpy.fmod()
to compute the remainder for an array of values.
</>
Copy
import numpy as np
# Define an array of dividends
x1 = np.array([7, 8, 9, 10])
# Define an array of divisors
x2 = np.array([3, 2, 4, 5])
# Compute element-wise remainder
result = np.fmod(x1, x2)
# Print the results
print("Dividends:", x1)
print("Divisors:", x2)
print("Remainders:", result)
Output:
Dividends: [ 7 8 9 10]
Divisors: [3 2 4 5]
Remainders: [1 0 1 0]
data:image/s3,"s3://crabby-images/cef70/cef70196d12504a28e95e7e7f699f51758fe4a0f" alt=""
3. Using the out
Parameter
Using an output array to store results instead of creating a new array.
</>
Copy
import numpy as np
# Define an array of dividends
x1 = np.array([10, 15, 20])
# Define an array of divisors
x2 = np.array([4, 6, 7])
# Create an output array with the same shape
output_array = np.empty_like(x1)
# Compute remainder and store in output_array
np.fmod(x1, x2, out=output_array)
# Print the results
print("Computed remainders:", output_array)
Output:
Computed remainders: [2 3 6]
data:image/s3,"s3://crabby-images/5fa76/5fa766cef03f9ff43369c3d3fd1a2b5a532361fb" alt=""
4. Using the where
Parameter
Using a condition to compute the remainder only for selected elements.
</>
Copy
import numpy as np
# Define an array of dividends
x1 = np.array([9, 10, 11, 12])
# Define an array of divisors
x2 = np.array([4, 5, 3, 6])
# Define a mask (compute remainder only where mask is True)
mask = np.array([True, False, True, False])
# Compute remainders where mask is True
result = np.fmod(x1, x2, where=mask)
# Print the results
print("Computed remainders with mask:", result)
Output:
Computed remainders with mask: [1 0 2 0]
data:image/s3,"s3://crabby-images/11a6a/11a6a00d1c5847766a4fc599bcc81625d8732147" alt=""
The remainder is computed only for elements where mask=True
.