NumPy: Find rows of a given array of shape that contain elements of each row of another given array of shape
Find rows containing elements of another array.
Write a NumPy program to find rows of a given array of shape (8,3) that contain elements of each row of another given array of shape (2,2).
Sample Solution:
Python Code:
# Importing the NumPy library
import numpy as np
# Generating two NumPy arrays 'nums1' and 'nums2' filled with random integers from 0 to 5
nums1 = np.random.randint(0, 6, (6, 4))
nums2 = np.random.randint(0, 6, (2, 3))
# Displaying the original arrays 'nums1' and 'nums2'
print("Original arrays:")
print(nums1)
print("\n", nums2)
# Comparing elements of 'nums1' with elements of 'nums2' using broadcasting
temp = (nums1[..., np.newaxis, np.newaxis] == nums2)
# Counting the number of occurrences of elements from 'nums2' within each row of 'nums1'
# Checking if the count is greater than or equal to the number of elements in 'nums2' rows
# Obtaining rows from 'nums1' that contain elements of each row of 'nums2'
rows = (temp.sum(axis=(1, 2, 3)) >= nums2.shape[1]).nonzero()[0]
# Displaying rows of 'nums1' that contain elements of each row of 'nums2'
print("\nRows of a given array that contain elements of each row of another given array:")
print(rows) 
Sample Output:
Original arrays: [[5 2 5 1] [5 4 1 3] [0 1 1 1] [2 0 4 0] [2 5 1 5] [4 0 4 0]] [[2 3 1] [1 1 4]] Rows of a given array that contain elements of each row of another given array: [0 1 2 4]
Explanation:
In the above exercise -
np.random.randint(0, 6, (6, 4)): Generates a 2D NumPy array nums1 with shape (6, 4) and random integers in the range of [0, 6).
np.random.randint(0, 6, (2, 3)): Generates a 2D NumPy array nums2 with shape (2, 3) and random integers in the range of [0, 6).
temp = (nums1[..., np.newaxis, np.newaxis] == nums2)
In the above code -
- nums1[..., np.newaxis, np.newaxis]: Adds two new axes at the end of nums1, resulting in a 4D array of shape (6, 4, 1, 1).
- nums1[..., np.newaxis, np.newaxis] == nums2: Compares nums1 and nums2 element-wise with broadcasting, resulting in a 4D boolean array of shape (6, 4, 2, 3).
rows = (temp.sum(axis=(1,2,3)) >= nums2.shape[1]).nonzero()[0]
In the above code –
- temp.sum(axis=(1, 2, 3)): Sums the boolean array temp along axes 1, 2, and 3, resulting in a 1D array with the count of matching elements for each row of nums1.
- (temp.sum(axis=(1, 2, 3)) >= nums2.shape[1]): Compares the count of matching elements for each row of nums1 to the number of columns in nums2. The result is a 1D boolean array of shape (6,).
- (temp.sum(axis=(1, 2, 3)) >= nums2.shape[1]).nonzero()[0]: Retrieves the indices of True values in the 1D boolean array, indicating the rows in nums1 that have at least as many occurrences of each element in nums2 along the rows.
print(rows): Finally print() function prints the row indices in nums1 that meet the specified condition.
For more Practice: Solve these Related Problems:
- Write a NumPy program to search for rows in a 2D array that contain all elements of a given 1D array using np.isin.
- Create a function that returns the indices of rows that have at least one match with each element of a smaller array.
- Implement a solution that uses boolean masks to compare each row with the target sub-array and filters accordingly.
- Test the function on a matrix with varying row patterns to ensure that only qualifying rows are returned.
Go to:
PREV : Extract rows with unequal values.
NEXT :  Create a record array from a regular array.
Python-Numpy Code Editor:
Have another way to solve this solution? Contribute your code (and comments) through Disqus.What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
