{
  "original_problem": {
    "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───\r\n│x│\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"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_15518",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with handling undefined derivatives, which is unrelated to rewriting expressions with zero handling."
      },
      {
        "idx": 2,
        "id": "similar_9184",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on limit evaluation for Bell numbers, which does not relate to expression rewriting or zero handling."
      },
      {
        "idx": 3,
        "id": "similar_17142",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves nondeterministic behavior due to assumptions, which is not directly related to expression rewriting or zero handling."
      },
      {
        "idx": 4,
        "id": "similar_8008",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about test failures due to recursion and assumptions, unrelated to expression rewriting or zero handling."
      },
      {
        "idx": 5,
        "id": "similar_17350",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves type errors with non-integer arguments, which does not relate to expression rewriting or zero handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "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_id": 15518,
        "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_closed_at": "2018-11-24T11:36:42Z",
        "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d"
      },
      "summary": "### Summary: This issue is related to the handling of higher-order derivatives in the SymPy library, specifically when attempting to evaluate derivatives for functions that do not have explicitly defined derivatives. The problem manifests as an exception being raised when such operations are attempted, indicating a flaw in the code's ability to gracefully manage these scenarios. The key symptom observed is an AttributeError when trying to call a non-existent method on a NoneType object, which occurs because the function lacks an explicit derivative. This issue impacts the derivative evaluation subsystem within the SymPy library, particularly affecting the `Basic._eval_derivative_n_times` function. The potential impact of this issue is moderately significant as it affects the reliability of derivative calculations for certain mathematical expressions, which could hinder users relying on SymPy for symbolic mathematics computations. The resolution involves ensuring that the system returns an appropriate symbolic representation of the derivative instead of failing with an exception.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception\n\nBody:\nThis 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/basic.py\n  function: Basic._eval_derivative_n_times\n"
    },
    {
      "similar_issue": {
        "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_id": 9184,
        "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_closed_at": "2017-10-13T04:35:13Z",
        "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0"
      },
      "summary": "### Summary:\nThis issue pertains to a mathematical computation in the Sympy library, specifically concerning the evaluation of the limit of Bell numbers as the input approaches infinity. The problem manifests when the function `bell(n).limit(n, oo)` returns an unevaluated expression `bell(oo)` instead of the expected result, infinity. Bell numbers, which count the number of partitions of a set, should logically approach infinity as the input becomes infinitely large. This issue aligns with previous corrections made to similar limit evaluations for other mathematical sequences, such as Fibonacci and Lucas numbers, indicating a broader requirement for consistency in the library's handling of infinite limits. The problem affects the combinatorial functions within Sympy, specifically the evaluation logic for Bell numbers. The impact is primarily on users relying on accurate limit evaluations for combinatorial functions, which can be critical for mathematical and scientific computations. The report suggests that a fix has been implemented in the Sympy codebase, specifically within the `bell._bell_incomplete_poly` function, to address this discrepancy.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: bell(n).limit(n, oo) should be oo rather than bell(oo)\n\nBody:\n`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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/combinatorial/numbers.py\n  function: bell._bell_incomplete_poly\n"
    },
    {
      "similar_issue": {
        "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_id": 17142,
        "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_closed_at": "2020-01-14T01:45:34Z",
        "base_commit": "f119ab5d30e8b373dc8956d41b7c11e53c140209"
      },
      "summary": "### Summary:\nThis issue pertains to a nondeterministic behavior in the SymPy library when invoking the `as_real_imag()` method on certain complex expressions. The problem is characterized by inconsistent behaviors where the method sometimes successfully returns a tuple representation of the real and imaginary parts of an expression, but at other times raises an `InconsistentAssumptions` exception. This exception arises due to mismatched or conflicting assumptions about the nature of the expression's components, such as their rationality or extended reality.\n\nKey symptoms include successful execution in some instances and exception traces in others, specifically pointing to assumption handling within the SymPy core library. The affected components primarily involve the assumption framework of the SymPy library, particularly in functions related to evaluating the properties of mathematical expressions like `atan` and `log`.\n\nThe potential impact is moderate, affecting users who rely on deterministic behavior from the `as_real_imag()` method for complex expressions. This nondeterminism could lead to unexpected application behavior or crashes in systems utilizing these mathematical computations. The severity is amplified by the complexity and depth of the exception trace, indicating a potentially intricate issue within the assumption evaluation logic.\n\nRelevant technical details abstracted for broader understanding include the role of the `as_real_imag()` method in decomposing expressions, the reliance on assumptions to evaluate expression properties, and the potential for conflicts in these assumptions leading to the observed exceptions. The fix involves adjustments in the SymPy core, particularly in the `Mul._eval_is_irrational` function, which likely addresses the flawed assumption logic contributing to the error.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Nondeterministic exception from (atan(I/(I + I*tan(1)))).as_real_imag() (InconsistentAssumptions)\n\nBody:\nSometimes 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)`.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/mul.py\n  function: Mul._eval_is_irrational\n"
    },
    {
      "similar_issue": {
        "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_id": 8008,
        "pr_number": 8044,
        "pr_title": "simplify Mul._eval_is_negative routine",
        "pr_body": "",
        "issue_closed_at": "2014-09-16T15:27:52Z",
        "base_commit": "3d2a26cb368ab2233dc73c2857ab0c6ca7e95f9e"
      },
      "summary": "### Summary:\nThis issue is a test failure that arises in the `meijerint` integration module of the SymPy library, specifically after merging a particular pull request (#7920). The failure is consistently reproducible on Python 2.7, with the test case `test_meijerint` encountering exceptions related to assumption handling and recursion depth when executed with both caching enabled and disabled. The failure manifests as assertion errors and runtime errors due to inconsistent assumptions and maximum recursion depth being exceeded. The affected components mainly include the `sympy/integrals/meijerint.py`, `sympy/simplify/hyperexpand.py`, and `sympy/core/assumptions.py`, indicating issues within the integration and simplification logic, particularly around handling complex expressions and their assumptions. The severity of this issue is moderate, as it affects the accuracy and reliability of symbolic integration within SymPy, potentially impacting users relying on the `meijerint` functionality for complex mathematical computations. Relevant technical details include the recursion and assumption logic within the core and simplifying modules, which likely necessitate a review and potential refactoring to prevent such depth and consistency issues in mathematical evaluations.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Test failure in meijerint after merging #7920\n\nBody:\nMore 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/mul.py\n  function: Mul._eval_is_algebraic_expr\n  function: Mul._eval_is_positive\n  function: Mul._eval_is_odd\n\nsympy/functions/elementary/exponential.py\n  function: log._eval_is_bounded\n\nsympy/polys/numberfields.py\n  function: _minpoly_compose\n"
    },
    {
      "similar_issue": {
        "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_id": 17350,
        "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_closed_at": "2019-08-23T06:49:24Z",
        "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c"
      },
      "summary": "### Summary:\nThis issue is related to the behavior of the `polygamma` function within the SymPy library when it is invoked with a non-integer argument. The core problem is that while SymPy allows non-integer first arguments for its `polygamma` function, this leads to a host of errors and exceptions when attempting to perform computations involving such objects. Specifically, the errors manifest as type-related exceptions and key errors during attempts to evaluate or rewrite expressions involving `polygamma` with non-integer arguments.\n\nKey symptoms and behaviors observed include multiple traceback errors:\n- `KeyError` related to assumptions like 'zero', 'finite', and 'extended_positive' indicating failures in attribute retrieval or evaluation.\n- `TypeError` indicating inappropriate type conversion or invalid comparison when the function is invoked with non-integer values, particularly complex numbers.\n\nAffected components involve:\n- The `polygamma` function in SymPy's special gamma functions.\n- Various evaluation and assumption handling mechanisms in SymPy's core.\n\nThe potential impact of the issue is significant, particularly for users who may inadvertently pass non-integer arguments to `polygamma`, resulting in runtime errors and incorrect computations. This could lead to incorrect mathematical results or application crashes, thus affecting the reliability and robustness of applications relying on SymPy for symbolic mathematics.\n\nRelevant technical details abstracted for broader understanding include:\n- SymPy's current implementation does not restrict `polygamma` to integer arguments, unlike mpmath, which causes inconsistencies and errors.\n- The errors are primarily due to type mismatches and improper handling of complex numbers within the function's logic.\n- The patch likely addresses these issues by enforcing proper input validation and type handling, preventing invalid operations on unsupported argument types.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?\n\nBody:\nmpmath'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```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/special/gamma_functions.py\n  class: polygamma\n  function: multigamma.fdiff\n  function: loggamma._eval_expand_func\n"
    }
  ]
}