{
  "original_problem": {
    "instance_id": "sympy__sympy-14308",
    "repo": "sympy/sympy",
    "created_at": "2018-02-22T16:54:06Z",
    "problem_statement": "vectors break pretty printing\n```py\r\nIn [1]: from sympy.vector import *\r\n\r\nIn [2]: e = CoordSysCartesian('e')\r\n\r\nIn [3]: (x/y)**t*e.j\r\nOut[3]:\r\n⎛   t⎞ e_j\r\n⎜⎛x⎞ e_j ⎟\r\n⎜⎜─⎟ ⎟\r\n⎝⎝y⎠ ⎠\r\n```\r\n\r\nAlso, when it does print correctly, the baseline is wrong (it should be centered). \n",
    "patch": "diff --git a/sympy/printing/pretty/pretty.py b/sympy/printing/pretty/pretty.py\n--- a/sympy/printing/pretty/pretty.py\n+++ b/sympy/printing/pretty/pretty.py\n@@ -931,26 +931,49 @@ def _print_BasisDependent(self, expr):\n         #Fixing the newlines\n         lengths = []\n         strs = ['']\n+        flag = []\n         for i, partstr in enumerate(o1):\n+            flag.append(0)\n             # XXX: What is this hack?\n             if '\\n' in partstr:\n                 tempstr = partstr\n                 tempstr = tempstr.replace(vectstrs[i], '')\n-                tempstr = tempstr.replace(u'\\N{RIGHT PARENTHESIS UPPER HOOK}',\n-                                          u'\\N{RIGHT PARENTHESIS UPPER HOOK}'\n-                                          + ' ' + vectstrs[i])\n+                if u'\\N{right parenthesis extension}' in tempstr:   # If scalar is a fraction\n+                    for paren in range(len(tempstr)):\n+                        flag[i] = 1\n+                        if tempstr[paren] == u'\\N{right parenthesis extension}':\n+                            tempstr = tempstr[:paren] + u'\\N{right parenthesis extension}'\\\n+                                         + ' '  + vectstrs[i] + tempstr[paren + 1:]\n+                            break\n+                elif u'\\N{RIGHT PARENTHESIS LOWER HOOK}' in tempstr:\n+                    flag[i] = 1\n+                    tempstr = tempstr.replace(u'\\N{RIGHT PARENTHESIS LOWER HOOK}',\n+                                        u'\\N{RIGHT PARENTHESIS LOWER HOOK}'\n+                                        + ' ' + vectstrs[i])\n+                else:\n+                    tempstr = tempstr.replace(u'\\N{RIGHT PARENTHESIS UPPER HOOK}',\n+                                        u'\\N{RIGHT PARENTHESIS UPPER HOOK}'\n+                                        + ' ' + vectstrs[i])\n                 o1[i] = tempstr\n+\n         o1 = [x.split('\\n') for x in o1]\n-        n_newlines = max([len(x) for x in o1])\n-        for parts in o1:\n-            lengths.append(len(parts[0]))\n+        n_newlines = max([len(x) for x in o1])  # Width of part in its pretty form\n+\n+        if 1 in flag:                           # If there was a fractional scalar\n+            for i, parts in enumerate(o1):\n+                if len(parts) == 1:             # If part has no newline\n+                    parts.insert(0, ' ' * (len(parts[0])))\n+                    flag[i] = 1\n+\n+        for i, parts in enumerate(o1):\n+            lengths.append(len(parts[flag[i]]))\n             for j in range(n_newlines):\n                 if j+1 <= len(parts):\n                     if j >= len(strs):\n                         strs.append(' ' * (sum(lengths[:-1]) +\n                                            3*(len(lengths)-1)))\n-                    if j == 0:\n-                        strs[0] += parts[0] + ' + '\n+                    if j == flag[i]:\n+                        strs[flag[i]] += parts[flag[i]] + ' + '\n                     else:\n                         strs[j] += parts[j] + ' '*(lengths[-1] -\n                                                    len(parts[j])+\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_10472",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve alignment problems in pretty-printing, requiring adjustments in rendering logic to ensure correct visual representation."
      },
      {
        "idx": 2,
        "id": "similar_10979",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about performance bottlenecks, which is unrelated to the pretty-printing alignment problem in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_13711",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about a missing method due to library changes, unrelated to pretty-printing or alignment issues."
      },
      {
        "idx": 4,
        "id": "similar_13598",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves handling missing configuration settings, which does not relate to pretty-printing or alignment problems."
      },
      {
        "idx": 5,
        "id": "similar_6988",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about symbolic simplification errors, unrelated to pretty-printing or alignment issues."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "pprint should align the middle of the matrix to the baseline?",
        "issue_body": "Consider the current behaviour, where operators align with the top of the matrix:\n\n```\n>>> Z = Matrix(5,5, lambda i,j: i+j)\n>>> pprint(MatMul(2,Z))\n2⋅⎡0  1  2  3  4⎤\n  ⎢             ⎥\n  ⎢1  2  3  4  5⎥\n  ⎢             ⎥\n  ⎢2  3  4  5  6⎥\n  ⎢             ⎥\n  ⎢3  4  5  6  7⎥\n  ⎢             ⎥\n  ⎣4  5  6  7  8⎦\n>>> pprint(MatAdd(Z,Z))\n⎡0  1  2  3  4⎤ + ⎡0  1  2  3  4⎤\n⎢             ⎥   ⎢             ⎥\n⎢1  2  3  4  5⎥   ⎢1  2  3  4  5⎥\n⎢             ⎥   ⎢             ⎥\n⎢2  3  4  5  6⎥   ⎢2  3  4  5  6⎥\n⎢             ⎥   ⎢             ⎥\n⎢3  4  5  6  7⎥   ⎢3  4  5  6  7⎥\n⎢             ⎥   ⎢             ⎥\n⎣4  5  6  7  8⎦   ⎣4  5  6  7  8⎦\n```\n\nThis looks poor, but I figured it might be the desired behaviour...\n\nHere's the example that makes me think its wrong:\n\n```\n>>> pprint(sin((1+1/x)/(1+1/y)) + det(MatMul(2,Z)))\n   ⎛    1⎞                       \n   ⎜1 + ─⎟                       \n   ⎜    x⎟                       \nsin⎜─────⎟ + 32⋅│⎡0  1  2  3  4⎤│\n   ⎜    1⎟      │⎢             ⎥│\n   ⎜1 + ─⎟      │⎢1  2  3  4  5⎥│\n   ⎝    y⎠      │⎢             ⎥│\n                │⎢2  3  4  5  6⎥│\n                │⎢             ⎥│\n                │⎢3  4  5  6  7⎥│\n                │⎢             ⎥│\n                │⎣4  5  6  7  8⎦│\n```\n\nHere's how I think it should work, using the proposed #10423:\n\n```\npprint(sin((1+1/x)/y) + Trace(Z))\n               ⎛⎡0  1  2  3  4⎤⎞\n   ⎛    1⎞     ⎜⎢             ⎥⎟\n   ⎜1 + ─⎟     ⎜⎢1  2  3  4  5⎥⎟\n   ⎜    x⎟     ⎜⎢             ⎥⎟\nsin⎜─────⎟ + tr⎜⎢2  3  4  5  6⎥⎟\n   ⎝  y  ⎠     ⎜⎢             ⎥⎟\n               ⎜⎢3  4  5  6  7⎥⎟\n               ⎜⎢             ⎥⎟\n               ⎝⎣4  5  6  7  8⎦⎠\n```\n\nwhere note the `sin` alignment is by-design, and (relevant to this bug) the `+` and `tr` operator line up with `sin`.\n\nAt least, det, MatAdd, MatMul, MatPow would need fixed, maybe others I haven't thought of.\n",
        "issue_id": 10472,
        "pr_number": 11947,
        "pr_title": "aligned middle of matrix with baseline",
        "pr_body": "**Previous Output**: \r\n\r\n```\r\n>>> Z = Matrix(5,5, lambda i,j: i+j)\r\n>>> pprint(MatMul(2,Z))\r\n2⋅⎡0  1  2  3  4⎤\r\n  ⎢             ⎥\r\n  ⎢1  2  3  4  5⎥\r\n  ⎢             ⎥\r\n  ⎢2  3  4  5  6⎥\r\n  ⎢             ⎥\r\n  ⎢3  4  5  6  7⎥\r\n  ⎢             ⎥\r\n  ⎣4  5  6  7  8⎦\r\n```\r\n\r\n**Output after this PR**:\r\n```\r\n>>> Z = Matrix(5,5, lambda i,j: i+j)\r\n>>> pprint(MatMul(2,Z))\r\n  ⎡0  1  2  3  4⎤\r\n  ⎢             ⎥\r\n  ⎢1  2  3  4  5⎥\r\n  ⎢             ⎥\r\n2.⎢2  3  4  5  6⎥\r\n  ⎢             ⎥\r\n  ⎢3  4  5  6  7⎥\r\n  ⎢             ⎥\r\n  ⎣4  5  6  7  8⎦\r\n```\r\nFixes #10472 . ",
        "issue_closed_at": "2016-12-22T06:52:11Z",
        "base_commit": "9a724a42c033c1aae97064947a0f44ec3b922d73"
      },
      "summary": "### Summary:\nThis issue concerns the alignment of mathematical expression components when printed using the `pprint` function within a software library, specifically regarding how operators are aligned in relation to matrices. The current behavior results in operators aligning with the top of matrices, which can create a visually unappealing and potentially confusing output. This misalignment becomes particularly evident when complex expressions involve both operators and matrices, where the expected behavior would have operators aligned centrally or with the baseline of the matrix.\n\nKey symptoms and behaviors observed include the misalignment of operators like `+`, `tr` (trace), and others when printed alongside matrices, leading to inconsistent and potentially misleading visual representations of expressions. The issue was observed in operations such as matrix multiplication (`MatMul`), matrix addition (`MatAdd`), and determinant calculations (`det`), among others.\n\nThe affected components include several modules related to matrix expressions and pretty-printing within the codebase, specifically functions responsible for merging matrix expressions and determining how matrix contents are printed. This issue primarily affects the visual representation of mathematical expressions, which can impact the readability and interpretability of printed outputs for users.\n\nThe potential impact is significant for users relying on the `pprint` function for clear and accurate presentation of mathematical expressions, as misaligned operators can lead to misunderstandings or misinterpretations of the intended calculations. The severity is moderate, as it affects the usability and effectiveness of the library's output but does not impact the underlying computational accuracy.\n\nRelevant technical details include the need to adjust the alignment logic within specific functions responsible for rendering matrix expressions, ensuring that operators align consistently with the baseline of the matrix. The changes required involve modifying the `merge_explicit` function in multiple matrix expression modules and adjusting the pretty-printing logic within the `PrettyPrinter` class.",
      "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: pprint should align the middle of the matrix to the baseline?\n\nBody:\nConsider the current behaviour, where operators align with the top of the matrix:\n\n```\n>>> Z = Matrix(5,5, lambda i,j: i+j)\n>>> pprint(MatMul(2,Z))\n2⋅⎡0  1  2  3  4⎤\n  ⎢             ⎥\n  ⎢1  2  3  4  5⎥\n  ⎢             ⎥\n  ⎢2  3  4  5  6⎥\n  ⎢             ⎥\n  ⎢3  4  5  6  7⎥\n  ⎢             ⎥\n  ⎣4  5  6  7  8⎦\n>>> pprint(MatAdd(Z,Z))\n⎡0  1  2  3  4⎤ + ⎡0  1  2  3  4⎤\n⎢             ⎥   ⎢             ⎥\n⎢1  2  3  4  5⎥   ⎢1  2  3  4  5⎥\n⎢             ⎥   ⎢             ⎥\n⎢2  3  4  5  6⎥   ⎢2  3  4  5  6⎥\n⎢             ⎥   ⎢             ⎥\n⎢3  4  5  6  7⎥   ⎢3  4  5  6  7⎥\n⎢             ⎥   ⎢             ⎥\n⎣4  5  6  7  8⎦   ⎣4  5  6  7  8⎦\n```\n\nThis looks poor, but I figured it might be the desired behaviour...\n\nHere's the example that makes me think its wrong:\n\n```\n>>> pprint(sin((1+1/x)/(1+1/y)) + det(MatMul(2,Z)))\n   ⎛    1⎞                       \n   ⎜1 + ─⎟                       \n   ⎜    x⎟                       \nsin⎜─────⎟ + 32⋅│⎡0  1  2  3  4⎤│\n   ⎜    1⎟      │⎢             ⎥│\n   ⎜1 + ─⎟      │⎢1  2  3  4  5⎥│\n   ⎝    y⎠      │⎢             ⎥│\n                │⎢2  3  4  5  6⎥│\n                │⎢             ⎥│\n                │⎢3  4  5  6  7⎥│\n                │⎢             ⎥│\n                │⎣4  5  6  7  8⎦│\n```\n\nHere's how I think it should work, using the proposed #10423:\n\n```\npprint(sin((1+1/x)/y) + Trace(Z))\n               ⎛⎡0  1  2  3  4⎤⎞\n   ⎛    1⎞     ⎜⎢             ⎥⎟\n   ⎜1 + ─⎟     ⎜⎢1  2  3  4  5⎥⎟\n   ⎜    x⎟     ⎜⎢             ⎥⎟\nsin⎜─────⎟ + tr⎜⎢2  3  4  5  6⎥⎟\n   ⎝  y  ⎠     ⎜⎢             ⎥⎟\n               ⎜⎢3  4  5  6  7⎥⎟\n               ⎜⎢             ⎥⎟\n               ⎝⎣4  5  6  7  8⎦⎠\n```\n\nwhere note the `sin` alignment is by-design, and (relevant to this bug) the `+` and `tr` operator line up with `sin`.\n\nAt least, det, MatAdd, MatMul, MatPow would need fixed, maybe others I haven't thought of.\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/matrices/expressions/matadd.py\n  function: merge_explicit\n\nsympy/matrices/expressions/matmul.py\n  function: merge_explicit\n\nsympy/printing/pretty/pretty.py\n  function: PrettyPrinter._print_matrix_contents\n  function: PrettyPrinter._print_MatrixElement\n"
    },
    {
      "similar_issue": {
        "issue_title": "count_ops is slow for large expressions",
        "issue_body": "It seems that this script was hanging inside `count_ops`:\n\n```\nmoorepants@garuda:pydy.wiki(master)$ SYMPY_CACHE_SIZE=10000 ipython\nPython 3.5.1 |Continuum Analytics, Inc.| (default, Dec  7 2015, 11:16:01) \nType \"copyright\", \"credits\" or \"license\" for more information.\n\nIPython 4.1.2 -- An enhanced Interactive Python.\n?         -> Introduction and overview of IPython's features.\n%quickref -> Quick reference.\nhelp      -> Python's own help system.\nobject?   -> Details about 'object', use 'object??' for extra details.\n\nIn [1]: %paste\n   In [1]: from pydy.models import n_link_pendulum_on_cart\n\n   In [2]: sys = n_link_pendulum_on_cart(3)\n\n   In [3]: x_dot = sys.eom_method.rhs()\n\n   In [4]: %time jac = x_dot.jacobian(sys.states)\n## -- End pasted text --\nCPU times: user 2.2 s, sys: 4 ms, total: 2.21 s\nWall time: 2.2 s\n\nIn [2]: %paste\n   In [5]: sys = n_link_pendulum_on_cart(4)\n\n   In [6]: x_dot = sys.eom_method.rhs()\n\n   In [7]: %time jac = x_dot.jacobian(sys.states)\n## -- End pasted text --\n^C---------------------------------------------------------------------------\nKeyboardInterrupt                         Traceback (most recent call last)\n<ipython-input-2-1039ec729c05> in <module>()\n      3 x_dot = sys.eom_method.rhs()\n      4 \n----> 5 get_ipython().magic('time jac = x_dot.jacobian(sys.states)')\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/interactiveshell.py in magic(self, arg_s)\n   2161         magic_name, _, magic_arg_s = arg_s.partition(' ')\n   2162         magic_name = magic_name.lstrip(prefilter.ESC_MAGIC)\n-> 2163         return self.run_line_magic(magic_name, magic_arg_s)\n   2164 \n   2165     #-------------------------------------------------------------------------\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/interactiveshell.py in run_line_magic(self, magic_name, line)\n   2082                 kwargs['local_ns'] = sys._getframe(stack_depth).f_locals\n   2083             with self.builtin_trap:\n-> 2084                 result = fn(*args,**kwargs)\n   2085             return result\n   2086 \n\n<decorator-gen-60> in time(self, line, cell, local_ns)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/magic.py in <lambda>(f, *a, **k)\n    191     # but it's overkill for just that one bit of state.\n    192     def magic_deco(arg):\n--> 193         call = lambda f, *a, **k: f(*a, **k)\n    194 \n    195         if callable(arg):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/magics/execution.py in time(self, line, cell, local_ns)\n   1175         else:\n   1176             st = clock2()\n-> 1177             exec(code, glob, local_ns)\n   1178             end = clock2()\n   1179             out = None\n\n<timed exec> in <module>()\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in jacobian(self, X)\n   1551         # m is the number of functions and n is the number of variables\n   1552         # computing the Jacobian is now easy:\n-> 1553         return self._new(m, n, lambda j, i: self[j].diff(X[i]))\n   1554 \n   1555     def QRdecomposition(self):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/dense.py in _new(cls, *args, **kwargs)\n    601     @classmethod\n    602     def _new(cls, *args, **kwargs):\n--> 603         rows, cols, flat_list = cls._handle_creation_inputs(*args, **kwargs)\n    604         self = object.__new__(cls)\n    605         self.rows = rows\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in _handle_creation_inputs(cls, *args, **kwargs)\n    207                     flat_list.extend(\n    208                         [cls._sympify(op(cls._sympify(i), cls._sympify(j)))\n--> 209                         for j in range(cols)])\n    210 \n    211             # Matrix(2, 2, [1, 2, 3, 4])\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in <listcomp>(.0)\n    207                     flat_list.extend(\n    208                         [cls._sympify(op(cls._sympify(i), cls._sympify(j)))\n--> 209                         for j in range(cols)])\n    210 \n    211             # Matrix(2, 2, [1, 2, 3, 4])\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in <lambda>(j, i)\n   1551         # m is the number of functions and n is the number of variables\n   1552         # computing the Jacobian is now easy:\n-> 1553         return self._new(m, n, lambda j, i: self[j].diff(X[i]))\n   1554 \n   1555     def QRdecomposition(self):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/power.py in _eval_derivative(self, s)\n    982     def _eval_derivative(self, s):\n    983         from sympy import log\n--> 984         dbase = self.base.diff(s)\n    985         dexp = self.exp.diff(s)\n    986         return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/power.py in _eval_derivative(self, s)\n    984         dbase = self.base.diff(s)\n    985         dexp = self.exp.diff(s)\n--> 986         return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n    987 \n    988     def _eval_evalf(self, prec):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, *args, **options)\n    388 \n    389         pr = max(cls._should_evalf(a) for a in result.args)\n--> 390         pr2 = min(cls._should_evalf(a) for a in result.args)\n    391         if pr2 > 0:\n    392             return result.evalf(mlib.libmpf.prec_to_dps(pr))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in <genexpr>(.0)\n    388 \n    389         pr = max(cls._should_evalf(a) for a in result.args)\n--> 390         pr2 = min(cls._should_evalf(a) for a in result.args)\n    391         if pr2 > 0:\n    392             return result.evalf(mlib.libmpf.prec_to_dps(pr))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in _should_evalf(cls, arg)\n    411         # Don't use as_real_imag() here, that's too much work\n    412         a, b = Wild('a'), Wild('b')\n--> 413         m = arg.match(a + b*S.ImaginaryUnit)\n    414         if not m or not (m[a].is_Float or m[b].is_Float):\n    415             return -1\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/basic.py in match(self, pattern, old)\n   1489         \"\"\"\n   1490         pattern = sympify(pattern)\n-> 1491         return pattern.matches(self, old=old)\n   1492 \n   1493     def count_ops(self, visual=None):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in matches(self, expr, repl_dict, old)\n    365 \n    366     def matches(self, expr, repl_dict={}, old=False):\n--> 367         return AssocOp._matches_commutative(self, expr, repl_dict, old)\n    368 \n    369     @staticmethod\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/operations.py in _matches_commutative(self, expr, repl_dict, old)\n    215                     d1 = w.matches(last_op, repl_dict)\n    216                     if d1 is not None:\n--> 217                         d2 = self.xreplace(d1).matches(expr, d1)\n    218                         if d2 is not None:\n    219                             return d2\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in matches(self, expr, repl_dict, old)\n    365 \n    366     def matches(self, expr, repl_dict={}, old=False):\n--> 367         return AssocOp._matches_commutative(self, expr, repl_dict, old)\n    368 \n    369     @staticmethod\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/operations.py in _matches_commutative(self, expr, repl_dict, old)\n    201             newexpr = self._combine_inverse(expr, exact)\n    202             if not old and (expr.is_Add or expr.is_Mul):\n--> 203                 if newexpr.count_ops() > expr.count_ops():\n    204                     return None\n    205             return newpattern.matches(newexpr, repl_dict)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in count_ops(self, visual)\n   1017         \"\"\"wrapper for count_ops that returns the operation count.\"\"\"\n   1018         from .function import count_ops\n-> 1019         return count_ops(self, visual)\n   1020 \n   1021     def args_cnc(self, cset=False, warn=True, split_1=True):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in count_ops(expr, visual)\n   2378                 a.is_Pow or\n   2379                 a.is_Function or\n-> 2380                 isinstance(a, Derivative) or\n   2381                     isinstance(a, Integral)):\n   2382 \n\nKeyboardInterrupt: \n\nIn [3]: \n```\n",
        "issue_id": 10979,
        "pr_number": 13441,
        "pr_title": "address issues with _commutative_match and _combine_inverse",
        "pr_body": "fixes #10979 (as best as I can see how); I suspect the slowdown is coming from the `_should_evalf` procedure rather than `count_ops`.",
        "issue_closed_at": "2017-10-13T23:48:13Z",
        "base_commit": "e0cd7d65857a90376a9b49529840f96908dd774f"
      },
      "summary": "### Summary:\n\nThis issue is related to a performance bottleneck experienced in a mathematical computation library when dealing with large expressions. The specific problem arises within the `count_ops` function, which becomes inefficient and causes the system to hang or become unresponsive when processing complex equations, such as those generated by a multi-link pendulum model. The symptoms are observed when the execution time significantly increases, resulting in user intervention to terminate the process manually. This issue primarily affects components responsible for symbolic differentiation and operation count, particularly within the SymPy library's matrix and expression handling modules.\n\nThe potential impact is substantial as it directly affects the usability and effectiveness of the library for users dealing with large symbolic computations. Such performance issues can hinder scientific and engineering applications relying on computational efficiency. Relevant technical details include inefficiencies in handling symbolic derivatives and operation counts within recursive or deeply nested expressions. The fix addresses these inefficiencies in several core functions across multiple modules, enhancing the performance and reliability of symbolic operation counting.",
      "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: count_ops is slow for large expressions\n\nBody:\nIt seems that this script was hanging inside `count_ops`:\n\n```\nmoorepants@garuda:pydy.wiki(master)$ SYMPY_CACHE_SIZE=10000 ipython\nPython 3.5.1 |Continuum Analytics, Inc.| (default, Dec  7 2015, 11:16:01) \nType \"copyright\", \"credits\" or \"license\" for more information.\n\nIPython 4.1.2 -- An enhanced Interactive Python.\n?         -> Introduction and overview of IPython's features.\n%quickref -> Quick reference.\nhelp      -> Python's own help system.\nobject?   -> Details about 'object', use 'object??' for extra details.\n\nIn [1]: %paste\n   In [1]: from pydy.models import n_link_pendulum_on_cart\n\n   In [2]: sys = n_link_pendulum_on_cart(3)\n\n   In [3]: x_dot = sys.eom_method.rhs()\n\n   In [4]: %time jac = x_dot.jacobian(sys.states)\n## -- End pasted text --\nCPU times: user 2.2 s, sys: 4 ms, total: 2.21 s\nWall time: 2.2 s\n\nIn [2]: %paste\n   In [5]: sys = n_link_pendulum_on_cart(4)\n\n   In [6]: x_dot = sys.eom_method.rhs()\n\n   In [7]: %time jac = x_dot.jacobian(sys.states)\n## -- End pasted text --\n^C---------------------------------------------------------------------------\nKeyboardInterrupt                         Traceback (most recent call last)\n<ipython-input-2-1039ec729c05> in <module>()\n      3 x_dot = sys.eom_method.rhs()\n      4 \n----> 5 get_ipython().magic('time jac = x_dot.jacobian(sys.states)')\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/interactiveshell.py in magic(self, arg_s)\n   2161         magic_name, _, magic_arg_s = arg_s.partition(' ')\n   2162         magic_name = magic_name.lstrip(prefilter.ESC_MAGIC)\n-> 2163         return self.run_line_magic(magic_name, magic_arg_s)\n   2164 \n   2165     #-------------------------------------------------------------------------\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/interactiveshell.py in run_line_magic(self, magic_name, line)\n   2082                 kwargs['local_ns'] = sys._getframe(stack_depth).f_locals\n   2083             with self.builtin_trap:\n-> 2084                 result = fn(*args,**kwargs)\n   2085             return result\n   2086 \n\n<decorator-gen-60> in time(self, line, cell, local_ns)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/magic.py in <lambda>(f, *a, **k)\n    191     # but it's overkill for just that one bit of state.\n    192     def magic_deco(arg):\n--> 193         call = lambda f, *a, **k: f(*a, **k)\n    194 \n    195         if callable(arg):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/IPython/core/magics/execution.py in time(self, line, cell, local_ns)\n   1175         else:\n   1176             st = clock2()\n-> 1177             exec(code, glob, local_ns)\n   1178             end = clock2()\n   1179             out = None\n\n<timed exec> in <module>()\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in jacobian(self, X)\n   1551         # m is the number of functions and n is the number of variables\n   1552         # computing the Jacobian is now easy:\n-> 1553         return self._new(m, n, lambda j, i: self[j].diff(X[i]))\n   1554 \n   1555     def QRdecomposition(self):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/dense.py in _new(cls, *args, **kwargs)\n    601     @classmethod\n    602     def _new(cls, *args, **kwargs):\n--> 603         rows, cols, flat_list = cls._handle_creation_inputs(*args, **kwargs)\n    604         self = object.__new__(cls)\n    605         self.rows = rows\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in _handle_creation_inputs(cls, *args, **kwargs)\n    207                     flat_list.extend(\n    208                         [cls._sympify(op(cls._sympify(i), cls._sympify(j)))\n--> 209                         for j in range(cols)])\n    210 \n    211             # Matrix(2, 2, [1, 2, 3, 4])\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in <listcomp>(.0)\n    207                     flat_list.extend(\n    208                         [cls._sympify(op(cls._sympify(i), cls._sympify(j)))\n--> 209                         for j in range(cols)])\n    210 \n    211             # Matrix(2, 2, [1, 2, 3, 4])\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/matrices/matrices.py in <lambda>(j, i)\n   1551         # m is the number of functions and n is the number of variables\n   1552         # computing the Jacobian is now easy:\n-> 1553         return self._new(m, n, lambda j, i: self[j].diff(X[i]))\n   1554 \n   1555     def QRdecomposition(self):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/power.py in _eval_derivative(self, s)\n    982     def _eval_derivative(self, s):\n    983         from sympy import log\n--> 984         dbase = self.base.diff(s)\n    985         dexp = self.exp.diff(s)\n    986         return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in _eval_derivative(self, s)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in <listcomp>(.0)\n    351     @cacheit\n    352     def _eval_derivative(self, s):\n--> 353         return self.func(*[a.diff(s) for a in self.args])\n    354 \n    355     def _eval_nseries(self, x, n, logx):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/mul.py in _eval_derivative(self, s)\n    832         terms = []\n    833         for i in range(len(args)):\n--> 834             d = args[i].diff(s)\n    835             if d:\n    836                 terms.append(self.func(*(args[:i] + [d] + args[i + 1:])))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in diff(self, *symbols, **assumptions)\n   2864         new_symbols = list(map(sympify, symbols))  # e.g. x, 2, y, z\n   2865         assumptions.setdefault(\"evaluate\", True)\n-> 2866         return Derivative(self, *new_symbols, **assumptions)\n   2867 \n   2868     ###########################################################################\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, expr, *variables, **assumptions)\n   1141                     old_v = v\n   1142                     v = new_v\n-> 1143                 obj = expr._eval_derivative(v)\n   1144                 nderivs += 1\n   1145                 if not is_symbol:\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/power.py in _eval_derivative(self, s)\n    984         dbase = self.base.diff(s)\n    985         dexp = self.exp.diff(s)\n--> 986         return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n    987 \n    988     def _eval_evalf(self, prec):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in __new__(cls, *args, **options)\n    388 \n    389         pr = max(cls._should_evalf(a) for a in result.args)\n--> 390         pr2 = min(cls._should_evalf(a) for a in result.args)\n    391         if pr2 > 0:\n    392             return result.evalf(mlib.libmpf.prec_to_dps(pr))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in <genexpr>(.0)\n    388 \n    389         pr = max(cls._should_evalf(a) for a in result.args)\n--> 390         pr2 = min(cls._should_evalf(a) for a in result.args)\n    391         if pr2 > 0:\n    392             return result.evalf(mlib.libmpf.prec_to_dps(pr))\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in _should_evalf(cls, arg)\n    411         # Don't use as_real_imag() here, that's too much work\n    412         a, b = Wild('a'), Wild('b')\n--> 413         m = arg.match(a + b*S.ImaginaryUnit)\n    414         if not m or not (m[a].is_Float or m[b].is_Float):\n    415             return -1\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/basic.py in match(self, pattern, old)\n   1489         \"\"\"\n   1490         pattern = sympify(pattern)\n-> 1491         return pattern.matches(self, old=old)\n   1492 \n   1493     def count_ops(self, visual=None):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in matches(self, expr, repl_dict, old)\n    365 \n    366     def matches(self, expr, repl_dict={}, old=False):\n--> 367         return AssocOp._matches_commutative(self, expr, repl_dict, old)\n    368 \n    369     @staticmethod\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/operations.py in _matches_commutative(self, expr, repl_dict, old)\n    215                     d1 = w.matches(last_op, repl_dict)\n    216                     if d1 is not None:\n--> 217                         d2 = self.xreplace(d1).matches(expr, d1)\n    218                         if d2 is not None:\n    219                             return d2\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/add.py in matches(self, expr, repl_dict, old)\n    365 \n    366     def matches(self, expr, repl_dict={}, old=False):\n--> 367         return AssocOp._matches_commutative(self, expr, repl_dict, old)\n    368 \n    369     @staticmethod\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/operations.py in _matches_commutative(self, expr, repl_dict, old)\n    201             newexpr = self._combine_inverse(expr, exact)\n    202             if not old and (expr.is_Add or expr.is_Mul):\n--> 203                 if newexpr.count_ops() > expr.count_ops():\n    204                     return None\n    205             return newpattern.matches(newexpr, repl_dict)\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/expr.py in count_ops(self, visual)\n   1017         \"\"\"wrapper for count_ops that returns the operation count.\"\"\"\n   1018         from .function import count_ops\n-> 1019         return count_ops(self, visual)\n   1020 \n   1021     def args_cnc(self, cset=False, warn=True, split_1=True):\n\n/home/moorepants/miniconda3/lib/python3.5/site-packages/sympy/core/function.py in count_ops(expr, visual)\n   2378                 a.is_Pow or\n   2379                 a.is_Function or\n-> 2380                 isinstance(a, Derivative) or\n   2381                     isinstance(a, Integral)):\n   2382 \n\nKeyboardInterrupt: \n\nIn [3]: \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/add.py\n  function: Add.matches\n\nsympy/core/function.py\n  function: Function._should_evalf\n\nsympy/core/operations.py\n  function: AssocOp._new_rawargs\n  function: AssocOp._matches_commutative\n"
    },
    {
      "similar_issue": {
        "issue_title": "test_llvmjit.py fails with llvmlite 0.21.0",
        "issue_body": "```\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_simple_expr _____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 25, in test_simple_expr\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_arg _______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 34, in test_two_arg\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________________ sympy/printing/tests/test_llvmjit.py:test_func ________________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 43, in test_func\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_func ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 52, in test_two_func\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_sqrt ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 61, in test_two_sqrt\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_pow _______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 70, in test_two_pow\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_callback ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 79, in test_callback\r\n    f = g.llvm_callable([a], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n_________ sympy/printing/tests/test_llvmjit.py:test_callback_cubature __________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 93, in test_callback_cubature\r\n    f = g.llvm_callable([a], e, callback_type='cubature')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_callback_two ____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 110, in test_callback_two\r\n    f = g.llvm_callable([a, b], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n__________ sympy/printing/tests/test_llvmjit.py:test_callback_alt_two __________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 125, in test_callback_alt_two\r\n    f = g.llvm_callable([n, d], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________ sympy/printing/tests/test_llvmjit.py:test_multiple_statements _________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 140, in test_multiple_statements\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________________ sympy/printing/tests/test_llvmjit.py:test_cse _________________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 157, in test_cse\r\n    f = g.llvm_callable([a, b], e2)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_cse_multiple ____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 181, in test_cse_multiple\r\n    f = g.llvm_callable([a, b], e3)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n_____ sympy/printing/tests/test_llvmjit.py:test_callback_cubature_multiple _____\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 193, in test_callback_cubature_multiple\r\n    f = g.llvm_callable([a, b], e3, callback_type='cubature')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n```\r\n\r\nIt seems `get_pointer_to_function` was deprecated(https://github.com/numba/llvmlite/pull/83) and removed in https://github.com/numba/llvmlite/pull/307.\r\n\r\n\r\nFailing Travis builds:\r\n\r\n-  [x] #13698\r\n-  [x] #13669\r\n-  [x] #13708\r\n-  [x] #13709\r\n-  [x] #13650\r\n-  [x] #13673\r\n-  [x] #13665 \r\n-  [x] #13693\r\n-  [x] #13713\r\n\r\nAlso, there were ignored errors before:\r\n\r\n```\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6e1f10>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6e1e90>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6d3dd0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6d3d50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6c8e50>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6c8dd0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f432e90>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f432e10>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f432690>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f432610>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f42aed0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f42ae50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f42a750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f42a6d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f41fe10>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f41fd90>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f41f750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f41f6d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f413c90>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f413c10>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f413250>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f4131d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f406750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f4066d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6b1cd0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6b1c50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6b1410>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6b1390>> ignored\r\n```",
        "issue_id": 13711,
        "pr_number": 13714,
        "pr_title": "llvmjit: Replace deprecated get_pointer_to_function",
        "pr_body": "... with get_function_address\r\n\r\n`get_pointer_to_function` was deprecated(https://github.com/numba/llvmlite/pull/83) and removed in https://github.com/numba/llvmlite/pull/307.\r\n\r\nFixes #13711 \r\n\r\n<!-- Please give this pull request a descriptive title. Pull requests with descriptive titles are more likely to receive reviews. Describe what you changed! A title that only references an issue number is not descriptive. -->\r\n\r\n<!-- If this pull request fixes an issue please indicate which issue by typing \"Fixes #NNNN\" below. -->\r\n",
        "issue_closed_at": "2017-12-09T21:00:49Z",
        "base_commit": "e01729f7e7f9d43df711084dde431aad4461b792"
      },
      "summary": "### Summary:\nThis issue pertains to the failure of tests in the `test_llvmjit.py` module when using the `llvmlite` library version 0.21.0. The core problem is an `AttributeError` caused by the deprecation and subsequent removal of the `get_pointer_to_function` attribute from the `ExecutionEngine` class in `llvmlite`. This change affects the `llvm_callable` function within the `sympy/printing/llvmjitcode.py` file, specifically in the `_compile_function` method, which relies on this now-removed attribute for its operation.\n\n1. **Problem Description**: The problem occurs when executing tests related to LLVM Just-In-Time (JIT) compilation in the SymPy library. The error arises due to a missing method in the `ExecutionEngine` class of the `llvmlite` library, which was previously used to retrieve function pointers during JIT compilation processes.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom is the repeated occurrence of an `AttributeError` during test execution, indicating that the `ExecutionEngine` object lacks the `get_pointer_to_function` method. This error is consistently observed across multiple test cases in the `test_llvmjit.py` module.\n\n3. **Affected Components or Systems**: The issue specifically affects the LLVM JIT compilation functionality in the SymPy library, as facilitated by the `llvmlite` library. The tests impacted are those that involve the `llvm_callable` method in `sympy/printing/llvmjitcode.py`.\n\n4. **Potential Impact or Severity**: The impact of this issue is significant in that it prevents successful execution and validation of several test cases related to JIT compilation in SymPy. This could hinder the development and deployment processes that rely on these tests for verification of functionality.\n\n5. **Relevant Technical Details**: The `get_pointer_to_function` method was deprecated and removed as per the pull requests mentioned, which necessitates refactoring the affected code to accommodate the changes in the `llvmlite` library. Additionally, there were previously ignored errors related to `NoneType` and `AttributeError` in the context of object finalization, which may indicate underlying issues with memory management or object lifecycle handling in the affected components. \n\nChanges Summary:\nModification in `sympy/printing/llvmjitcode.py` specifically in the `LLVMJitCode._compile_function` method to address the removal of the `get_pointer_to_function` method.",
      "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_llvmjit.py fails with llvmlite 0.21.0\n\nBody:\n```\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_simple_expr _____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 25, in test_simple_expr\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_arg _______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 34, in test_two_arg\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________________ sympy/printing/tests/test_llvmjit.py:test_func ________________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 43, in test_func\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_func ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 52, in test_two_func\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_sqrt ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 61, in test_two_sqrt\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_two_pow _______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 70, in test_two_pow\r\n    f = g.llvm_callable([a, b], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n______________ sympy/printing/tests/test_llvmjit.py:test_callback ______________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 79, in test_callback\r\n    f = g.llvm_callable([a], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n_________ sympy/printing/tests/test_llvmjit.py:test_callback_cubature __________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 93, in test_callback_cubature\r\n    f = g.llvm_callable([a], e, callback_type='cubature')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_callback_two ____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 110, in test_callback_two\r\n    f = g.llvm_callable([a, b], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n__________ sympy/printing/tests/test_llvmjit.py:test_callback_alt_two __________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 125, in test_callback_alt_two\r\n    f = g.llvm_callable([n, d], e, callback_type='scipy.integrate.test')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________ sympy/printing/tests/test_llvmjit.py:test_multiple_statements _________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 140, in test_multiple_statements\r\n    f = g.llvm_callable([a], e)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n________________ sympy/printing/tests/test_llvmjit.py:test_cse _________________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 157, in test_cse\r\n    f = g.llvm_callable([a, b], e2)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n____________ sympy/printing/tests/test_llvmjit.py:test_cse_multiple ____________\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 181, in test_cse_multiple\r\n    f = g.llvm_callable([a, b], e3)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n________________________________________________________________________________\r\n_____ sympy/printing/tests/test_llvmjit.py:test_callback_cubature_multiple _____\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/utilities/runtests.py\", line 1267, in _timeout\r\n    function()\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/tests/test_llvmjit.py\", line 193, in test_callback_cubature_multiple\r\n    f = g.llvm_callable([a, b], e3, callback_type='cubature')\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 469, in llvm_callable\r\n    fptr = _llvm_jit_code(args, expr, signature, callback_type)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 355, in _llvm_jit_code\r\n    fptr = jit._compile_function(strmod)\r\n  File \"/home/travis/miniconda/envs/test-environment/lib/python2.7/site-packages/sympy-1.1.2.dev0-py2.7.egg/sympy/printing/llvmjitcode.py\", line 284, in _compile_function\r\n    fptr = exe_eng.get_pointer_to_function(\r\nAttributeError: 'ExecutionEngine' object has no attribute 'get_pointer_to_function'\r\n```\r\n\r\nIt seems `get_pointer_to_function` was deprecated(https://github.com/numba/llvmlite/pull/83) and removed in https://github.com/numba/llvmlite/pull/307.\r\n\r\n\r\nFailing Travis builds:\r\n\r\n-  [x] #13698\r\n-  [x] #13669\r\n-  [x] #13708\r\n-  [x] #13709\r\n-  [x] #13650\r\n-  [x] #13673\r\n-  [x] #13665 \r\n-  [x] #13693\r\n-  [x] #13713\r\n\r\nAlso, there were ignored errors before:\r\n\r\n```\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6e1f10>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6e1e90>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6d3dd0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6d3d50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6c8e50>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6c8dd0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f432e90>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f432e10>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f432690>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f432610>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f42aed0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f42ae50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f42a750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f42a6d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f41fe10>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f41fd90>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f41f750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f41f6d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f413c90>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f413c10>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f413250>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f4131d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f406750>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f4066d0>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6b1cd0>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6b1c50>> ignored\r\nException TypeError: \"'NoneType' object is not callable\" in <bound method ExecutionEngine.__del__ of <llvmlite.binding.executionengine.ExecutionEngine object at 0x7f271f6b1410>> ignored\r\nException AttributeError: '_as_parameter_' in <bound method ModuleRef.__del__ of <llvmlite.binding.module.ModuleRef object at 0x7f271f6b1390>> ignored\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/printing/llvmjitcode.py\n  function: LLVMJitCode._compile_function\n"
    },
    {
      "similar_issue": {
        "issue_title": "Python code printer (pycode) should support Assignment",
        "issue_body": "There is a lookup on 'contract', either we should give it a default in the `PythonCodePrinter` or we should make the code accessing `_settings` use `.get` with a default.\r\n\r\n```\r\nIn [3]: from sympy.printing.pycode import pycode\r\n\r\nIn [4]: from sympy.codegen.ast import Assignment\r\n\r\nIn [5]: pycode(Assignment(x, 3))\r\nKeyError\r\n...\r\n/home/bjorn/vc/sympy/sympy/printing/codeprinter.pyc in _print_Assignment(self, expr)\r\n    309                 lines.append(code0)\r\n    310             return \"\\n\".join(lines)\r\n--> 311         elif self._settings[\"contract\"] and (lhs.has(IndexedBase) or\r\n    312                 rhs.has(IndexedBase)):\r\n    313             # Here we check if there is looping to be done, and if so\r\n\r\nKeyError: 'contract'\r\n```",
        "issue_id": 13598,
        "pr_number": 13624,
        "pr_title": "Python code printer(pycode) supporting Assignment",
        "pr_body": "Changed the accessing of `_settings` to use `.get` with a default value of `False`. \r\nReplaced the `NotImplementedError` in `_get_comment` with the codestring. \r\n\r\nFixes #13598 \r\n",
        "issue_closed_at": "2017-11-29T07:32:30Z",
        "base_commit": "a67e45eecc972b53e95effb09fe503a05325d3f5"
      },
      "summary": "### Summary:\n\nThis issue is related to a problem in the SymPy library's Python code printing functionality, specifically when handling assignment operations within the `pycode` function. The problem arises from the absence of a default value for a configuration setting, \"contract,\" which leads to a `KeyError` when the setting is accessed in the code responsible for printing assignment statements.\n\n1. **Problem description in general terms:**\n   The `PythonCodePrinter` class within the SymPy library fails to properly handle assignment operations due to missing configuration settings, resulting in runtime errors. The system lacks a mechanism to handle the absence of certain configuration keys gracefully.\n\n2. **Key symptoms and behaviors observed:**\n   - Attempting to print an `Assignment` object using `pycode` results in a `KeyError`.\n   - The error specifically occurs when the code attempts to access a non-existent configuration setting, \"contract,\" within its private `_settings` dictionary.\n\n3. **Affected components or systems:**\n   - The primary component affected is the `PythonCodePrinter` class, particularly within the `sympy/printing/codeprinter.py` and `sympy/printing/pycode.py` modules.\n   - Functionally, this impacts users of the SymPy library who rely on its code generation capabilities, especially those involving assignments.\n\n4. **Potential impact or severity:**\n   - The issue can be considered moderately severe as it directly affects the usability of the `pycode` function for generating Python code from symbolic expressions involving assignments.\n   - It may disrupt workflows that depend on automated code generation, causing interruptions or requiring workarounds.\n\n5. **Relevant technical details abstracted for broader understanding:**\n   - The problem is rooted in the code's reliance on a configuration setting that lacks a default value, making the system vulnerable to `KeyError` when the setting is accessed.\n   - Addressing the issue requires either providing a default value for the \"contract\" setting or modifying the code to safely access configuration settings using methods that allow defaults, such as `.get()`.",
      "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: Python code printer (pycode) should support Assignment\n\nBody:\nThere is a lookup on 'contract', either we should give it a default in the `PythonCodePrinter` or we should make the code accessing `_settings` use `.get` with a default.\r\n\r\n```\r\nIn [3]: from sympy.printing.pycode import pycode\r\n\r\nIn [4]: from sympy.codegen.ast import Assignment\r\n\r\nIn [5]: pycode(Assignment(x, 3))\r\nKeyError\r\n...\r\n/home/bjorn/vc/sympy/sympy/printing/codeprinter.pyc in _print_Assignment(self, expr)\r\n    309                 lines.append(code0)\r\n    310             return \"\\n\".join(lines)\r\n--> 311         elif self._settings[\"contract\"] and (lhs.has(IndexedBase) or\r\n    312                 rhs.has(IndexedBase)):\r\n    313             # Here we check if there is looping to be done, and if so\r\n\r\nKeyError: 'contract'\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/printing/codeprinter.py\n  function: CodePrinter._print_Assignment\n\nsympy/printing/pycode.py\n  function: PythonCodePrinter._module_format\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 pertains to the incorrect behavior of the `expand_log` function in the SymPy library, a Python library for symbolic mathematics. The problem arises when attempting to simplify logarithmic expressions involving the exponential function, specifically `log(exp(x))`, where the expected output should ideally be `x` when the `force=True` argument is used.\n\n1. **Problem Description in General Terms:**\n   The primary issue is the failure of the `expand_log` function to correctly simplify expressions of the form `log(exp(x))` to `x` when the force option is enabled. The function does not return the simplest form of the expression as intended.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - When executing `expand_log(log(exp(x)), force=True)`, the output is `log(e**x)` instead of the expected `x`.\n   - In contrast, the function performs correctly for expressions like `log(y**(x))`, returning `x⋅log(y)`, indicating inconsistency in handling similar expressions.\n\n3. **Affected Components or Systems:**\n   The issue affects the `expand_log` method within the `sympy.functions.elementary.exponential` module, specifically in the `log._eval_expand_log` function, which is responsible for expanding logarithmic expressions.\n\n4. **Potential Impact or Severity:**\n   The impact is primarily on users relying on symbolic simplification for mathematical expressions involving logarithms and exponentials. This could lead to incorrect results in computations or analyses where such simplifications are necessary, potentially affecting mathematical accuracy and reliability.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The core of the problem is the handling of logarithmic identities within the symbolic manipulation process. The existing implementation fails to apply the identity `log(exp(x)) = x` correctly when the `force` parameter is set to `True`, highlighting a need for revisiting the logic that governs expression simplification in logarithmic contexts. The resolution requires adjustments in the `log._eval_expand_log` function to ensure consistent and mathematically accurate simplification across similar expressions.\n\nIn summary, this issue highlights a specific case of symbolic computation inconsistency within the SymPy library, necessitating a fix to ensure accurate and reliable expression simplification.",
      "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"
    }
  ]
}