numpy.testing.assert_approx_equal#

testing.assert_approx_equal(actual, desired, significant=7, err_msg='', verbose=True)[源代码]#

如果两个项不等于指定有效位数,则引发 AssertionError。

注意

建议使用 assert_allcloseassert_array_almost_equal_nulpassert_array_max_ulp 中的一个,而不是此函数,以实现更一致的浮点数比较。

给定两个数字,检查它们是否近似相等。近似相等定义为匹配的有效数字的数量。

参数:
actual标量

要检查的对象。

desired标量

期望的对象。

significantint, 可选

所需的精度,默认为 7。

err_msgstr, optional

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

verbosebool, optional

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

引发:
AssertionError

如果 actual 和 desired 在指定精度内不相等。

另请参阅

assert_allclose

以期望的相对和/或绝对精度比较两个 array_like 对象是否相等。

assert_array_almost_equal_nulp, assert_array_max_ulp, assert_equal

示例

>>> np.testing.assert_approx_equal(0.12345677777777e-20, 0.1234567e-20)
>>> np.testing.assert_approx_equal(0.12345670e-20, 0.12345671e-20,
...                                significant=8)
>>> np.testing.assert_approx_equal(0.12345670e-20, 0.12345672e-20,
...                                significant=8)
Traceback (most recent call last):
    ...
AssertionError:
Items are not equal to 8 significant digits:
 ACTUAL: 1.234567e-21
 DESIRED: 1.2345672e-21

求值的条件引发异常是

>>> abs(0.12345670e-20/1e-21 - 0.12345672e-20/1e-21) >= 10**-(8-1)
True