| # Tests the functions imported from math |
| |
| try: |
| from math import * |
| except ImportError: |
| print("SKIP") |
| import sys |
| sys.exit() |
| |
| test_values = [-100., -1.23456, -1, -0.5, 0.0, 0.5, 1.23456, 100.] |
| p_test_values = [0.1, 0.5, 1.23456] |
| unit_range_test_values = [-1., -0.75, -0.5, -0.25, 0., 0.25, 0.5, 0.75, 1.] |
| |
| functions = [('sqrt', sqrt, p_test_values), |
| ('exp', exp, test_values), |
| ('expm1', expm1, test_values), |
| ('log', log, p_test_values), |
| ('log2', log2, p_test_values), |
| ('log10', log10, p_test_values), |
| ('cosh', cosh, test_values), |
| ('sinh', sinh, test_values), |
| ('tanh', tanh, test_values), |
| ('acosh', acosh, [1.0, 5.0, 1.0]), |
| ('asinh', asinh, test_values), |
| ('atanh', atanh, [-0.99, -0.5, 0.0, 0.5, 0.99]), |
| ('cos', cos, test_values), |
| ('sin', sin, test_values), |
| ('tan', tan, test_values), |
| ('acos', acos, unit_range_test_values), |
| ('asin', asin, unit_range_test_values), |
| ('atan', atan, test_values), |
| ('ceil', ceil, test_values), |
| ('fabs', fabs, test_values), |
| ('floor', floor, test_values), |
| #('frexp', frexp, test_values), |
| ('trunc', trunc, test_values) |
| ] |
| |
| for function_name, function, test_vals in functions: |
| print(function_name) |
| for value in test_vals: |
| print("{:.7g}".format(function(value))) |
| |
| binary_functions = [('copysign', copysign, [(23., 42.), (-23., 42.), (23., -42.), |
| (-23., -42.), (1., 0.0), (1., -0.0)]) |
| ] |
| |
| for function_name, function, test_vals in binary_functions: |
| print(function_name) |
| for value1, value2 in test_vals: |
| print("{:.7g}".format(function(value1, value2))) |