{
  "original_problem": {
    "instance_id": "sympy__sympy-11870",
    "repo": "sympy/sympy",
    "created_at": "2016-11-17T21:36:03Z",
    "problem_statement": "simplifying exponential -> trig identities\n```\r\nf = 1 / 2 * (-I*exp(I*k) + I*exp(-I*k))\r\ntrigsimp(f)\r\n```\r\n\r\nIdeally, this would yield `sin(k)`. Is there a way to do this?\r\n\r\nAs a corollary, it would be awesome if \r\n\r\n```\r\nf = 1 / 2 / k* (-I*exp(I*k) + I*exp(-I*k))\r\ntrigsimp(f)\r\n```\r\n\r\ncould yield `sinc(k)`. Thank you for your consideration!\n",
    "patch": "diff --git a/sympy/functions/elementary/trigonometric.py b/sympy/functions/elementary/trigonometric.py\n--- a/sympy/functions/elementary/trigonometric.py\n+++ b/sympy/functions/elementary/trigonometric.py\n@@ -16,6 +16,8 @@\n from sympy.sets.sets import FiniteSet\n from sympy.utilities.iterables import numbered_symbols\n from sympy.core.compatibility import range\n+from sympy.core.relational import Ne\n+from sympy.functions.elementary.piecewise import Piecewise\n \n ###############################################################################\n ########################## TRIGONOMETRIC FUNCTIONS ############################\n@@ -400,6 +402,9 @@ def _eval_rewrite_as_csc(self, arg):\n     def _eval_rewrite_as_sec(self, arg):\n         return 1 / sec(arg - S.Pi / 2, evaluate=False)\n \n+    def _eval_rewrite_as_sinc(self, arg):\n+        return arg*sinc(arg)\n+\n     def _eval_conjugate(self):\n         return self.func(self.args[0].conjugate())\n \n@@ -1789,7 +1794,7 @@ def _eval_rewrite_as_jn(self, arg):\n         return jn(0, arg)\n \n     def _eval_rewrite_as_sin(self, arg):\n-        return sin(arg) / arg\n+        return Piecewise((sin(arg)/arg, Ne(arg, 0)), (1, True))\n \n \n ###############################################################################\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_8626",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves iterator handling in a physics module, unrelated to symbolic simplification or mathematical identity handling."
      },
      {
        "idx": 2,
        "id": "similar_6988",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve inconsistencies in mathematical simplification functions within SymPy, focusing on correct handling of mathematical identities."
      },
      {
        "idx": 3,
        "id": "similar_10020",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about recursion depth in complex number handling, not directly related to symbolic simplification or identity transformation."
      },
      {
        "idx": 4,
        "id": "similar_8008",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves symbolic integration and assumptions, which are not directly related to the simplification of exponential to trigonometric identities."
      },
      {
        "idx": 5,
        "id": "similar_11102",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about representation and printing of series, not about symbolic simplification or identity transformation."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "bug in physics/mechanics/lagrange.py",
        "issue_body": "When providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n",
        "issue_id": 8626,
        "pr_number": 8627,
        "pr_title": "Bug Fix #8626",
        "pr_body": "Let me know if a test case is needed\n",
        "issue_closed_at": "2015-01-06T16:57:16Z",
        "base_commit": "65f7c8c2c9c1927eaa8520c4ce06864f93a20ad1"
      },
      "summary": "### Summary:\nThis issue is related to a bug in the software module responsible for handling Lagrangian mechanics calculations within a physics library, specifically in the `lagrange.py` file. The problem occurs when a list of forces, known as `forcelist`, contains more than one force. The core issue is that not all forces are processed because the iterator designed to parse this list is prematurely exhausted during its first use in a loop. As a result, subsequent forces are ignored, leading to incomplete calculations. The affected component is a function within the `LagrangesMethod` class that forms Lagrange's equations. The severity of this issue could be significant in contexts where accurate and complete force calculations are critical for the correct modeling of mechanical systems. The technical detail to note is the improper handling of iterators, which is a common pitfall in programming, leading to partial data processing. A proposed fix involves modifying the code to ensure that all elements of the `forcelist` are appropriately handled, thereby rectifying the calculation errors.",
      "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: bug in physics/mechanics/lagrange.py\n\nBody:\nWhen providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\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/physics/mechanics/lagrange.py\n  function: LagrangesMethod.form_lagranges_equations\n"
    },
    {
      "similar_issue": {
        "issue_title": "expand_log(exp(x), force=True) should give x",
        "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   ⎛ x⎞\nlog⎝ℯ ⎠\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x⋅log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
        "issue_id": 6988,
        "pr_number": 8548,
        "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
        "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x⋅log(y)\n```\n",
        "issue_closed_at": "2014-12-03T13:34:14Z",
        "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023"
      },
      "summary": "### Summary:\n\nThis issue involves the incorrect behavior of the `expand_log` function within the SymPy library, a Python library for symbolic mathematics. The problem specifically arises when using `expand_log` with expressions that involve exponential functions and logarithms, where the expected mathematical simplification does not occur as anticipated.\n\n1. **Problem Description:**\n   The `expand_log` function is expected to simplify logarithmic expressions involving exponentials correctly. However, an inconsistency is observed where applying `expand_log` to `log(exp(x))` does not return `x` as expected when the `force` parameter is set to `True`.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - The expression `expand_log(log(exp(x)), force=True)` returns `log(e^x)` instead of the simplified result `x`.\n   - Conversely, the expression `expand_log(log(y**(x)), force=True)` correctly simplifies to `x * log(y)`, indicating inconsistent behavior in similar mathematical contexts.\n\n3. **Affected Components or Systems:**\n   The issue is localized within the SymPy library, specifically affecting the `log._eval_expand_log` function in the `sympy/functions/elementary/exponential.py` module. This function is responsible for expanding logarithmic expressions.\n\n4. **Potential Impact or Severity:**\n   This issue may lead to incorrect mathematical computations and outputs when users rely on the `expand_log` function to simplify expressions involving exponentials and logarithms. While it may not cause critical system failures, it can affect the accuracy of symbolic mathematics calculations, potentially impacting research or applications dependent on correct symbolic manipulation.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The function `expand_log` is designed to simplify logarithmic expressions by expanding them based on certain rules. The `force=True` parameter is intended to ensure such expansions occur even if they might not be typically performed.\n   - The discrepancy in behavior suggests a need for consistency in the handling of mathematical identities, particularly those involving exponentials and logarithms, within the symbolic computation framework provided by SymPy.",
      "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: expand_log(exp(x), force=True) should give x\n\nBody:\n```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   ⎛ x⎞\nlog⎝ℯ ⎠\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x⋅log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\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/elementary/exponential.py\n  function: log._eval_expand_log\n"
    },
    {
      "similar_issue": {
        "issue_title": "oo**I raises RunTimeError",
        "issue_body": "```\ngxyd@swap:~/Public/sympy$ python3.4\nPython 3.4.3 (default, Jul 28 2015, 18:20:59) \n[GCC 4.8.4] on linux\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\n>>> from sympy import *\n>>> oo**I\nTraceback (most recent call last):\n  File \"<stdin>\", line 1, in <module>\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\nRuntimeError: maximum recursion depth exceeded while calling a Python object\n```\n\nSome part of traceback has been removed to keep it short\n",
        "issue_id": 10020,
        "pr_number": 10029,
        "pr_title": "oo**e for non-real complex `e` handling",
        "pr_body": "fixes #10020\n",
        "issue_closed_at": "2015-12-08T15:49:18Z",
        "base_commit": "41fc8f5a4dabd350f2f23a4aef53db728ca8ee0d"
      },
      "summary": "### Summary:\n\nThis issue is related to a computational error in the SymPy library, specifically when attempting to compute the power of infinity (`oo`) raised to an imaginary unit (`I`). The problem is characterized by a `RuntimeError` due to maximum recursion depth being exceeded, which indicates a logical flaw in the handling of certain mathematical expressions involving complex numbers and infinity within the library.\n\n1. **Problem description in general terms:**\n   The problem arises when evaluating expressions involving powers of infinity combined with complex numbers, leading to a recursive loop that exceeds Python's maximum recursion depth limit.\n\n2. **Key symptoms and behaviors observed:**\n   The primary symptom observed is a `RuntimeError` with the message \"maximum recursion depth exceeded while calling a Python object.\" This error is triggered during the computation of `oo**I` within the SymPy environment, indicating an infinite recursive call chain.\n\n3. **Affected components or systems:**\n   The issue affects the core computational components of the SymPy library, specifically in the modules handling numbers and power operations. The affected components include:\n   - `sympy/core/numbers.py`: The `_eval_power` method in the `ImaginaryUnit` class.\n   - `sympy/core/power.py`: The `Pow` class managing power operations.\n\n4. **Potential impact or severity:**\n   The impact of this issue could be significant for users relying on SymPy for symbolic computation involving complex numbers and infinity. It may lead to application crashes or incorrect computation results, thus affecting the reliability and robustness of mathematical computations in SymPy.\n\n5. **Any relevant technical details abstracted for broader understanding:**\n   The technical root of the issue lies in the recursive evaluation logic when handling powers involving infinity. The recursive calls fail to reach a termination condition, looping indefinitely until the recursion limit is hit. This necessitates revisiting and possibly refactoring the logic in the `ImaginaryUnit._eval_power` method and the `Pow` class to handle such expressions correctly and efficiently.",
      "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: oo**I raises RunTimeError\n\nBody:\n```\ngxyd@swap:~/Public/sympy$ python3.4\nPython 3.4.3 (default, Jul 28 2015, 18:20:59) \n[GCC 4.8.4] on linux\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\n>>> from sympy import *\n>>> oo**I\nTraceback (most recent call last):\n  File \"<stdin>\", line 1, in <module>\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\nRuntimeError: maximum recursion depth exceeded while calling a Python object\n```\n\nSome part of traceback has been removed to keep it short\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/numbers.py\n  function: ImaginaryUnit._eval_power\n  function: ImaginaryUnit._eval_power\n  function: ImaginaryUnit._eval_power\n\nsympy/core/power.py\n  class: Pow\n  class: Pow\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:\n\nThis issue is centered around a test failure in the `meijerint` module of the SymPy library, which arose after merging a code pull request identified as #7920. The test failure is consistently reproducible in the Python 2.7 environment, indicating a deterministic problem rather than an intermittent one.\n\n1. **Problem Description in General Terms**:\n   The primary problem involves a test case failure related to the symbolic integration functionality in SymPy, specifically within the `meijerint` component. The failure occurs when validating the correctness of definite integrals computed using the Meijer G-function representation.\n\n2. **Key Symptoms and Behaviors Observed**:\n   - The test script `test_meijerint.py` encounters an assertion error, where the expected output of a definite integral does not match the computed result.\n   - With caching enabled, the error manifests as an `InconsistentAssumptions` exception, suggesting a discrepancy between assumed properties and actual computations.\n   - Disabling caching leads to a different error, a `RuntimeError` due to maximum recursion depth being exceeded, indicating potential issues with recursive function calls or symbolic expression handling.\n\n3. **Affected Components or Systems**:\n   The affected components are primarily within the SymPy symbolic mathematics library, particularly:\n   - `sympy.integrals.meijerint`: Functions for handling Meijer G-function based integrals.\n   - `sympy.simplify.hyperexpand`: Functions for expanding hypergeometric expressions.\n   - `sympy.core.assumptions`: The module managing assumptions about mathematical properties.\n   - `sympy.core.mul`: Handling of multiplication operations within symbolic expressions.\n   - `sympy.functions.elementary.exponential`: Functions related to exponential expressions.\n\n4. **Potential Impact or Severity**:\n   The issue has a significant impact on the reliability of the symbolic integration capabilities of SymPy, which could affect users relying on accurate mathematical computations in applications involving symbolic mathematics. The reproducibility of the failure across environments and the presence of multiple error types indicate a critical need for resolution.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   - The problem relates to the handling of assumptions and properties of symbolic expressions during integration and simplification processes. \n   - The test failures suggest potential issues in the logic of evaluating mathematical properties, such as positivity and boundedness, which are crucial in symbolic computations.\n   - The recursion depth error implies challenges in expression handling that require optimization or reworking of recursive logic to prevent stack overflow.\n\nOverall, the problem necessitates a comprehensive review and correction of the logic within the affected modules to ensure accurate and efficient computation of symbolic integrals in SymPy. The fixed code elements suggest that the patch addresses issues within the multiplication operations, logarithmic evaluations, and polynomial composition functions.",
      "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": "fps should print as a formal power series",
        "issue_body": "When I first used `fps`, I didn't realize it really was a formal power series as it claims to be, because it prints like a normal series (same as `series`)\n\n```\nIn [21]: fps(sin(x))\nOut[21]:\n     3     5\n    x     x     ⎛ 6⎞\nx - ── + ─── + O⎝x ⎠\n    6    120\n```\n\nBut if you look at the string form, you see\n\n```\nIn [22]: print(fps(sin(x)))\nFormalPowerSeries(sin(x), x, 0, 1, (SeqFormula(Piecewise(((-1/4)**(_k/2 - 1/2)/(RisingFactorial(3/2, _k/2 - 1/2)*factorial(_k/2 - 1/2)), Eq(Mod(_k, 2), 1)), (0, True)), (_k, 2, oo)), SeqFormula(x**_k, (_k, 0, oo)), x))\n```\n\nThat is, it really does represent it as the formula `Sum((-1)**n/factorial(2*n + 1)*x**n, (n, 0, oo))` (albiet, not simplified). It out to print it like this, so you can see that that's what it's working with.\n\nSide question: if you enter something it can't compute, it just returns the function\n\n```\nIn [25]: fps(tan(x))\nOut[25]: tan(x)\n```\n\nIs that intentional? It seems like it ought to raise an exception in that case. \n\n@leosartaj \n",
        "issue_id": 11102,
        "pr_number": 11384,
        "pr_title": "Update formal power series printing",
        "pr_body": "fixes #11102 \nping @asmeurer \n",
        "issue_closed_at": "2016-07-14T22:47:58Z",
        "base_commit": "496e776108957d8c049cbef49522cef4c1955e2f"
      },
      "summary": "### Summary:\nThis issue pertains to the discrepancy in the representation of formal power series (fps) within a symbolic mathematics library, specifically focusing on how these series are printed or displayed to the user. \n\n1. **Problem Description:**\n   The issue arises from the `fps` function, which is expected to output a series in the formal power series notation. However, users have reported that it prints in a format similar to a regular mathematical series, which does not clearly convey its nature as a formal power series. This inconsistency can lead to confusion for users who rely on the output to understand the underlying mathematical representation.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - The output of the `fps` function looks identical to that of a regular series, which masks its intended representation as a formal power series.\n   - When examined more closely (e.g., using the string form), the series is indeed represented as a formal power series, but this is not evident in the standard print output.\n   - In cases where the function cannot compute a formal power series, it defaults to returning the function itself without raising an exception, which could mislead users into thinking the computation was successful.\n\n3. **Affected Components or Systems:**\n   The issue affects the printing modules within the library, specifically the functionality responsible for rendering mathematical series in both LaTeX and pretty-print formats, as indicated by the changes in `sympy/printing/latex.py` and `sympy/printing/pretty/pretty.py`.\n\n4. **Potential Impact or Severity:**\n   The impact is primarily on user experience and understanding. Users may be misled by the printed output, potentially leading to misinterpretations of mathematical results. Although the severity is not critical in terms of system functionality, it is significant in terms of clarity and usability for end-users working with formal power series.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The technical root of the issue lies in the way the library's printing functions handle and display formal power series. The intended behavior is for the `fps` output to clearly indicate its structure and parameters as a formal power series, rather than defaulting to standard series notation. Additionally, handling cases where computation is not feasible by providing informative feedback (such as exceptions) is crucial for improving user guidance and error management.",
      "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: fps should print as a formal power series\n\nBody:\nWhen I first used `fps`, I didn't realize it really was a formal power series as it claims to be, because it prints like a normal series (same as `series`)\n\n```\nIn [21]: fps(sin(x))\nOut[21]:\n     3     5\n    x     x     ⎛ 6⎞\nx - ── + ─── + O⎝x ⎠\n    6    120\n```\n\nBut if you look at the string form, you see\n\n```\nIn [22]: print(fps(sin(x)))\nFormalPowerSeries(sin(x), x, 0, 1, (SeqFormula(Piecewise(((-1/4)**(_k/2 - 1/2)/(RisingFactorial(3/2, _k/2 - 1/2)*factorial(_k/2 - 1/2)), Eq(Mod(_k, 2), 1)), (0, True)), (_k, 2, oo)), SeqFormula(x**_k, (_k, 0, oo)), x))\n```\n\nThat is, it really does represent it as the formula `Sum((-1)**n/factorial(2*n + 1)*x**n, (n, 0, oo))` (albiet, not simplified). It out to print it like this, so you can see that that's what it's working with.\n\nSide question: if you enter something it can't compute, it just returns the function\n\n```\nIn [25]: fps(tan(x))\nOut[25]: tan(x)\n```\n\nIs that intentional? It seems like it ought to raise an exception in that case. \n\n@leosartaj \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/printing/latex.py\n  function: LatexPrinter._print_FourierSeries\n\nsympy/printing/pretty/pretty.py\n  function: PrettyPrinter._print_FourierSeries\n"
    }
  ]
}