{
  "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\u239b   t\u239e e_j\r\n\u239c\u239bx\u239e e_j \u239f\r\n\u239c\u239c\u2500\u239f \u239f\r\n\u239d\u239dy\u23a0 \u23a0\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",
  "similar_bug_items": [
    {
      "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\u22c5\u23a10  1  2  3  4\u23a4\r\n  \u23a2             \u23a5\r\n  \u23a21  2  3  4  5\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a22  3  4  5  6\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a23  4  5  6  7\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a34  5  6  7  8\u23a6\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  \u23a10  1  2  3  4\u23a4\r\n  \u23a2             \u23a5\r\n  \u23a21  2  3  4  5\u23a5\r\n  \u23a2             \u23a5\r\n2.\u23a22  3  4  5  6\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a23  4  5  6  7\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a34  5  6  7  8\u23a6\r\n```\r\nFixes #10472 . ",
      "issue_id": 10472,
      "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\u22c5\u23a10  1  2  3  4\u23a4\n  \u23a2             \u23a5\n  \u23a21  2  3  4  5\u23a5\n  \u23a2             \u23a5\n  \u23a22  3  4  5  6\u23a5\n  \u23a2             \u23a5\n  \u23a23  4  5  6  7\u23a5\n  \u23a2             \u23a5\n  \u23a34  5  6  7  8\u23a6\n>>> pprint(MatAdd(Z,Z))\n\u23a10  1  2  3  4\u23a4 + \u23a10  1  2  3  4\u23a4\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a21  2  3  4  5\u23a5   \u23a21  2  3  4  5\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a22  3  4  5  6\u23a5   \u23a22  3  4  5  6\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a23  4  5  6  7\u23a5   \u23a23  4  5  6  7\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a34  5  6  7  8\u23a6   \u23a34  5  6  7  8\u23a6\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   \u239b    1\u239e                       \n   \u239c1 + \u2500\u239f                       \n   \u239c    x\u239f                       \nsin\u239c\u2500\u2500\u2500\u2500\u2500\u239f + 32\u22c5\u2502\u23a10  1  2  3  4\u23a4\u2502\n   \u239c    1\u239f      \u2502\u23a2             \u23a5\u2502\n   \u239c1 + \u2500\u239f      \u2502\u23a21  2  3  4  5\u23a5\u2502\n   \u239d    y\u23a0      \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a22  3  4  5  6\u23a5\u2502\n                \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a23  4  5  6  7\u23a5\u2502\n                \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a34  5  6  7  8\u23a6\u2502\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               \u239b\u23a10  1  2  3  4\u23a4\u239e\n   \u239b    1\u239e     \u239c\u23a2             \u23a5\u239f\n   \u239c1 + \u2500\u239f     \u239c\u23a21  2  3  4  5\u23a5\u239f\n   \u239c    x\u239f     \u239c\u23a2             \u23a5\u239f\nsin\u239c\u2500\u2500\u2500\u2500\u2500\u239f + tr\u239c\u23a22  3  4  5  6\u23a5\u239f\n   \u239d  y  \u23a0     \u239c\u23a2             \u23a5\u239f\n               \u239c\u23a23  4  5  6  7\u23a5\u239f\n               \u239c\u23a2             \u23a5\u239f\n               \u239d\u23a34  5  6  7  8\u23a6\u23a0\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_closed_at": "2016-12-22T06:52:11Z",
      "base_commit": "9a724a42c033c1aae97064947a0f44ec3b922d73",
      "changes": [
        {
          "file": "sympy/matrices/expressions/matadd.py",
          "type": "function",
          "name": "merge_explicit",
          "class_name": null,
          "code": "def merge_explicit(matadd):\n    \"\"\" Merge explicit MatrixBase arguments\n\n    >>> from sympy import MatrixSymbol, eye, Matrix, MatAdd, pprint\n    >>> from sympy.matrices.expressions.matadd import merge_explicit\n    >>> A = MatrixSymbol('A', 2, 2)\n    >>> B = eye(2)\n    >>> C = Matrix([[1, 2], [3, 4]])\n    >>> X = MatAdd(A, B, C)\n    >>> pprint(X)\n    A + [1  0] + [1  2]\n        [    ]   [    ]\n        [0  1]   [3  4]\n    >>> pprint(merge_explicit(X))\n    A + [2  2]\n        [    ]\n        [3  5]\n    \"\"\"\n    groups = sift(matadd.args, lambda arg: isinstance(arg, MatrixBase))\n    if len(groups[True]) > 1:\n        return MatAdd(*(groups[False] + [reduce(add, groups[True])]))\n    else:\n        return matadd"
        },
        {
          "file": "sympy/matrices/expressions/matmul.py",
          "type": "function",
          "name": "merge_explicit",
          "class_name": null,
          "code": "def merge_explicit(matmul):\n    \"\"\" Merge explicit MatrixBase arguments\n\n    >>> from sympy import MatrixSymbol, eye, Matrix, MatMul, pprint\n    >>> from sympy.matrices.expressions.matmul import merge_explicit\n    >>> A = MatrixSymbol('A', 2, 2)\n    >>> B = Matrix([[1, 1], [1, 1]])\n    >>> C = Matrix([[1, 2], [3, 4]])\n    >>> X = MatMul(A, B, C)\n    >>> pprint(X)\n    A*[1  1]*[1  2]\n      [    ] [    ]\n      [1  1] [3  4]\n    >>> pprint(merge_explicit(X))\n    A*[4  6]\n      [    ]\n      [4  6]\n\n    >>> X = MatMul(B, A, C)\n    >>> pprint(X)\n    [1  1]*A*[1  2]\n    [    ]   [    ]\n    [1  1]   [3  4]\n    >>> pprint(merge_explicit(X))\n    [1  1]*A*[1  2]\n    [    ]   [    ]\n    [1  1]   [3  4]\n    \"\"\"\n    if not any(isinstance(arg, MatrixBase) for arg in matmul.args):\n        return matmul\n    newargs = []\n    last = matmul.args[0]\n    for arg in matmul.args[1:]:\n        if isinstance(arg, (MatrixBase, Number)) and isinstance(last, (MatrixBase, Number)):\n            last = last * arg\n        else:\n            newargs.append(last)\n            last = arg\n    newargs.append(last)\n\n    return MatMul(*newargs)"
        },
        {
          "file": "sympy/printing/pretty/pretty.py",
          "type": "function",
          "name": "_print_matrix_contents",
          "class_name": "PrettyPrinter",
          "code": "def _print_matrix_contents(self, e):\n        \"\"\"\n        This method factors out what is essentially grid printing.\n        \"\"\"\n        M = e   # matrix\n        Ms = {}  # i,j -> pretty(M[i,j])\n        for i in range(M.rows):\n            for j in range(M.cols):\n                Ms[i, j] = self._print(M[i, j])\n\n        # h- and v- spacers\n        hsep = 2\n        vsep = 1\n\n        # max width for columns\n        maxw = [-1] * M.cols\n\n        for j in range(M.cols):\n            maxw[j] = max([Ms[i, j].width() for i in range(M.rows)] or [0])\n\n        # drawing result\n        D = None\n\n        for i in range(M.rows):\n\n            D_row = None\n            for j in range(M.cols):\n                s = Ms[i, j]\n\n                # reshape s to maxw\n                # XXX this should be generalized, and go to stringPict.reshape ?\n                assert s.width() <= maxw[j]\n\n                # hcenter it, +0.5 to the right                        2\n                # ( it's better to align formula starts for say 0 and r )\n                # XXX this is not good in all cases -- maybe introduce vbaseline?\n                wdelta = maxw[j] - s.width()\n                wleft = wdelta // 2\n                wright = wdelta - wleft\n\n                s = prettyForm(*s.right(' '*wright))\n                s = prettyForm(*s.left(' '*wleft))\n\n                # we don't need vcenter cells -- this is automatically done in\n                # a pretty way because when their baselines are taking into\n                # account in .right()\n\n                if D_row is None:\n                    D_row = s   # first box in a row\n                    continue\n\n                D_row = prettyForm(*D_row.right(' '*hsep))  # h-spacer\n                D_row = prettyForm(*D_row.right(s))\n\n            if D is None:\n                D = D_row       # first row in a picture\n                continue\n\n            # v-spacer\n            for _ in range(vsep):\n                D = prettyForm(*D.below(' '))\n\n            D = prettyForm(*D.below(D_row))\n\n        if D is None:\n            D = prettyForm('')  # Empty Matrix\n\n        return D"
        },
        {
          "file": "sympy/printing/pretty/pretty.py",
          "type": "function",
          "name": "_print_MatrixElement",
          "class_name": "PrettyPrinter",
          "code": "def _print_MatrixElement(self, expr):\n        from sympy.matrices import MatrixSymbol\n        from sympy import Symbol\n        if (isinstance(expr.parent, MatrixSymbol)\n                and expr.i.is_number and expr.j.is_number):\n            return self._print(\n                    Symbol(expr.parent.name + '_%d%d'%(expr.i, expr.j)))\n        else:\n            prettyFunc = self._print(expr.parent)\n            prettyIndices = self._print_seq((expr.i, expr.j), delimiter=', '\n                    ).parens(left='[', right=']')[0]\n            pform = prettyForm(binding=prettyForm.FUNC,\n                    *stringPict.next(prettyFunc, prettyIndices))\n\n            # store pform parts so it can be reassembled e.g. when powered\n            pform.prettyFunc = prettyFunc\n            pform.prettyArgs = prettyIndices\n\n            return pform"
        }
      ]
    },
    {
      "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_id": 10979,
      "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_closed_at": "2017-10-13T23:48:13Z",
      "base_commit": "e0cd7d65857a90376a9b49529840f96908dd774f",
      "changes": [
        {
          "file": "sympy/core/add.py",
          "type": "function",
          "name": "matches",
          "class_name": "Add",
          "code": "def matches(self, expr, repl_dict={}, old=False):\n        return AssocOp._matches_commutative(self, expr, repl_dict, old)"
        },
        {
          "file": "sympy/core/function.py",
          "type": "function",
          "name": "_should_evalf",
          "class_name": "Function",
          "code": "def _should_evalf(cls, arg):\n        \"\"\"\n        Decide if the function should automatically evalf().\n\n        By default (in this implementation), this happens if (and only if) the\n        ARG is a floating point number.\n        This function is used by __new__.\n\n        Returns the precision to evalf to, or -1 if it shouldn't evalf.\n        \"\"\"\n        from sympy.core.symbol import Wild\n        if arg.is_Float:\n            return arg._prec\n        if not arg.is_Add:\n            return -1\n        # Don't use as_real_imag() here, that's too much work\n        a, b = Wild('a'), Wild('b')\n        m = arg.match(a + b*S.ImaginaryUnit)\n        if not m or not (m[a].is_Float or m[b].is_Float):\n            return -1\n        l = [m[i]._prec for i in m if m[i].is_Float]\n        l.append(-1)\n        return max(l)"
        },
        {
          "file": "sympy/core/operations.py",
          "type": "function",
          "name": "_new_rawargs",
          "class_name": "AssocOp",
          "code": "def _new_rawargs(self, *args, **kwargs):\n        \"\"\"Create new instance of own class with args exactly as provided by\n        caller but returning the self class identity if args is empty.\n\n           This is handy when we want to optimize things, e.g.\n\n               >>> from sympy import Mul, S\n               >>> from sympy.abc import x, y\n               >>> e = Mul(3, x, y)\n               >>> e.args\n               (3, x, y)\n               >>> Mul(*e.args[1:])\n               x*y\n               >>> e._new_rawargs(*e.args[1:])  # the same as above, but faster\n               x*y\n\n           Note: use this with caution. There is no checking of arguments at\n           all. This is best used when you are rebuilding an Add or Mul after\n           simply removing one or more terms. If modification which result,\n           for example, in extra 1s being inserted (as when collecting an\n           expression's numerators and denominators) they will not show up in\n           the result but a Mul will be returned nonetheless:\n\n               >>> m = (x*y)._new_rawargs(S.One, x); m\n               x\n               >>> m == x\n               False\n               >>> m.is_Mul\n               True\n\n           Another issue to be aware of is that the commutativity of the result\n           is based on the commutativity of self. If you are rebuilding the\n           terms that came from a commutative object then there will be no\n           problem, but if self was non-commutative then what you are\n           rebuilding may now be commutative.\n\n           Although this routine tries to do as little as possible with the\n           input, getting the commutativity right is important, so this level\n           of safety is enforced: commutativity will always be recomputed if\n           self is non-commutative and kwarg `reeval=False` has not been\n           passed.\n        \"\"\"\n        if kwargs.pop('reeval', True) and self.is_commutative is False:\n            is_commutative = None\n        else:\n            is_commutative = self.is_commutative\n        return self._from_args(args, is_commutative)"
        },
        {
          "file": "sympy/core/operations.py",
          "type": "function",
          "name": "_matches_commutative",
          "class_name": "AssocOp",
          "code": "def _matches_commutative(self, expr, repl_dict={}, old=False):\n        \"\"\"\n        Matches Add/Mul \"pattern\" to an expression \"expr\".\n\n        repl_dict ... a dictionary of (wild: expression) pairs, that get\n                      returned with the results\n\n        This function is the main workhorse for Add/Mul.\n\n        For instance:\n\n        >>> from sympy import symbols, Wild, sin\n        >>> a = Wild(\"a\")\n        >>> b = Wild(\"b\")\n        >>> c = Wild(\"c\")\n        >>> x, y, z = symbols(\"x y z\")\n        >>> (a+sin(b)*c)._matches_commutative(x+sin(y)*z)\n        {a_: x, b_: y, c_: z}\n\n        In the example above, \"a+sin(b)*c\" is the pattern, and \"x+sin(y)*z\" is\n        the expression.\n\n        The repl_dict contains parts that were already matched. For example\n        here:\n\n        >>> (x+sin(b)*c)._matches_commutative(x+sin(y)*z, repl_dict={a: x})\n        {a_: x, b_: y, c_: z}\n\n        the only function of the repl_dict is to return it in the\n        result, e.g. if you omit it:\n\n        >>> (x+sin(b)*c)._matches_commutative(x+sin(y)*z)\n        {b_: y, c_: z}\n\n        the \"a: x\" is not returned in the result, but otherwise it is\n        equivalent.\n\n        \"\"\"\n        # make sure expr is Expr if pattern is Expr\n        from .expr import Add, Expr\n        from sympy import Mul\n        if isinstance(self, Expr) and not isinstance(expr, Expr):\n            return None\n\n        # handle simple patterns\n        if self == expr:\n            return repl_dict\n\n        d = self._matches_simple(expr, repl_dict)\n        if d is not None:\n            return d\n\n        # eliminate exact part from pattern: (2+a+w1+w2).matches(expr) -> (w1+w2).matches(expr-a-2)\n        from .function import WildFunction\n        from .symbol import Wild\n        wild_part = []\n        exact_part = []\n        for p in ordered(self.args):\n            if p.has(Wild, WildFunction) and (not expr.has(p)):\n                # not all Wild should stay Wilds, for example:\n                # (w2+w3).matches(w1) -> (w1+w3).matches(w1) -> w3.matches(0)\n                wild_part.append(p)\n            else:\n                exact_part.append(p)\n\n        if exact_part:\n            exact = self.func(*exact_part)\n            free = expr.free_symbols\n            if free and (exact.free_symbols - free):\n                # there are symbols in the exact part that are not\n                # in the expr; but if there are no free symbols, let\n                # the matching continue\n                return None\n            newpattern = self.func(*wild_part)\n            newexpr = self._combine_inverse(expr, exact)\n            if not old and (expr.is_Add or expr.is_Mul):\n                if newexpr.count_ops() > expr.count_ops():\n                    return None\n            return newpattern.matches(newexpr, repl_dict)\n\n        # now to real work ;)\n        i = 0\n        saw = set()\n        while expr not in saw:\n            saw.add(expr)\n            expr_list = (self.identity,) + tuple(ordered(self.make_args(expr)))\n            for last_op in reversed(expr_list):\n                for w in reversed(wild_part):\n                    d1 = w.matches(last_op, repl_dict)\n                    if d1 is not None:\n                        d2 = self.xreplace(d1).matches(expr, d1)\n                        if d2 is not None:\n                            return d2\n\n            if i == 0:\n                if self.is_Mul:\n                    # make e**i look like Mul\n                    if expr.is_Pow and expr.exp.is_Integer:\n                        if expr.exp > 0:\n                            expr = Mul(*[expr.base, expr.base**(expr.exp - 1)], evaluate=False)\n                        else:\n                            expr = Mul(*[1/expr.base, expr.base**(expr.exp + 1)], evaluate=False)\n                        i += 1\n                        continue\n\n                elif self.is_Add:\n                    # make i*e look like Add\n                    c, e = expr.as_coeff_Mul()\n                    if abs(c) > 1:\n                        if c > 0:\n                            expr = Add(*[e, (c - 1)*e], evaluate=False)\n                        else:\n                            expr = Add(*[-e, (c + 1)*e], evaluate=False)\n                        i += 1\n                        continue\n\n                    # try collection on non-Wild symbols\n                    from sympy.simplify.radsimp import collect\n                    was = expr\n                    did = set()\n                    for w in reversed(wild_part):\n                        c, w = w.as_coeff_mul(Wild)\n                        free = c.free_symbols - did\n                        if free:\n                            did.update(free)\n                            expr = collect(expr, free)\n                    if expr != was:\n                        i += 0\n                        continue\n\n                break  # if we didn't continue, there is nothing more to do\n\n        return"
        }
      ]
    },
    {
      "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_id": 13711,
      "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_closed_at": "2017-12-09T21:00:49Z",
      "base_commit": "e01729f7e7f9d43df711084dde431aad4461b792",
      "changes": [
        {
          "file": "sympy/printing/llvmjitcode.py",
          "type": "function",
          "name": "_compile_function",
          "class_name": "LLVMJitCode",
          "code": "def _compile_function(self, strmod):\n        global exe_engines\n        llmod = llvm.parse_assembly(strmod)\n\n        pmb = llvm.create_pass_manager_builder()\n        pmb.opt_level = 2\n        pass_manager = llvm.create_module_pass_manager()\n        pmb.populate(pass_manager)\n\n        pass_manager.run(llmod)\n\n        target_machine = \\\n            llvm.Target.from_default_triple().create_target_machine()\n        exe_eng = llvm.create_mcjit_compiler(llmod, target_machine)\n        exe_eng.finalize_object()\n        exe_engines.append(exe_eng)\n\n        if False:\n            print(\"Assembly\")\n            print(target_machine.emit_assembly(llmod))\n\n        fptr = exe_eng.get_pointer_to_function(\n            llmod.get_function(self.link_name))\n\n        return fptr"
        }
      ]
    },
    {
      "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_id": 13598,
      "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_closed_at": "2017-11-29T07:32:30Z",
      "base_commit": "a67e45eecc972b53e95effb09fe503a05325d3f5",
      "changes": [
        {
          "file": "sympy/printing/codeprinter.py",
          "type": "function",
          "name": "_print_Assignment",
          "class_name": "CodePrinter",
          "code": "def _print_Assignment(self, expr):\n        from sympy.functions.elementary.piecewise import Piecewise\n        from sympy.matrices.expressions.matexpr import MatrixSymbol\n        from sympy.tensor.indexed import IndexedBase\n        lhs = expr.lhs\n        rhs = expr.rhs\n        # We special case assignments that take multiple lines\n        if isinstance(expr.rhs, Piecewise):\n            # Here we modify Piecewise so each expression is now\n            # an Assignment, and then continue on the print.\n            expressions = []\n            conditions = []\n            for (e, c) in rhs.args:\n                expressions.append(Assignment(lhs, e))\n                conditions.append(c)\n            temp = Piecewise(*zip(expressions, conditions))\n            return self._print(temp)\n        elif isinstance(lhs, MatrixSymbol):\n            # Here we form an Assignment for each element in the array,\n            # printing each one.\n            lines = []\n            for (i, j) in self._traverse_matrix_indices(lhs):\n                temp = Assignment(lhs[i, j], rhs[i, j])\n                code0 = self._print(temp)\n                lines.append(code0)\n            return \"\\n\".join(lines)\n        elif self._settings[\"contract\"] and (lhs.has(IndexedBase) or\n                rhs.has(IndexedBase)):\n            # Here we check if there is looping to be done, and if so\n            # print the required loops.\n            return self._doprint_loops(rhs, lhs)\n        else:\n            lhs_code = self._print(lhs)\n            rhs_code = self._print(rhs)\n            return self._get_statement(\"%s = %s\" % (lhs_code, rhs_code))"
        },
        {
          "file": "sympy/printing/pycode.py",
          "type": "function",
          "name": "_module_format",
          "class_name": "PythonCodePrinter",
          "code": "def _module_format(self, fqn, register=True):\n        parts = fqn.split('.')\n        if register and len(parts) > 1:\n            self.module_imports['.'.join(parts[:-1])].add(parts[-1])\n\n        if self._settings['fully_qualified_modules']:\n            return fqn\n        else:\n            return fqn.split('(')[0].split('[')[0].split('.')[-1]"
        }
      ]
    },
    {
      "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\u22c5log(y)\n```\n",
      "issue_id": 6988,
      "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   \u239b x\u239e\nlog\u239d\u212f \u23a0\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x\u22c5log(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_closed_at": "2014-12-03T13:34:14Z",
      "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023",
      "changes": [
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_expand_log",
          "class_name": "log",
          "code": "def _eval_expand_log(self, deep=True, **hints):\n        from sympy import unpolarify\n        from sympy.concrete import Sum, Product\n        force = hints.get('force', False)\n        arg = self.args[0]\n        if arg.is_Integer:\n            # remove perfect powers\n            p = perfect_power(int(arg))\n            if p is not False:\n                return p[1]*self.func(p[0])\n        elif arg.is_Mul:\n            expr = []\n            nonpos = []\n            for x in arg.args:\n                if force or x.is_positive or x.is_polar:\n                    a = self.func(x)\n                    if isinstance(a, log):\n                        expr.append(self.func(x)._eval_expand_log(**hints))\n                    else:\n                        expr.append(a)\n                elif x.is_negative:\n                    a = self.func(-x)\n                    expr.append(a)\n                    nonpos.append(S.NegativeOne)\n                else:\n                    nonpos.append(x)\n            return Add(*expr) + log(Mul(*nonpos))\n        elif arg.is_Pow:\n            if force or (arg.exp.is_real and arg.base.is_positive) or \\\n                    arg.base.is_polar:\n                b = arg.base\n                e = arg.exp\n                a = self.func(b)\n                if isinstance(a, log):\n                    return unpolarify(e) * a._eval_expand_log(**hints)\n                else:\n                    return unpolarify(e) * a\n        elif isinstance(arg, Product):\n            if arg.function.is_positive:\n                return Sum(log(arg.function), *arg.limits)\n\n        return self.func(arg)"
        }
      ]
    }
  ]
}