2017-10-04 21:00:05 +11:00
|
|
|
# Tests domain errors in special math functions
|
|
|
|
|
|
|
|
try:
|
|
|
|
import math
|
2021-03-15 19:27:36 +05:30
|
|
|
|
2017-10-04 21:00:05 +11:00
|
|
|
math.erf
|
|
|
|
except (ImportError, AttributeError):
|
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
inf = float("inf")
|
|
|
|
nan = float("nan")
|
2017-10-04 21:00:05 +11:00
|
|
|
|
|
|
|
# single argument functions
|
|
|
|
for name, f, args in (
|
2021-03-15 19:27:36 +05:30
|
|
|
("expm1", math.exp, ()),
|
|
|
|
("log2", math.log2, (-1, 0)),
|
|
|
|
("log10", math.log10, (-1, 0)),
|
|
|
|
("sinh", math.sinh, ()),
|
|
|
|
("cosh", math.cosh, ()),
|
|
|
|
("tanh", math.tanh, ()),
|
|
|
|
("asinh", math.asinh, ()),
|
|
|
|
("acosh", math.acosh, (-1, 0.9, 1)),
|
|
|
|
("atanh", math.atanh, (-1, 1)),
|
|
|
|
("erf", math.erf, ()),
|
|
|
|
("erfc", math.erfc, ()),
|
|
|
|
("gamma", math.gamma, (-2, -1, 0, 1)),
|
|
|
|
("lgamma", math.lgamma, (-2, -1, 0, 1)),
|
|
|
|
):
|
2017-10-04 21:00:05 +11:00
|
|
|
for x in args + (inf, nan):
|
|
|
|
try:
|
|
|
|
ans = f(x)
|
2021-03-15 19:27:36 +05:30
|
|
|
print("%.4f" % ans)
|
2017-10-04 21:00:05 +11:00
|
|
|
except ValueError:
|
2021-03-15 19:27:36 +05:30
|
|
|
print(name, "ValueError")
|
2017-10-04 21:00:05 +11:00
|
|
|
except OverflowError:
|
2021-03-15 19:27:36 +05:30
|
|
|
print(name, "OverflowError")
|