{
  "instance_id": "sympy__sympy-19487",
  "repo": "sympy/sympy",
  "created_at": "2020-06-04T09:25:34Z",
  "problem_statement": "Rewrite sign as abs\nIn sympy the `sign` function is defined as\r\n```\r\n    sign(z)  :=  z / Abs(z)\r\n```\r\nfor all complex non-zero `z`. There should be a way to rewrite the sign in terms of `Abs` e.g.:\r\n```\r\n>>> sign(x).rewrite(Abs)                                                                                                                   \r\n x \r\n\u2500\u2500\u2500\r\n\u2502x\u2502\r\n```\r\nI'm not sure how the possibility of `x` being zero should be handled currently we have\r\n```\r\n>>> sign(0)                                                                                                                               \r\n0\r\n>>> 0 / Abs(0)                                                                                                                            \r\nnan\r\n```\r\nMaybe `sign(0)` should be `nan` as well. Otherwise maybe rewrite as Abs would have to be careful about the possibility of the arg being zero (that would make the rewrite fail in most cases).\n",
  "patch": "diff --git a/sympy/functions/elementary/complexes.py b/sympy/functions/elementary/complexes.py\n--- a/sympy/functions/elementary/complexes.py\n+++ b/sympy/functions/elementary/complexes.py\n@@ -394,6 +394,9 @@ def _eval_rewrite_as_Heaviside(self, arg, **kwargs):\n         if arg.is_extended_real:\n             return Heaviside(arg, H0=S(1)/2) * 2 - 1\n \n+    def _eval_rewrite_as_Abs(self, arg, **kwargs):\n+        return Piecewise((0, Eq(arg, 0)), (arg / Abs(arg), True))\n+\n     def _eval_simplify(self, **kwargs):\n         return self.func(self.args[0].factor())  # XXX include doit?\n \n",
  "similar_bug_items": [
    {
      "pr_number": 15519,
      "pr_title": "Exit _eval_derivative_n_times when None is obtained",
      "pr_body": "#### References to other Issues or PRs\r\n\r\nFixes #15518 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nThe method `_eval_derivative_n_times` contains a loop that involves calling `_eval_derivative`. The latter may return None when evaluation is not implemented. In such a case the loop should be aborted (returning None) instead of trying to differentiate None.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* core\r\n  * Fixed a bug in the creation of higher order derivatives that cannot be evaluated.  \r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 15518,
      "issue_title": "Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception",
      "issue_body": "This issue arose in a [comment on another issue]( https://github.com/sympy/sympy/issues/15457#issuecomment-436453327) but since it's actually unrelated, is posted here separately. \r\n```\r\n>>> re(x).diff(x, 2)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/ubuntu/sympy/sympy/core/expr.py\", line 3047, in diff\r\n    return Derivative(self, *symbols, **assumptions)\r\n  File \"/home/ubuntu/sympy/sympy/core/function.py\", line 1370, in __new__\r\n    obj = expr._eval_derivative_n_times(v, count)\r\n  File \"/home/ubuntu/sympy/sympy/core/basic.py\", line 1688, in _eval_derivative_n_times\r\n    obj2 = obj._accept_eval_derivative(s)\r\nAttributeError: 'NoneType' object has no attribute '_accept_eval_derivative'\r\n```\r\nThis happens whenever a higher-order derivative is requested for a function that does not have an explicit derivative. The expected output is \r\n```\r\nDerivative(re(x), (x, 2))\r\n```\r\nA PR is forthcoming. \r\n",
      "issue_closed_at": "2018-11-24T11:36:42Z",
      "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d",
      "changes": [
        {
          "file": "sympy/core/basic.py",
          "type": "function",
          "name": "_eval_derivative_n_times",
          "class_name": "Basic",
          "code": "def _eval_derivative_n_times(self, s, n):\n        # This is the default evaluator for derivatives (as called by `diff`\n        # and `Derivative`), it will attempt a loop to derive the expression\n        # `n` times by calling the corresponding `_eval_derivative` method,\n        # while leaving the derivative unevaluated if `n` is symbolic.  This\n        # method should be overridden if the object has a closed form for its\n        # symbolic n-th derivative.\n        from sympy import Integer\n        if isinstance(n, (int, Integer)):\n            obj = self\n            for i in range(n):\n                obj2 = obj._accept_eval_derivative(s)\n                if obj == obj2:\n                    break\n                obj = obj2\n            return obj\n        else:\n            return None"
        }
      ]
    },
    {
      "pr_number": 13437,
      "pr_title": "Fix bell(n) for n=oo, and negative/non-integer 'n'",
      "pr_body": "This PR uses commits of #9198 (maintaining ownership to original author). And tries to address the requested changes on PR #9198 .\r\nFixes #9184",
      "issue_id": 9184,
      "issue_title": "bell(n).limit(n, oo) should be oo rather than bell(oo)",
      "issue_body": "`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n",
      "issue_closed_at": "2017-10-13T04:35:13Z",
      "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "_bell_incomplete_poly",
          "class_name": "bell",
          "code": "def _bell_incomplete_poly(n, k, symbols):\n        r\"\"\"\n        The second kind of Bell polynomials (incomplete Bell polynomials).\n\n        Calculated by recurrence formula:\n\n        .. math:: B_{n,k}(x_1, x_2, \\dotsc, x_{n-k+1}) =\n                \\sum_{m=1}^{n-k+1}\n                \\x_m \\binom{n-1}{m-1} B_{n-m,k-1}(x_1, x_2, \\dotsc, x_{n-m-k})\n\n        where\n            B_{0,0} = 1;\n            B_{n,0} = 0; for n>=1\n            B_{0,k} = 0; for k>=1\n\n        \"\"\"\n        if (n == 0) and (k == 0):\n            return S.One\n        elif (n == 0) or (k == 0):\n            return S.Zero\n        s = S.Zero\n        a = S.One\n        for m in range(1, n - k + 2):\n            s += a * bell._bell_incomplete_poly(\n                n - m, k - 1, symbols) * symbols[m - 1]\n            a = a * (n - m) / m\n        return expand_mul(s)"
        }
      ]
    },
    {
      "pr_number": 18325,
      "pr_title": "Fix Mul.is_irrational",
      "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\". See\r\nhttps://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #17142\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nI'd get to make the logic to correctly work by adding an additional check if every arguments are real.\r\n\r\n#### Other comments\r\n\r\nI'm not sure how to test out the original issue, unless it's getting run a thousand times.\r\nBut I would just post the original case on the travis and see if it gets failed for some other contributors' build. If it fails again, then the issue should get raised up again, right?\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 17142,
      "issue_title": "Nondeterministic exception from (atan(I/(I + I*tan(1)))).as_real_imag() (InconsistentAssumptions)",
      "issue_body": "Sometimes this works:\r\n\r\n```\r\n>>> from sympy import *\r\n>>> e = atan(I/(I + I*tan(1)))\r\n>>> e.as_real_imag()\r\n(atan(I/(I + I*tan(1))), 0)\r\n```\r\n\r\nSometimes it gives this exception:\r\n\r\n```\r\n>>> e.as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_real'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'rational'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"testing.py\", line 114, in <module>\r\n    print(c, e.as_real_imag())\r\n  File \"/home/e/se/sympy/core/expr.py\", line 1921, in as_real_imag\r\n    return (re(self), im(self))\r\n  File \"/home/e/se/sympy/core/cache.py\", line 94, in wrapper\r\n    retval = cfunc(*args, **kwargs)\r\n  File \"/home/e/se/sympy/core/function.py\", line 462, in __new__\r\n    result = super(Function, cls).__new__(cls, *args, **options)\r\n  File \"/home/e/se/sympy/core/cache.py\", line 94, in wrapper\r\n    retval = cfunc(*args, **kwargs)\r\n  File \"/home/e/se/sympy/core/function.py\", line 277, in __new__\r\n    evaluated = cls.eval(*args)\r\n  File \"/home/e/se/sympy/functions/elementary/complexes.py\", line 58, in eval\r\n    elif arg.is_extended_real:\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/e/se/sympy/functions/elementary/trigonometric.py\", line 2269, in _eval_is_rational\r\n    if s.args[0].is_rational:\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/e/se/sympy/core/assumptions.py\", line 311, in _ask\r\n    assumptions.deduce_all_facts(((fact, a),))\r\n  File \"/home/e/se/sympy/core/facts.py\", line 522, in deduce_all_facts\r\n    if not self._tell(k, v) or v is None:\r\n  File \"/home/e/se/sympy/core/facts.py\", line 493, in _tell\r\n    raise InconsistentAssumptions(self, k, v)\r\nsympy.core.facts.InconsistentAssumptions: {\r\n\talgebraic: False,\r\n\tcommutative: True,\r\n\tcomplex: True,\r\n\tcomposite: False,\r\n\teven: False,\r\n\textended_negative: None,\r\n\textended_nonzero: True,\r\n\textended_positive: None,\r\n\textended_real: True,\r\n\tfinite: True,\r\n\thermitian: True,\r\n\timaginary: False,\r\n\tinfinite: False,\r\n\tinteger: False,\r\n\tirrational: False,\r\n\tnegative: None,\r\n\tnonzero: True,\r\n\todd: False,\r\n\tpositive: None,\r\n\tprime: False,\r\n\trational: False,\r\n\treal: True,\r\n\ttranscendental: True,\r\n\tzero: False}, irrational=True\r\n```\r\n\r\nAnother example is `log(I + I*pi/2)`.",
      "issue_closed_at": "2020-01-14T01:45:34Z",
      "base_commit": "f119ab5d30e8b373dc8956d41b7c11e53c140209",
      "changes": [
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_irrational",
          "class_name": "Mul",
          "code": "def _eval_is_irrational(self):\n        for t in self.args:\n            a = t.is_irrational\n            if a:\n                others = list(self.args)\n                others.remove(t)\n                if all((x.is_rational and fuzzy_not(x.is_zero)) is True for x in others):\n                    return True\n                return\n            if a is None:\n                return\n        return False"
        }
      ]
    },
    {
      "pr_number": 8044,
      "pr_title": "simplify Mul._eval_is_negative routine",
      "pr_body": "",
      "issue_id": 8008,
      "issue_title": "Test failure in meijerint after merging #7920",
      "issue_body": "More detailed discussion can be found at the bottom of #7920.\n\nThis fails in 2.7 - 100% reproducible on my machine\n\n``` bash\nPYTHONHASHSEED=730299569 bin/test sympy/integrals/tests/test_meijerint.py -k test_meijerint --seed 68924065\n============================= test process starts =============================\nexecutable:         /home/ptb/miniconda3/envs/py27/bin/python  (2.7.8-final-0) [CPython]\narchitecture:       64-bit\ncache:              yes\nground types:       python \nrandom seed:        68924065\nhash randomization: on (PYTHONHASHSEED=730299569)\n\nsympy/integrals/tests/test_meijerint.py[2] .E                            [FAIL]\n\n_______________________________________________________________________________\n___________ sympy/integrals/tests/test_meijerint.py:test_meijerint ____________\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/tests/test_meijerint.py\", line 148, in test_meijerint\n    assert expand(meijerint_definite(exp(x), x, 0, I)[0]) == exp(I) - 1\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1795, in meijerint_definite\n    res = _meijerint_definite_2(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1852, in _meijerint_definite_2\n    res = _meijerint_definite_3(g, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1864, in _meijerint_definite_3\n    res = _meijerint_definite_4(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1944, in _meijerint_definite_4\n    return _my_unpolarify(hyperexpand(res)), cond\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2482, in hyperexpand\n    return f.replace(hyper, do_replace).replace(meijerg, do_meijer)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1351, in replace\n    rv = bottom_up(self, rec_replace, atoms=True)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 4077, in bottom_up\n    for a in rv.args])\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 4080, in bottom_up\n    rv = F(rv)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1336, in rec_replace\n    new = _value(expr, result)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1280, in <lambda>\n    _value = lambda expr, result: value(*expr.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2479, in do_meijer\n    allow_hyper, rewrite=rewrite)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2367, in _meijergexpand\n    slater1, cond1 = do_slater(func.an, func.bm, func.ap, func.bq, z, z0)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2303, in do_slater\n    t, premult, bh, rewrite=None)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2068, in _hyperexpand\n    return powdenest(r, polar=True).replace(hyper, hyperexpand_special)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2442, in powdenest\n    eq, rep = polarify(eq)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2166, in polarify\n    eq = _polarify(sympify(eq), lift)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2101, in _polarify\n    return polar_lift(eq)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 375, in __new__\n    result = super(Function, cls).__new__(cls, *args, **options)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 199, in __new__\n    evaluated = cls.eval(*args)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/complexes.py\", line 651, in eval\n    ar = argument(arg)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 375, in __new__\n    result = super(Function, cls).__new__(cls, *args, **options)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 199, in __new__\n    evaluated = cls.eval(*args)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/complexes.py\", line 487, in eval\n    sign(a) for a in arg_.args])\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 379, in __new__\n    pr = max(cls._should_evalf(a) for a in result.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 379, in <genexpr>\n    pr = max(cls._should_evalf(a) for a in result.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 398, in _should_evalf\n    re, im = arg.as_real_imag()\n  File \"/home/ptb/gitrepos/sympy/sympy/core/add.py\", line 701, in as_real_imag\n    re, im = term.as_real_imag(deep=deep)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/exponential.py\", line 330, in as_real_imag\n    return (exp(re)*cos, exp(re)*sin)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 415, in flatten\n    c_part.append(Pow(b, e))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/power.py\", line 170, in __new__\n    elif e.is_integer and _coeff_isneg(b):\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 180, in _ask\n    assumptions.deduce_all_facts(((fact, a),))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/facts.py\", line 506, in deduce_all_facts\n    if not self._tell(k, v) or v is None:\n  File \"/home/ptb/gitrepos/sympy/sympy/core/facts.py\", line 477, in _tell\n    raise InconsistentAssumptions(self, k, v)\nInconsistentAssumptions: {\n    commutative: True,\n    complex: True,\n    composite: False,\n    even: False,\n    hermitian: True,\n    imaginary: False,\n    integer: False,\n    irrational: True,\n    negative: False,\n    noninteger: True,\n    nonnegative: True,\n    nonpositive: False,\n    nonzero: True,\n    odd: False,\n    positive: True,\n    prime: False,\n    rational: False,\n    real: True,\n    zero: False}, imaginary=True\n\n========== tests finished: 1 passed, 1 exceptions, in 10.71 seconds ===========\nDO *NOT* COMMIT!\n```\n\nFails with a different error with caching disabled\n\n``` bash\nSYMPY_USE_CACHE=NO PYTHONHASHSEED=730299569 bin/test sympy/integrals/tests/test_meijerint.py -k test_meijerint --seed 68924065============================= test process starts =============================\nexecutable:         /home/ptb/miniconda3/envs/py27/bin/python  (2.7.8-final-0) [CPython]\narchitecture:       64-bit\ncache:              no\nground types:       python \nrandom seed:        68924065\nhash randomization: on (PYTHONHASHSEED=730299569)\n\nsympy/integrals/tests/test_meijerint.py[2] .E                            [FAIL]\n\n_______________________________________________________________________________\n___________ sympy/integrals/tests/test_meijerint.py:test_meijerint ____________\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/tests/test_meijerint.py\", line 138, in test_meijerint\n    i, c = meijerint_definite(exp(-((x - mu)/(2*sigma))**2), x, 0, oo)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1766, in meijerint_definite\n    res = _meijerint_definite_2(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1852, in _meijerint_definite_2\n    res = _meijerint_definite_3(g, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1864, in _meijerint_definite_3\n    res = _meijerint_definite_4(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1935, in _meijerint_definite_4\n    cond = And(cond, _check_antecedents(f1_, f2_, x))\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1075, in _check_antecedents\n    conds += [And(Eq(p, q), Eq(cstar, 0), bstar.is_positive is True, omega.is_positive is True, re(mu) < 1,\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 388, in flatten\n    c_powers = _gather(c_powers)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 384, in _gather\n    new_c_powers.append((b, c*t))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1671, in __mul__\n    return Rational.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1227, in __mul__\n    return Number.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 361, in __mul__\n    return AtomicExpr.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 284, in flatten\n    neg1e += S.Half\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1647, in __add__\n    return Rational.__add__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1205, in __add__\n    return Rational(self.p*other.q + self.q*other.p, self.q*other.q)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1096, in __new__\n    p = Rational(p)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1084, in __new__\n    if isinstance(p, fractions.Fraction):\nRuntimeError: maximum recursion depth exceeded\n\n========== tests finished: 1 passed, 1 exceptions, in 41.05 seconds ===========\nDO *NOT* COMMIT!\n```\n",
      "issue_closed_at": "2014-09-16T15:27:52Z",
      "base_commit": "3d2a26cb368ab2233dc73c2857ab0c6ca7e95f9e",
      "changes": [
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_algebraic_expr",
          "class_name": "Mul",
          "code": "def _eval_is_algebraic_expr(self, syms):\n        return all(term._eval_is_algebraic_expr(syms) for term in self.args)"
        },
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_positive",
          "class_name": "Mul",
          "code": "def _eval_is_positive(self):\n        \"\"\"Return True if self is positive, False if not, and None if it\n        cannot be determined.\n\n        This algorithm is non-recursive and works by keeping track of the\n        sign which changes when a negative or nonpositive is encountered.\n        Whether a nonpositive or nonnegative is seen is also tracked since\n        the presence of these makes it impossible to return True, but\n        possible to return False if the end result is nonpositive. e.g.\n\n            pos * neg * nonpositive -> pos or zero -> None is returned\n            pos * neg * nonnegative -> neg or zero -> False is returned\n        \"\"\"\n\n        sign = 1\n        saw_NON = False\n        for t in self.args:\n            if t.is_positive:\n                continue\n            elif t.is_negative:\n                sign = -sign\n            elif t.is_zero:\n                return False\n            elif t.is_nonpositive:\n                sign = -sign\n                saw_NON = True\n            elif t.is_nonnegative:\n                saw_NON = True\n            else:\n                return\n        if sign == 1 and saw_NON is False:\n            return True\n        if sign < 0:\n            return False"
        },
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_odd",
          "class_name": "Mul",
          "code": "def _eval_is_odd(self):\n        is_integer = self.is_integer\n\n        if is_integer:\n            r, acc = True, 1\n            for t in self.args:\n                if not t.is_integer:\n                    return None\n                elif t.is_even:\n                    r = False\n                elif t.is_integer:\n                    if r is False:\n                        pass\n                    elif acc != 1 and (acc + t).is_odd:\n                        r = False\n                    elif t.is_odd is None:\n                        r = None\n                acc = t\n            return r\n\n        # !integer -> !odd\n        elif is_integer is False:\n            return False"
        },
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_is_bounded",
          "class_name": "log",
          "code": "def _eval_is_bounded(self):\n        arg = self.args[0]\n        if arg.is_zero:\n            return False\n        return arg.is_bounded"
        },
        {
          "file": "sympy/polys/numberfields.py",
          "type": "function",
          "name": "_minpoly_compose",
          "class_name": null,
          "code": "def _minpoly_compose(ex, x, dom):\n    \"\"\"\n    Computes the minimal polynomial of an algebraic element\n    using operations on minimal polynomials\n\n    Examples\n    ========\n\n    >>> from sympy import minimal_polynomial, sqrt, Rational\n    >>> from sympy.abc import x, y\n    >>> minimal_polynomial(sqrt(2) + 3*Rational(1, 3), x, compose=True)\n    x**2 - 2*x - 1\n    >>> minimal_polynomial(sqrt(y) + 1/y, x, compose=True)\n    x**2*y**2 - 2*x*y - y**3 + 1\n\n    \"\"\"\n    if ex.is_Rational:\n        return ex.q*x - ex.p\n    if ex is I:\n        return x**2 + 1\n    if hasattr(dom, 'symbols') and ex in dom.symbols:\n        return x - ex\n\n    if dom.is_QQ and _is_sum_surds(ex):\n        # eliminate the square roots\n        ex -= x\n        while 1:\n            ex1 = _separate_sq(ex)\n            if ex1 is ex:\n                return ex\n            else:\n                ex = ex1\n\n    if ex.is_Add:\n        res = _minpoly_add(x, dom, *ex.args)\n    elif ex.is_Mul:\n        f = Factors(ex).factors\n        r = sift(f.items(), lambda itx: itx[0].is_rational and itx[1].is_rational)\n        if r[True] and dom == QQ:\n            ex1 = Mul(*[bx**ex for bx, ex in r[False] + r[None]])\n            r1 = r[True]\n            dens = [y.q for _, y in r1]\n            lcmdens = reduce(lcm, dens, 1)\n            nums = [base**(y.p*lcmdens // y.q) for base, y in r1]\n            ex2 = Mul(*nums)\n            mp1 = minimal_polynomial(ex1, x)\n            # use the fact that in SymPy canonicalization products of integers\n            # raised to rational powers are organized in relatively prime\n            # bases, and that in ``base**(n/d)`` a perfect power is\n            # simplified with the root\n            mp2 = ex2.q*x**lcmdens - ex2.p\n            ex2 = ex2**Rational(1, lcmdens)\n            res = _minpoly_op_algebraic_element(Mul, ex1, ex2, x, dom, mp1=mp1, mp2=mp2)\n        else:\n            res = _minpoly_mul(x, dom, *ex.args)\n    elif ex.is_Pow:\n        res = _minpoly_pow(ex.base, ex.exp, x, dom)\n    elif ex.__class__ is C.sin:\n        res = _minpoly_sin(ex, x)\n    elif ex.__class__ is C.cos:\n        res = _minpoly_cos(ex, x)\n    elif ex.__class__ is C.exp:\n        res = _minpoly_exp(ex, x)\n    elif ex.__class__ is RootOf:\n        res = _minpoly_rootof(ex, x)\n    else:\n        raise NotAlgebraic(\"%s doesn't seem to be an algebraic element\" % ex)\n    return res"
        }
      ]
    },
    {
      "pr_number": 17375,
      "pr_title": "polygamma improvements (evaluation, real and positivity determination)",
      "pr_body": "Closes #17350. Fixes #12569.\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n- Add `_eval_evalf` to prevent evaluation when the first argument is not a nonnegative integer.\r\n- Remove `_eval_is_real` since the logic was wrong.\r\n- Update `_eval_is_positive` and `_eval_is_negative` to avoid doing comparisons with `>`.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 17350,
      "issue_title": "Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?",
      "issue_body": "mpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\r\n```",
      "issue_closed_at": "2019-08-23T06:49:24Z",
      "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c",
      "changes": [
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "class",
          "name": "polygamma",
          "code": "class polygamma(Function):\n    r\"\"\"\n    The function ``polygamma(n, z)`` returns ``log(gamma(z)).diff(n + 1)``.\n\n    It is a meromorphic function on `\\mathbb{C}` and defined as the (n+1)-th\n    derivative of the logarithm of the gamma function:\n\n    .. math::\n        \\psi^{(n)} (z) := \\frac{\\mathrm{d}^{n+1}}{\\mathrm{d} z^{n+1}} \\log\\Gamma(z).\n\n    Examples\n    ========\n\n    Several special values are known:\n\n    >>> from sympy import S, polygamma\n    >>> polygamma(0, 1)\n    -EulerGamma\n    >>> polygamma(0, 1/S(2))\n    -2*log(2) - EulerGamma\n    >>> polygamma(0, 1/S(3))\n    -log(3) - sqrt(3)*pi/6 - EulerGamma - log(sqrt(3))\n    >>> polygamma(0, 1/S(4))\n    -pi/2 - log(4) - log(2) - EulerGamma\n    >>> polygamma(0, 2)\n    1 - EulerGamma\n    >>> polygamma(0, 23)\n    19093197/5173168 - EulerGamma\n\n    >>> from sympy import oo, I\n    >>> polygamma(0, oo)\n    oo\n    >>> polygamma(0, -oo)\n    oo\n    >>> polygamma(0, I*oo)\n    oo\n    >>> polygamma(0, -I*oo)\n    oo\n\n    Differentiation with respect to x is supported:\n\n    >>> from sympy import Symbol, diff\n    >>> x = Symbol(\"x\")\n    >>> diff(polygamma(0, x), x)\n    polygamma(1, x)\n    >>> diff(polygamma(0, x), x, 2)\n    polygamma(2, x)\n    >>> diff(polygamma(0, x), x, 3)\n    polygamma(3, x)\n    >>> diff(polygamma(1, x), x)\n    polygamma(2, x)\n    >>> diff(polygamma(1, x), x, 2)\n    polygamma(3, x)\n    >>> diff(polygamma(2, x), x)\n    polygamma(3, x)\n    >>> diff(polygamma(2, x), x, 2)\n    polygamma(4, x)\n\n    >>> n = Symbol(\"n\")\n    >>> diff(polygamma(n, x), x)\n    polygamma(n + 1, x)\n    >>> diff(polygamma(n, x), x, 2)\n    polygamma(n + 2, x)\n\n    We can rewrite polygamma functions in terms of harmonic numbers:\n\n    >>> from sympy import harmonic\n    >>> polygamma(0, x).rewrite(harmonic)\n    harmonic(x - 1) - EulerGamma\n    >>> polygamma(2, x).rewrite(harmonic)\n    2*harmonic(x - 1, 3) - 2*zeta(3)\n    >>> ni = Symbol(\"n\", integer=True)\n    >>> polygamma(ni, x).rewrite(harmonic)\n    (-1)**(n + 1)*(-harmonic(x - 1, n + 1) + zeta(n + 1))*factorial(n)\n\n    See Also\n    ========\n\n    gamma: Gamma function.\n    lowergamma: Lower incomplete gamma function.\n    uppergamma: Upper incomplete gamma function.\n    loggamma: Log Gamma function.\n    digamma: Digamma function.\n    trigamma: Trigamma function.\n    sympy.functions.special.beta_functions.beta: Euler Beta function.\n\n    References\n    ==========\n\n    .. [1] https://en.wikipedia.org/wiki/Polygamma_function\n    .. [2] http://mathworld.wolfram.com/PolygammaFunction.html\n    .. [3] http://functions.wolfram.com/GammaBetaErf/PolyGamma/\n    .. [4] http://functions.wolfram.com/GammaBetaErf/PolyGamma2/\n    \"\"\"\n\n\n    def fdiff(self, argindex=2):\n        if argindex == 2:\n            n, z = self.args[:2]\n            return polygamma(n + 1, z)\n        else:\n            raise ArgumentIndexError(self, argindex)\n\n    def _eval_is_positive(self):\n        if self.args[1].is_positive and (self.args[0] > 0) == True:\n            return self.args[0].is_odd\n\n    def _eval_is_negative(self):\n        if self.args[1].is_positive and (self.args[0] > 0) == True:\n            return self.args[0].is_even\n\n    def _eval_is_real(self):\n        return self.args[0].is_real\n\n    def _eval_aseries(self, n, args0, x, logx):\n        from sympy import Order\n        if args0[1] != oo or not \\\n                (self.args[0].is_Integer and self.args[0].is_nonnegative):\n            return super(polygamma, self)._eval_aseries(n, args0, x, logx)\n        z = self.args[1]\n        N = self.args[0]\n\n        if N == 0:\n            # digamma function series\n            # Abramowitz & Stegun, p. 259, 6.3.18\n            r = log(z) - 1/(2*z)\n            o = None\n            if n < 2:\n                o = Order(1/z, x)\n            else:\n                m = ceiling((n + 1)//2)\n                l = [bernoulli(2*k) / (2*k*z**(2*k)) for k in range(1, m)]\n                r -= Add(*l)\n                o = Order(1/z**(2*m), x)\n            return r._eval_nseries(x, n, logx) + o\n        else:\n            # proper polygamma function\n            # Abramowitz & Stegun, p. 260, 6.4.10\n            # We return terms to order higher than O(x**n) on purpose\n            # -- otherwise we would not be able to return any terms for\n            #    quite a long time!\n            fac = gamma(N)\n            e0 = fac + N*fac/(2*z)\n            m = ceiling((n + 1)//2)\n            for k in range(1, m):\n                fac = fac*(2*k + N - 1)*(2*k + N - 2) / ((2*k)*(2*k - 1))\n                e0 += bernoulli(2*k)*fac/z**(2*k)\n            o = Order(1/z**(2*m), x)\n            if n == 0:\n                o = Order(1/z, x)\n            elif n == 1:\n                o = Order(1/z**2, x)\n            r = e0._eval_nseries(z, n, logx) + o\n            return (-1 * (-1/z)**N * r)._eval_nseries(x, n, logx)\n\n    @classmethod\n    def eval(cls, n, z):\n        n, z = map(sympify, (n, z))\n        from sympy import unpolarify\n\n        if n.is_integer:\n            if n.is_nonnegative:\n                nz = unpolarify(z)\n                if z != nz:\n                    return polygamma(n, nz)\n\n            if n == -1:\n                return loggamma(z)\n            else:\n                if z.is_Number:\n                    if z is S.NaN:\n                        return S.NaN\n                    elif z is S.Infinity:\n                        if n.is_Number:\n                            if n is S.Zero:\n                                return S.Infinity\n                            else:\n                                return S.Zero\n                    elif z.is_Integer:\n                        if z.is_nonpositive:\n                            return S.ComplexInfinity\n                        else:\n                            if n is S.Zero:\n                                return -S.EulerGamma + harmonic(z - 1, 1)\n                            elif n.is_odd:\n                                return (-1)**(n + 1)*factorial(n)*zeta(n + 1, z)\n\n        if n == 0:\n            if z is S.NaN:\n                return S.NaN\n            elif z.is_Rational:\n\n                p, q = z.as_numer_denom()\n\n                # only expand for small denominators to avoid creating long expressions\n                if q <= 5:\n                    return expand_func(polygamma(n, z, evaluate=False))\n\n            elif z in (S.Infinity, S.NegativeInfinity):\n                return S.Infinity\n            else:\n                t = z.extract_multiplicatively(S.ImaginaryUnit)\n                if t in (S.Infinity, S.NegativeInfinity):\n                    return S.Infinity\n\n        # TODO n == 1 also can do some rational z\n\n    def _eval_expand_func(self, **hints):\n        n, z = self.args\n\n        if n.is_Integer and n.is_nonnegative:\n            if z.is_Add:\n                coeff = z.args[0]\n                if coeff.is_Integer:\n                    e = -(n + 1)\n                    if coeff > 0:\n                        tail = Add(*[Pow(\n                            z - i, e) for i in range(1, int(coeff) + 1)])\n                    else:\n                        tail = -Add(*[Pow(\n                            z + i, e) for i in range(0, int(-coeff))])\n                    return polygamma(n, z - coeff) + (-1)**n*factorial(n)*tail\n\n            elif z.is_Mul:\n                coeff, z = z.as_two_terms()\n                if coeff.is_Integer and coeff.is_positive:\n                    tail = [ polygamma(n, z + Rational(\n                        i, coeff)) for i in range(0, int(coeff)) ]\n                    if n == 0:\n                        return Add(*tail)/coeff + log(coeff)\n                    else:\n                        return Add(*tail)/coeff**(n + 1)\n                z *= coeff\n\n        if n == 0 and z.is_Rational:\n            p, q = z.as_numer_denom()\n\n            # Reference:\n            #   Values of the polygamma functions at rational arguments, J. Choi, 2007\n            part_1 = -S.EulerGamma - pi * cot(p * pi / q) / 2 - log(q) + Add(\n                *[cos(2 * k * pi * p / q) * log(2 * sin(k * pi / q)) for k in range(1, q)])\n\n            if z > 0:\n                n = floor(z)\n                z0 = z - n\n                return part_1 + Add(*[1 / (z0 + k) for k in range(n)])\n            elif z < 0:\n                n = floor(1 - z)\n                z0 = z + n\n                return part_1 - Add(*[1 / (z0 - 1 - k) for k in range(n)])\n\n        return polygamma(n, z)\n\n    def _eval_rewrite_as_zeta(self, n, z, **kwargs):\n        if n >= S.One:\n            return (-1)**(n + 1)*factorial(n)*zeta(n + 1, z)\n        else:\n            return self\n\n    def _eval_rewrite_as_harmonic(self, n, z, **kwargs):\n        if n.is_integer:\n            if n == S.Zero:\n                return harmonic(z - 1) - S.EulerGamma\n            else:\n                return S.NegativeOne**(n+1) * factorial(n) * (zeta(n+1) - harmonic(z-1, n+1))\n\n    def _eval_as_leading_term(self, x):\n        from sympy import Order\n        n, z = [a.as_leading_term(x) for a in self.args]\n        o = Order(z, x)\n        if n == 0 and o.contains(1/x):\n            return o.getn() * log(x)\n        else:\n            return self.func(n, z)"
        },
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "function",
          "name": "fdiff",
          "class_name": "multigamma",
          "code": "def fdiff(self, argindex=2):\n        from sympy import Sum\n        if argindex == 2:\n            x, p = self.args\n            k = Dummy(\"k\")\n            return self.func(x, p)*Sum(polygamma(0, x + (1 - k)/2), (k, 1, p))\n        else:\n            raise ArgumentIndexError(self, argindex)"
        },
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "function",
          "name": "_eval_expand_func",
          "class_name": "loggamma",
          "code": "def _eval_expand_func(self, **hints):\n        from sympy import Sum\n        z = self.args[0]\n\n        if z.is_Rational:\n            p, q = z.as_numer_denom()\n            # General rational arguments (u + p/q)\n            # Split z as n + p/q with p < q\n            n = p // q\n            p = p - n*q\n            if p.is_positive and q.is_positive and p < q:\n                k = Dummy(\"k\")\n                if n.is_positive:\n                    return loggamma(p / q) - n*log(q) + Sum(log((k - 1)*q + p), (k, 1, n))\n                elif n.is_negative:\n                    return loggamma(p / q) - n*log(q) + S.Pi*S.ImaginaryUnit*n - Sum(log(k*q - p), (k, 1, -n))\n                elif n.is_zero:\n                    return loggamma(p / q)\n\n        return self"
        }
      ]
    }
  ]
}