test_order.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477
  1. from sympy.core.add import Add
  2. from sympy.core.function import (Function, expand)
  3. from sympy.core.numbers import (I, Rational, nan, oo, pi)
  4. from sympy.core.singleton import S
  5. from sympy.core.symbol import (Symbol, symbols)
  6. from sympy.functions.elementary.complexes import (conjugate, transpose)
  7. from sympy.functions.elementary.exponential import (exp, log)
  8. from sympy.functions.elementary.miscellaneous import sqrt
  9. from sympy.functions.elementary.trigonometric import (cos, sin)
  10. from sympy.integrals.integrals import Integral
  11. from sympy.series.order import O, Order
  12. from sympy.core.expr import unchanged
  13. from sympy.testing.pytest import raises
  14. from sympy.abc import w, x, y, z
  15. def test_caching_bug():
  16. #needs to be a first test, so that all caches are clean
  17. #cache it
  18. O(w)
  19. #and test that this won't raise an exception
  20. O(w**(-1/x/log(3)*log(5)), w)
  21. def test_free_symbols():
  22. assert Order(1).free_symbols == set()
  23. assert Order(x).free_symbols == {x}
  24. assert Order(1, x).free_symbols == {x}
  25. assert Order(x*y).free_symbols == {x, y}
  26. assert Order(x, x, y).free_symbols == {x, y}
  27. def test_simple_1():
  28. o = Rational(0)
  29. assert Order(2*x) == Order(x)
  30. assert Order(x)*3 == Order(x)
  31. assert -28*Order(x) == Order(x)
  32. assert Order(Order(x)) == Order(x)
  33. assert Order(Order(x), y) == Order(Order(x), x, y)
  34. assert Order(-23) == Order(1)
  35. assert Order(exp(x)) == Order(1, x)
  36. assert Order(exp(1/x)).expr == exp(1/x)
  37. assert Order(x*exp(1/x)).expr == x*exp(1/x)
  38. assert Order(x**(o/3)).expr == x**(o/3)
  39. assert Order(x**(o*Rational(5, 3))).expr == x**(o*Rational(5, 3))
  40. assert Order(x**2 + x + y, x) == O(1, x)
  41. assert Order(x**2 + x + y, y) == O(1, y)
  42. raises(ValueError, lambda: Order(exp(x), x, x))
  43. raises(TypeError, lambda: Order(x, 2 - x))
  44. def test_simple_2():
  45. assert Order(2*x)*x == Order(x**2)
  46. assert Order(2*x)/x == Order(1, x)
  47. assert Order(2*x)*x*exp(1/x) == Order(x**2*exp(1/x))
  48. assert (Order(2*x)*x*exp(1/x)/log(x)**3).expr == x**2*exp(1/x)*log(x)**-3
  49. def test_simple_3():
  50. assert Order(x) + x == Order(x)
  51. assert Order(x) + 2 == 2 + Order(x)
  52. assert Order(x) + x**2 == Order(x)
  53. assert Order(x) + 1/x == 1/x + Order(x)
  54. assert Order(1/x) + 1/x**2 == 1/x**2 + Order(1/x)
  55. assert Order(x) + exp(1/x) == Order(x) + exp(1/x)
  56. def test_simple_4():
  57. assert Order(x)**2 == Order(x**2)
  58. def test_simple_5():
  59. assert Order(x) + Order(x**2) == Order(x)
  60. assert Order(x) + Order(x**-2) == Order(x**-2)
  61. assert Order(x) + Order(1/x) == Order(1/x)
  62. def test_simple_6():
  63. assert Order(x) - Order(x) == Order(x)
  64. assert Order(x) + Order(1) == Order(1)
  65. assert Order(x) + Order(x**2) == Order(x)
  66. assert Order(1/x) + Order(1) == Order(1/x)
  67. assert Order(x) + Order(exp(1/x)) == Order(exp(1/x))
  68. assert Order(x**3) + Order(exp(2/x)) == Order(exp(2/x))
  69. assert Order(x**-3) + Order(exp(2/x)) == Order(exp(2/x))
  70. def test_simple_7():
  71. assert 1 + O(1) == O(1)
  72. assert 2 + O(1) == O(1)
  73. assert x + O(1) == O(1)
  74. assert 1/x + O(1) == 1/x + O(1)
  75. def test_simple_8():
  76. assert O(sqrt(-x)) == O(sqrt(x))
  77. assert O(x**2*sqrt(x)) == O(x**Rational(5, 2))
  78. assert O(x**3*sqrt(-(-x)**3)) == O(x**Rational(9, 2))
  79. assert O(x**Rational(3, 2)*sqrt((-x)**3)) == O(x**3)
  80. assert O(x*(-2*x)**(I/2)) == O(x*(-x)**(I/2))
  81. def test_as_expr_variables():
  82. assert Order(x).as_expr_variables(None) == (x, ((x, 0),))
  83. assert Order(x).as_expr_variables(((x, 0),)) == (x, ((x, 0),))
  84. assert Order(y).as_expr_variables(((x, 0),)) == (y, ((x, 0), (y, 0)))
  85. assert Order(y).as_expr_variables(((x, 0), (y, 0))) == (y, ((x, 0), (y, 0)))
  86. def test_contains_0():
  87. assert Order(1, x).contains(Order(1, x))
  88. assert Order(1, x).contains(Order(1))
  89. assert Order(1).contains(Order(1, x)) is False
  90. def test_contains_1():
  91. assert Order(x).contains(Order(x))
  92. assert Order(x).contains(Order(x**2))
  93. assert not Order(x**2).contains(Order(x))
  94. assert not Order(x).contains(Order(1/x))
  95. assert not Order(1/x).contains(Order(exp(1/x)))
  96. assert not Order(x).contains(Order(exp(1/x)))
  97. assert Order(1/x).contains(Order(x))
  98. assert Order(exp(1/x)).contains(Order(x))
  99. assert Order(exp(1/x)).contains(Order(1/x))
  100. assert Order(exp(1/x)).contains(Order(exp(1/x)))
  101. assert Order(exp(2/x)).contains(Order(exp(1/x)))
  102. assert not Order(exp(1/x)).contains(Order(exp(2/x)))
  103. def test_contains_2():
  104. assert Order(x).contains(Order(y)) is None
  105. assert Order(x).contains(Order(y*x))
  106. assert Order(y*x).contains(Order(x))
  107. assert Order(y).contains(Order(x*y))
  108. assert Order(x).contains(Order(y**2*x))
  109. def test_contains_3():
  110. assert Order(x*y**2).contains(Order(x**2*y)) is None
  111. assert Order(x**2*y).contains(Order(x*y**2)) is None
  112. def test_contains_4():
  113. assert Order(sin(1/x**2)).contains(Order(cos(1/x**2))) is True
  114. assert Order(cos(1/x**2)).contains(Order(sin(1/x**2))) is True
  115. def test_contains():
  116. assert Order(1, x) not in Order(1)
  117. assert Order(1) in Order(1, x)
  118. raises(TypeError, lambda: Order(x*y**2) in Order(x**2*y))
  119. def test_add_1():
  120. assert Order(x + x) == Order(x)
  121. assert Order(3*x - 2*x**2) == Order(x)
  122. assert Order(1 + x) == Order(1, x)
  123. assert Order(1 + 1/x) == Order(1/x)
  124. # TODO : A better output for Order(log(x) + 1/log(x))
  125. # could be Order(log(x)). Currently Order for expressions
  126. # where all arguments would involve a log term would fall
  127. # in this category and outputs for these should be improved.
  128. assert Order(log(x) + 1/log(x)) == Order((log(x)**2 + 1)/log(x))
  129. assert Order(exp(1/x) + x) == Order(exp(1/x))
  130. assert Order(exp(1/x) + 1/x**20) == Order(exp(1/x))
  131. def test_ln_args():
  132. assert O(log(x)) + O(log(2*x)) == O(log(x))
  133. assert O(log(x)) + O(log(x**3)) == O(log(x))
  134. assert O(log(x*y)) + O(log(x) + log(y)) == O(log(x) + log(y), x, y)
  135. def test_multivar_0():
  136. assert Order(x*y).expr == x*y
  137. assert Order(x*y**2).expr == x*y**2
  138. assert Order(x*y, x).expr == x
  139. assert Order(x*y**2, y).expr == y**2
  140. assert Order(x*y*z).expr == x*y*z
  141. assert Order(x/y).expr == x/y
  142. assert Order(x*exp(1/y)).expr == x*exp(1/y)
  143. assert Order(exp(x)*exp(1/y)).expr == exp(x)*exp(1/y)
  144. def test_multivar_0a():
  145. assert Order(exp(1/x)*exp(1/y)).expr == exp(1/x)*exp(1/y)
  146. def test_multivar_1():
  147. assert Order(x + y).expr == x + y
  148. assert Order(x + 2*y).expr == x + y
  149. assert (Order(x + y) + x).expr == (x + y)
  150. assert (Order(x + y) + x**2) == Order(x + y)
  151. assert (Order(x + y) + 1/x) == 1/x + Order(x + y)
  152. assert Order(x**2 + y*x).expr == x**2 + y*x
  153. def test_multivar_2():
  154. assert Order(x**2*y + y**2*x, x, y).expr == x**2*y + y**2*x
  155. def test_multivar_mul_1():
  156. assert Order(x + y)*x == Order(x**2 + y*x, x, y)
  157. def test_multivar_3():
  158. assert (Order(x) + Order(y)).args in [
  159. (Order(x), Order(y)),
  160. (Order(y), Order(x))]
  161. assert Order(x) + Order(y) + Order(x + y) == Order(x + y)
  162. assert (Order(x**2*y) + Order(y**2*x)).args in [
  163. (Order(x*y**2), Order(y*x**2)),
  164. (Order(y*x**2), Order(x*y**2))]
  165. assert (Order(x**2*y) + Order(y*x)) == Order(x*y)
  166. def test_issue_3468():
  167. y = Symbol('y', negative=True)
  168. z = Symbol('z', complex=True)
  169. # check that Order does not modify assumptions about symbols
  170. Order(x)
  171. Order(y)
  172. Order(z)
  173. assert x.is_positive is None
  174. assert y.is_positive is False
  175. assert z.is_positive is None
  176. def test_leading_order():
  177. assert (x + 1 + 1/x**5).extract_leading_order(x) == ((1/x**5, O(1/x**5)),)
  178. assert (1 + 1/x).extract_leading_order(x) == ((1/x, O(1/x)),)
  179. assert (1 + x).extract_leading_order(x) == ((1, O(1, x)),)
  180. assert (1 + x**2).extract_leading_order(x) == ((1, O(1, x)),)
  181. assert (2 + x**2).extract_leading_order(x) == ((2, O(1, x)),)
  182. assert (x + x**2).extract_leading_order(x) == ((x, O(x)),)
  183. def test_leading_order2():
  184. assert set((2 + pi + x**2).extract_leading_order(x)) == {(pi, O(1, x)),
  185. (S(2), O(1, x))}
  186. assert set((2*x + pi*x + x**2).extract_leading_order(x)) == {(2*x, O(x)),
  187. (x*pi, O(x))}
  188. def test_order_leadterm():
  189. assert O(x**2)._eval_as_leading_term(x) == O(x**2)
  190. def test_order_symbols():
  191. e = x*y*sin(x)*Integral(x, (x, 1, 2))
  192. assert O(e) == O(x**2*y, x, y)
  193. assert O(e, x) == O(x**2)
  194. def test_nan():
  195. assert O(nan) is nan
  196. assert not O(x).contains(nan)
  197. def test_O1():
  198. assert O(1, x) * x == O(x)
  199. assert O(1, y) * x == O(1, y)
  200. def test_getn():
  201. # other lines are tested incidentally by the suite
  202. assert O(x).getn() == 1
  203. assert O(x/log(x)).getn() == 1
  204. assert O(x**2/log(x)**2).getn() == 2
  205. assert O(x*log(x)).getn() == 1
  206. raises(NotImplementedError, lambda: (O(x) + O(y)).getn())
  207. def test_diff():
  208. assert O(x**2).diff(x) == O(x)
  209. def test_getO():
  210. assert (x).getO() is None
  211. assert (x).removeO() == x
  212. assert (O(x)).getO() == O(x)
  213. assert (O(x)).removeO() == 0
  214. assert (z + O(x) + O(y)).getO() == O(x) + O(y)
  215. assert (z + O(x) + O(y)).removeO() == z
  216. raises(NotImplementedError, lambda: (O(x) + O(y)).getn())
  217. def test_leading_term():
  218. from sympy.functions.special.gamma_functions import digamma
  219. assert O(1/digamma(1/x)) == O(1/log(x))
  220. def test_eval():
  221. assert Order(x).subs(Order(x), 1) == 1
  222. assert Order(x).subs(x, y) == Order(y)
  223. assert Order(x).subs(y, x) == Order(x)
  224. assert Order(x).subs(x, x + y) == Order(x + y, (x, -y))
  225. assert (O(1)**x).is_Pow
  226. def test_issue_4279():
  227. a, b = symbols('a b')
  228. assert O(a, a, b) + O(1, a, b) == O(1, a, b)
  229. assert O(b, a, b) + O(1, a, b) == O(1, a, b)
  230. assert O(a + b, a, b) + O(1, a, b) == O(1, a, b)
  231. assert O(1, a, b) + O(a, a, b) == O(1, a, b)
  232. assert O(1, a, b) + O(b, a, b) == O(1, a, b)
  233. assert O(1, a, b) + O(a + b, a, b) == O(1, a, b)
  234. def test_issue_4855():
  235. assert 1/O(1) != O(1)
  236. assert 1/O(x) != O(1/x)
  237. assert 1/O(x, (x, oo)) != O(1/x, (x, oo))
  238. f = Function('f')
  239. assert 1/O(f(x)) != O(1/x)
  240. def test_order_conjugate_transpose():
  241. x = Symbol('x', real=True)
  242. y = Symbol('y', imaginary=True)
  243. assert conjugate(Order(x)) == Order(conjugate(x))
  244. assert conjugate(Order(y)) == Order(conjugate(y))
  245. assert conjugate(Order(x**2)) == Order(conjugate(x)**2)
  246. assert conjugate(Order(y**2)) == Order(conjugate(y)**2)
  247. assert transpose(Order(x)) == Order(transpose(x))
  248. assert transpose(Order(y)) == Order(transpose(y))
  249. assert transpose(Order(x**2)) == Order(transpose(x)**2)
  250. assert transpose(Order(y**2)) == Order(transpose(y)**2)
  251. def test_order_noncommutative():
  252. A = Symbol('A', commutative=False)
  253. assert Order(A + A*x, x) == Order(1, x)
  254. assert (A + A*x)*Order(x) == Order(x)
  255. assert (A*x)*Order(x) == Order(x**2, x)
  256. assert expand((1 + Order(x))*A*A*x) == A*A*x + Order(x**2, x)
  257. assert expand((A*A + Order(x))*x) == A*A*x + Order(x**2, x)
  258. assert expand((A + Order(x))*A*x) == A*A*x + Order(x**2, x)
  259. def test_issue_6753():
  260. assert (1 + x**2)**10000*O(x) == O(x)
  261. def test_order_at_infinity():
  262. assert Order(1 + x, (x, oo)) == Order(x, (x, oo))
  263. assert Order(3*x, (x, oo)) == Order(x, (x, oo))
  264. assert Order(x, (x, oo))*3 == Order(x, (x, oo))
  265. assert -28*Order(x, (x, oo)) == Order(x, (x, oo))
  266. assert Order(Order(x, (x, oo)), (x, oo)) == Order(x, (x, oo))
  267. assert Order(Order(x, (x, oo)), (y, oo)) == Order(x, (x, oo), (y, oo))
  268. assert Order(3, (x, oo)) == Order(1, (x, oo))
  269. assert Order(x**2 + x + y, (x, oo)) == O(x**2, (x, oo))
  270. assert Order(x**2 + x + y, (y, oo)) == O(y, (y, oo))
  271. assert Order(2*x, (x, oo))*x == Order(x**2, (x, oo))
  272. assert Order(2*x, (x, oo))/x == Order(1, (x, oo))
  273. assert Order(2*x, (x, oo))*x*exp(1/x) == Order(x**2*exp(1/x), (x, oo))
  274. assert Order(2*x, (x, oo))*x*exp(1/x)/log(x)**3 == Order(x**2*exp(1/x)*log(x)**-3, (x, oo))
  275. assert Order(x, (x, oo)) + 1/x == 1/x + Order(x, (x, oo)) == Order(x, (x, oo))
  276. assert Order(x, (x, oo)) + 1 == 1 + Order(x, (x, oo)) == Order(x, (x, oo))
  277. assert Order(x, (x, oo)) + x == x + Order(x, (x, oo)) == Order(x, (x, oo))
  278. assert Order(x, (x, oo)) + x**2 == x**2 + Order(x, (x, oo))
  279. assert Order(1/x, (x, oo)) + 1/x**2 == 1/x**2 + Order(1/x, (x, oo)) == Order(1/x, (x, oo))
  280. assert Order(x, (x, oo)) + exp(1/x) == exp(1/x) + Order(x, (x, oo))
  281. assert Order(x, (x, oo))**2 == Order(x**2, (x, oo))
  282. assert Order(x, (x, oo)) + Order(x**2, (x, oo)) == Order(x**2, (x, oo))
  283. assert Order(x, (x, oo)) + Order(x**-2, (x, oo)) == Order(x, (x, oo))
  284. assert Order(x, (x, oo)) + Order(1/x, (x, oo)) == Order(x, (x, oo))
  285. assert Order(x, (x, oo)) - Order(x, (x, oo)) == Order(x, (x, oo))
  286. assert Order(x, (x, oo)) + Order(1, (x, oo)) == Order(x, (x, oo))
  287. assert Order(x, (x, oo)) + Order(x**2, (x, oo)) == Order(x**2, (x, oo))
  288. assert Order(1/x, (x, oo)) + Order(1, (x, oo)) == Order(1, (x, oo))
  289. assert Order(x, (x, oo)) + Order(exp(1/x), (x, oo)) == Order(x, (x, oo))
  290. assert Order(x**3, (x, oo)) + Order(exp(2/x), (x, oo)) == Order(x**3, (x, oo))
  291. assert Order(x**-3, (x, oo)) + Order(exp(2/x), (x, oo)) == Order(exp(2/x), (x, oo))
  292. # issue 7207
  293. assert Order(exp(x), (x, oo)).expr == Order(2*exp(x), (x, oo)).expr == exp(x)
  294. assert Order(y**x, (x, oo)).expr == Order(2*y**x, (x, oo)).expr == exp(x*log(y))
  295. # issue 19545
  296. assert Order(1/x - 3/(3*x + 2), (x, oo)).expr == x**(-2)
  297. def test_mixing_order_at_zero_and_infinity():
  298. assert (Order(x, (x, 0)) + Order(x, (x, oo))).is_Add
  299. assert Order(x, (x, 0)) + Order(x, (x, oo)) == Order(x, (x, oo)) + Order(x, (x, 0))
  300. assert Order(Order(x, (x, oo))) == Order(x, (x, oo))
  301. # not supported (yet)
  302. raises(NotImplementedError, lambda: Order(x, (x, 0))*Order(x, (x, oo)))
  303. raises(NotImplementedError, lambda: Order(x, (x, oo))*Order(x, (x, 0)))
  304. raises(NotImplementedError, lambda: Order(Order(x, (x, oo)), y))
  305. raises(NotImplementedError, lambda: Order(Order(x), (x, oo)))
  306. def test_order_at_some_point():
  307. assert Order(x, (x, 1)) == Order(1, (x, 1))
  308. assert Order(2*x - 2, (x, 1)) == Order(x - 1, (x, 1))
  309. assert Order(-x + 1, (x, 1)) == Order(x - 1, (x, 1))
  310. assert Order(x - 1, (x, 1))**2 == Order((x - 1)**2, (x, 1))
  311. assert Order(x - 2, (x, 2)) - O(x - 2, (x, 2)) == Order(x - 2, (x, 2))
  312. def test_order_subs_limits():
  313. # issue 3333
  314. assert (1 + Order(x)).subs(x, 1/x) == 1 + Order(1/x, (x, oo))
  315. assert (1 + Order(x)).limit(x, 0) == 1
  316. # issue 5769
  317. assert ((x + Order(x**2))/x).limit(x, 0) == 1
  318. assert Order(x**2).subs(x, y - 1) == Order((y - 1)**2, (y, 1))
  319. assert Order(10*x**2, (x, 2)).subs(x, y - 1) == Order(1, (y, 3))
  320. def test_issue_9351():
  321. assert exp(x).series(x, 10, 1) == exp(10) + Order(x - 10, (x, 10))
  322. def test_issue_9192():
  323. assert O(1)*O(1) == O(1)
  324. assert O(1)**O(1) == O(1)
  325. def test_issue_9910():
  326. assert O(x*log(x) + sin(x), (x, oo)) == O(x*log(x), (x, oo))
  327. def test_performance_of_adding_order():
  328. l = [x**i for i in range(1000)]
  329. l.append(O(x**1001))
  330. assert Add(*l).subs(x,1) == O(1)
  331. def test_issue_14622():
  332. assert (x**(-4) + x**(-3) + x**(-1) + O(x**(-6), (x, oo))).as_numer_denom() == (
  333. x**4 + x**5 + x**7 + O(x**2, (x, oo)), x**8)
  334. assert (x**3 + O(x**2, (x, oo))).is_Add
  335. assert O(x**2, (x, oo)).contains(x**3) is False
  336. assert O(x, (x, oo)).contains(O(x, (x, 0))) is None
  337. assert O(x, (x, 0)).contains(O(x, (x, oo))) is None
  338. raises(NotImplementedError, lambda: O(x**3).contains(x**w))
  339. def test_issue_15539():
  340. assert O(1/x**2 + 1/x**4, (x, -oo)) == O(1/x**2, (x, -oo))
  341. assert O(1/x**4 + exp(x), (x, -oo)) == O(1/x**4, (x, -oo))
  342. assert O(1/x**4 + exp(-x), (x, -oo)) == O(exp(-x), (x, -oo))
  343. assert O(1/x, (x, oo)).subs(x, -x) == O(-1/x, (x, -oo))
  344. def test_issue_18606():
  345. assert unchanged(Order, 0)
  346. def test_issue_22165():
  347. assert O(log(x)).contains(2)
  348. def test_issue_23231():
  349. # This test checks Order for expressions having
  350. # arguments containing variables in exponents/powers.
  351. assert O(x**x + 2**x, (x, oo)) == O(exp(x*log(x)), (x, oo))
  352. assert O(x**x + x**2, (x, oo)) == O(exp(x*log(x)), (x, oo))
  353. assert O(x**x + 1/x**2, (x, oo)) == O(exp(x*log(x)), (x, oo))
  354. assert O(2**x + 3**x , (x, oo)) == O(exp(x*log(3)), (x, oo))
  355. def test_issue_9917():
  356. assert O(x*sin(x) + 1, (x, oo)) == O(x, (x, oo))