1
0

02_float.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # test == != >= <= < >
  2. assert 1.0 == 1.0
  3. assert 1.0 != 1.1
  4. assert 1.0 >= 1.0
  5. assert 1.0 <= 1.0
  6. assert 1.0 < 1.1
  7. assert 1.1 > 1.0
  8. def eq(a, b):
  9. dt = a - b
  10. return dt > -0.001 and dt < 0.001
  11. # test + - * ** /
  12. assert eq(1.5 + 3, 4.5)
  13. assert eq(1.5 + 3.9, 5.4)
  14. assert eq(5.3 - 2.5, 2.8)
  15. assert eq(0.2**2, 0.04)
  16. assert eq(4**(-1.0), 0.25)
  17. assert eq(2/1, 2.0)
  18. assert eq(3/2.0, 1.5)
  19. assert eq(1/9, 0.11111)
  20. # test += -= *= /=
  21. x = 3.0
  22. x += 1
  23. assert eq(x, 4.0)
  24. x -= 1
  25. assert eq(x, 3.0)
  26. x *= 2
  27. assert eq(x, 6.0)
  28. x /= 1.8
  29. assert eq(x, 3.3333)
  30. # test __str__, __repr__
  31. assert str(1.0) == '1.0'
  32. assert repr(1.0) == '1.0'
  33. # test float()
  34. assert float() == 0.0
  35. assert float(True) == 1.0
  36. assert float(False) == 0.0
  37. assert float(1) == 1.0
  38. assert float(-2) == -2.0
  39. assert eq(float(1), 1.0)
  40. assert eq(float(1.0), 1.0)
  41. assert eq(float(1.1), 1.1)
  42. assert eq(float(1.9), 1.9)
  43. assert eq(float(-1.9), -1.9)
  44. assert eq(float(1.5), 1.5)
  45. assert eq(float(-1.5), -1.5)
  46. assert eq(float("123"), 123.0)
  47. assert eq(float("123.456"), 123.456)
  48. inf = float("inf")
  49. assert 1/0 == inf
  50. assert -1/0 == -inf
  51. assert 1/inf == 0
  52. assert -1/inf == 0
  53. assert 2**-6000 == 0.0
  54. assert 2.0 ** 6000 == inf
  55. assert (-2.0) ** 6001 == -inf
  56. # test .123 forms
  57. assert float(".123") == 0.123
  58. assert .123 == 0.123
  59. assert eq(.5 *2, 1.0)
  60. assert eq(2 * .5, 1.0)
  61. assert eq(2 * (.5), 1.0)
  62. assert eq(2 * (.5 + 1), 3.0)
  63. assert 1e3 == 1000.0
  64. assert 1e-3 == 0.001
  65. assert -1e3 == -1000.0
  66. assert -1e-3 == -0.001
  67. assert 1e0 == 1.0
  68. assert 1e-0 == 1.0
  69. assert 2e3 == 2000.0
  70. assert -2e-3 == -0.002
  71. assert 3.4e-3 == 0.0034
  72. assert 3.4e+3 == 3400.0
  73. assert abs(1.0) == 1.0
  74. assert abs(-1.0) == 1.0
  75. assert abs(0.0) == 0.0
  76. # import math
  77. # assert math.isnan(0/0)
  78. # assert 2e3j == 2000j
  79. # assert -2e-3j == -0.002j
  80. # try:
  81. # float('-x13')
  82. # exit(1)
  83. # except ValueError:
  84. # pass