numpy.testing.assert_array_equal#

testing.assert_array_equal(actual, desired, err_msg='', verbose=True, *, strict=False)[source]#

如果两个类数组(array_like)对象不相等,则会引发 AssertionError。

给定两个类数组(array_like)对象,检查它们的形状和所有元素是否相等(但请参阅“备注”中对标量的特殊处理)。如果形状不匹配或值冲突,则会引发异常。与 NumPy 中的标准用法不同,NaN 被当作数字进行比较,如果两个对象在相同位置都有 NaN,则不会引发断言。

建议对浮点数进行相等性验证时,保持通常的谨慎。

备注

actualdesired 已经是 numpy.ndarray 的实例,且 desired 不是 dict 时,assert_equal(actual, desired) 的行为与此函数的行为相同。否则,此函数在比较前会对输入执行 np.asanyarray,而 assert_equal 为常见的 Python 类型定义了特殊的比较规则。例如,只有 assert_equal 可以用于比较嵌套的 Python 列表。在新代码中,如果需要 assert_array_equal 的行为,请考虑仅使用 assert_equal,并显式地将 actualdesired 转换为数组。

参数:
actual类数组(array_like)

要检查的实际对象。

desired类数组(array_like)

期望的对象。

err_msg字符串, 可选

失败时要打印的错误消息。

verbose布尔值, 可选

如果为 True,则冲突的值会附加到错误消息中。

strict布尔值, 可选

如果为 True,当类数组(array_like)对象的形状或数据类型不匹配时,会引发 AssertionError。在“备注”部分中提到的对标量的特殊处理将被禁用。

1.24.0 版中新增。

引发:
AssertionError

如果实际对象和期望对象不相等。

另请参阅

assert_allclose

比较两个类数组(array_like)对象,以达到期望的相对和/或绝对精度相等。

assert_array_almost_equal_nulp, assert_array_max_ulp, assert_equal

备注

actualdesired 中的一个为标量而另一个为类数组(array_like)时,函数会检查类数组对象中的每个元素是否与该标量相等。此行为可以通过 strict 参数禁用。

示例

第一次断言不会引发异常

>>> np.testing.assert_array_equal([1.0,2.33333,np.nan],
...                               [np.exp(0),2.33333, np.nan])

浮点数存在数值不精确性时断言失败

>>> np.testing.assert_array_equal([1.0,np.pi,np.nan],
...                               [1, np.sqrt(np.pi)**2, np.nan])
Traceback (most recent call last):
    ...
AssertionError:
Arrays are not equal

Mismatched elements: 1 / 3 (33.3%)
Max absolute difference among violations: 4.4408921e-16
Max relative difference among violations: 1.41357986e-16
 ACTUAL: array([1.      , 3.141593,      nan])
 DESIRED: array([1.      , 3.141593,      nan])

对于这些情况,请改用 assert_allclose 或其中一个 nulp(浮点值数量)函数。

>>> np.testing.assert_allclose([1.0,np.pi,np.nan],
...                            [1, np.sqrt(np.pi)**2, np.nan],
...                            rtol=1e-10, atol=0)

如“备注”部分所述,assert_array_equal 对标量有特殊处理。这里测试检查 x 中的每个值是否为 3。

>>> x = np.full((2, 5), fill_value=3)
>>> np.testing.assert_array_equal(x, 3)

当比较标量和数组时,使用 strict 参数来引发 AssertionError。

>>> np.testing.assert_array_equal(x, 3, strict=True)
Traceback (most recent call last):
    ...
AssertionError:
Arrays are not equal

(shapes (2, 5), () mismatch)
 ACTUAL: array([[3, 3, 3, 3, 3],
       [3, 3, 3, 3, 3]])
 DESIRED: array(3)

strict 参数还确保数组数据类型匹配。

>>> x = np.array([2, 2, 2])
>>> y = np.array([2., 2., 2.], dtype=np.float32)
>>> np.testing.assert_array_equal(x, y, strict=True)
Traceback (most recent call last):
    ...
AssertionError:
Arrays are not equal

(dtypes int64, float32 mismatch)
 ACTUAL: array([2, 2, 2])
 DESIRED: array([2., 2., 2.], dtype=float32)