1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- from sympy.solvers.decompogen import decompogen, compogen
- from sympy.core.symbol import symbols
- from sympy.functions.elementary.complexes import Abs
- from sympy.functions.elementary.exponential import exp
- from sympy.functions.elementary.miscellaneous import sqrt, Max
- from sympy.functions.elementary.trigonometric import (cos, sin)
- from sympy.testing.pytest import XFAIL, raises
- x, y = symbols('x y')
- def test_decompogen():
- assert decompogen(sin(cos(x)), x) == [sin(x), cos(x)]
- assert decompogen(sin(x)**2 + sin(x) + 1, x) == [x**2 + x + 1, sin(x)]
- assert decompogen(sqrt(6*x**2 - 5), x) == [sqrt(x), 6*x**2 - 5]
- assert decompogen(sin(sqrt(cos(x**2 + 1))), x) == [sin(x), sqrt(x), cos(x), x**2 + 1]
- assert decompogen(Abs(cos(x)**2 + 3*cos(x) - 4), x) == [Abs(x), x**2 + 3*x - 4, cos(x)]
- assert decompogen(sin(x)**2 + sin(x) - sqrt(3)/2, x) == [x**2 + x - sqrt(3)/2, sin(x)]
- assert decompogen(Abs(cos(y)**2 + 3*cos(x) - 4), x) == [Abs(x), 3*x + cos(y)**2 - 4, cos(x)]
- assert decompogen(x, y) == [x]
- assert decompogen(1, x) == [1]
- assert decompogen(Max(3, x), x) == [Max(3, x)]
- raises(TypeError, lambda: decompogen(x < 5, x))
- u = 2*x + 3
- assert decompogen(Max(sqrt(u),(u)**2), x) == [Max(sqrt(x), x**2), u]
- assert decompogen(Max(u, u**2, y), x) == [Max(x, x**2, y), u]
- assert decompogen(Max(sin(x), u), x) == [Max(2*x + 3, sin(x))]
- def test_decompogen_poly():
- assert decompogen(x**4 + 2*x**2 + 1, x) == [x**2 + 2*x + 1, x**2]
- assert decompogen(x**4 + 2*x**3 - x - 1, x) == [x**2 - x - 1, x**2 + x]
- @XFAIL
- def test_decompogen_fails():
- A = lambda x: x**2 + 2*x + 3
- B = lambda x: 4*x**2 + 5*x + 6
- assert decompogen(A(x*exp(x)), x) == [x**2 + 2*x + 3, x*exp(x)]
- assert decompogen(A(B(x)), x) == [x**2 + 2*x + 3, 4*x**2 + 5*x + 6]
- assert decompogen(A(1/x + 1/x**2), x) == [x**2 + 2*x + 3, 1/x + 1/x**2]
- assert decompogen(A(1/x + 2/(x + 1)), x) == [x**2 + 2*x + 3, 1/x + 2/(x + 1)]
- def test_compogen():
- assert compogen([sin(x), cos(x)], x) == sin(cos(x))
- assert compogen([x**2 + x + 1, sin(x)], x) == sin(x)**2 + sin(x) + 1
- assert compogen([sqrt(x), 6*x**2 - 5], x) == sqrt(6*x**2 - 5)
- assert compogen([sin(x), sqrt(x), cos(x), x**2 + 1], x) == sin(sqrt(
- cos(x**2 + 1)))
- assert compogen([Abs(x), x**2 + 3*x - 4, cos(x)], x) == Abs(cos(x)**2 +
- 3*cos(x) - 4)
- assert compogen([x**2 + x - sqrt(3)/2, sin(x)], x) == (sin(x)**2 + sin(x) -
- sqrt(3)/2)
- assert compogen([Abs(x), 3*x + cos(y)**2 - 4, cos(x)], x) == \
- Abs(3*cos(x) + cos(y)**2 - 4)
- assert compogen([x**2 + 2*x + 1, x**2], x) == x**4 + 2*x**2 + 1
- # the result is in unsimplified form
- assert compogen([x**2 - x - 1, x**2 + x], x) == -x**2 - x + (x**2 + x)**2 - 1
|