| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 | from sympy.core.numbers import Rationalfrom sympy.core.symbol import (Dummy, Symbol)from sympy.functions.elementary.exponential import expdef test_equal():    b = Symbol("b")    a = Symbol("a")    e1 = a + b    e2 = 2*a*b    e3 = a**3*b**2    e4 = a*b + b*a    assert not e1 == e2    assert not e1 == e2    assert e1 != e2    assert e2 == e4    assert e2 != e3    assert not e2 == e3    x = Symbol("x")    e1 = exp(x + 1/x)    y = Symbol("x")    e2 = exp(y + 1/y)    assert e1 == e2    assert not e1 != e2    y = Symbol("y")    e2 = exp(y + 1/y)    assert not e1 == e2    assert e1 != e2    e5 = Rational(3) + 2*x - x - x    assert e5 == 3    assert 3 == e5    assert e5 != 4    assert 4 != e5    assert e5 != 3 + x    assert 3 + x != e5def test_expevalbug():    x = Symbol("x")    e1 = exp(1*x)    e3 = exp(x)    assert e1 == e3def test_cmp_bug1():    class T:        pass    t = T()    x = Symbol("x")    assert not (x == t)    assert (x != t)def test_cmp_bug2():    class T:        pass    t = T()    assert not (Symbol == t)    assert (Symbol != t)def test_cmp_issue_4357():    """ Check that Basic subclasses can be compared with sympifiable objects.    https://github.com/sympy/sympy/issues/4357    """    assert not (Symbol == 1)    assert (Symbol != 1)    assert not (Symbol == 'x')    assert (Symbol != 'x')def test_dummy_eq():    x = Symbol('x')    y = Symbol('y')    u = Dummy('u')    assert (u**2 + 1).dummy_eq(x**2 + 1) is True    assert ((u**2 + 1) == (x**2 + 1)) is False    assert (u**2 + y).dummy_eq(x**2 + y, x) is True    assert (u**2 + y).dummy_eq(x**2 + y, y) is False
 |