equal

equal(x1: array | int | float | complex | bool, x2: array | int | float | complex | bool, /) array

Computes the truth value of x1_i == x2_i for each element x1_i of the input array x1 with the respective element x2_i of the input array x2.

Parameters:
  • x1 (Union[array, int, float, complex, bool]) – first input array. May have any data type.

  • x2 (Union[array, int, float, complex, bool]) – second input array. Must be compatible with x1 (see Broadcasting). May have any data type.

Returns:

out (array) – an array containing the element-wise results. The returned array must have a data type of bool.

Notes

  • At least one of x1 or x2 must be an array.

Special Cases

For real-valued floating-point operands,

  • If x1_i is NaN or x2_i is NaN, the result is False.

  • If x1_i is +infinity and x2_i is +infinity, the result is True.

  • If x1_i is -infinity and x2_i is -infinity, the result is True.

  • If x1_i is -0 and x2_i is either +0 or -0, the result is True.

  • If x1_i is +0 and x2_i is either +0 or -0, the result is True.

  • If x1_i is a finite number, x2_i is a finite number, and x1_i equals x2_i, the result is True.

  • In the remaining cases, the result is False.

For complex floating-point operands, let a = real(x1_i), b = imag(x1_i), c = real(x2_i), d = imag(x2_i), and

  • If a, b, c, or d is NaN, the result is False.

  • In the remaining cases, the result is the logical AND of the equality comparison between the real values a and c (real components) and between the real values b and d (imaginary components), as described above for real-valued floating-point operands (i.e., a == c AND b == d).

Note

For discussion of complex number equality, see Complex Numbers.

Note

Comparison of arrays without a corresponding promotable data type (see Type Promotion Rules) is undefined and thus implementation-dependent.

Changed in version 2022.12: Added complex data type support.