{
  "instance_id": "sympy__sympy-23262",
  "repo": "sympy/sympy",
  "created_at": "2022-03-21T07:17:35Z",
  "problem_statement": "Python code printer not respecting tuple with one element\nHi,\r\n\r\nThanks for the recent updates in SymPy! I'm trying to update my code to use SymPy 1.10 but ran into an issue with the Python code printer. MWE:\r\n\r\n\r\n```python\r\nimport inspect\r\nfrom sympy import lambdify\r\n\r\ninspect.getsource(lambdify([], tuple([1])))\r\n```\r\nSymPy 1.9 and under outputs:\r\n```\r\n'def _lambdifygenerated():\\n    return (1,)\\n'\r\n```\r\n\r\nBut SymPy 1.10 gives\r\n\r\n```\r\n'def _lambdifygenerated():\\n    return (1)\\n'\r\n```\r\nNote the missing comma after `1` that causes an integer to be returned instead of a tuple. \r\n\r\nFor tuples with two or more elements, the generated code is correct:\r\n```python\r\ninspect.getsource(lambdify([], tuple([1, 2])))\r\n```\r\nIn SymPy  1.10 and under, outputs:\r\n\r\n```\r\n'def _lambdifygenerated():\\n    return (1, 2)\\n'\r\n```\r\nThis result is expected.\r\n\r\nNot sure if this is a regression. As this breaks my program which assumes the return type to always be a tuple, could you suggest a workaround from the code generation side? Thank you. \n",
  "patch": "diff --git a/sympy/utilities/lambdify.py b/sympy/utilities/lambdify.py\n--- a/sympy/utilities/lambdify.py\n+++ b/sympy/utilities/lambdify.py\n@@ -956,9 +956,9 @@ def _recursive_to_string(doprint, arg):\n         return doprint(arg)\n     elif iterable(arg):\n         if isinstance(arg, list):\n-            left, right = \"[]\"\n+            left, right = \"[\", \"]\"\n         elif isinstance(arg, tuple):\n-            left, right = \"()\"\n+            left, right = \"(\", \",)\"\n         else:\n             raise NotImplementedError(\"unhandled type: %s, %s\" % (type(arg), arg))\n         return left +', '.join(_recursive_to_string(doprint, e) for e in arg) + right\n",
  "similar_bug_items": [
    {
      "pr_number": 15519,
      "pr_title": "Exit _eval_derivative_n_times when None is obtained",
      "pr_body": "#### References to other Issues or PRs\r\n\r\nFixes #15518 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nThe method `_eval_derivative_n_times` contains a loop that involves calling `_eval_derivative`. The latter may return None when evaluation is not implemented. In such a case the loop should be aborted (returning None) instead of trying to differentiate None.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* core\r\n  * Fixed a bug in the creation of higher order derivatives that cannot be evaluated.  \r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 15518,
      "issue_title": "Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception",
      "issue_body": "This issue arose in a [comment on another issue]( https://github.com/sympy/sympy/issues/15457#issuecomment-436453327) but since it's actually unrelated, is posted here separately. \r\n```\r\n>>> re(x).diff(x, 2)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/ubuntu/sympy/sympy/core/expr.py\", line 3047, in diff\r\n    return Derivative(self, *symbols, **assumptions)\r\n  File \"/home/ubuntu/sympy/sympy/core/function.py\", line 1370, in __new__\r\n    obj = expr._eval_derivative_n_times(v, count)\r\n  File \"/home/ubuntu/sympy/sympy/core/basic.py\", line 1688, in _eval_derivative_n_times\r\n    obj2 = obj._accept_eval_derivative(s)\r\nAttributeError: 'NoneType' object has no attribute '_accept_eval_derivative'\r\n```\r\nThis happens whenever a higher-order derivative is requested for a function that does not have an explicit derivative. The expected output is \r\n```\r\nDerivative(re(x), (x, 2))\r\n```\r\nA PR is forthcoming. \r\n",
      "issue_closed_at": "2018-11-24T11:36:42Z",
      "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d",
      "changes": [
        {
          "file": "sympy/core/basic.py",
          "type": "function",
          "name": "_eval_derivative_n_times",
          "class_name": "Basic",
          "code": "def _eval_derivative_n_times(self, s, n):\n        # This is the default evaluator for derivatives (as called by `diff`\n        # and `Derivative`), it will attempt a loop to derive the expression\n        # `n` times by calling the corresponding `_eval_derivative` method,\n        # while leaving the derivative unevaluated if `n` is symbolic.  This\n        # method should be overridden if the object has a closed form for its\n        # symbolic n-th derivative.\n        from sympy import Integer\n        if isinstance(n, (int, Integer)):\n            obj = self\n            for i in range(n):\n                obj2 = obj._accept_eval_derivative(s)\n                if obj == obj2:\n                    break\n                obj = obj2\n            return obj\n        else:\n            return None"
        }
      ]
    },
    {
      "pr_number": 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": 18067,
      "pr_title": "Bump version on 1.5 branch to 1.5.1",
      "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\". See\r\nhttps://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n\r\nThis is due to #18063 which fixes #18056 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nBump the version to 1.5.1\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 18056,
      "issue_title": "Sympy incorrectly attempts to eval reprs in its __eq__ method",
      "issue_body": "Passing strings produced by unknown objects into eval is **very bad**. It is especially surprising for an equality check to trigger that kind of behavior. This should be fixed ASAP.\r\n\r\nRepro code:\r\n\r\n```\r\nimport sympy\r\nclass C:\r\n    def __repr__(self):\r\n        return 'x.y'\r\n_ = sympy.Symbol('x') == C()\r\n```\r\n\r\nResults in:\r\n\r\n```\r\nE   AttributeError: 'Symbol' object has no attribute 'y'\r\n```\r\n\r\nOn the line:\r\n\r\n```\r\n    expr = eval(\r\n        code, global_dict, local_dict)  # take local objects in preference\r\n```\r\n\r\nWhere code is:\r\n\r\n```\r\nSymbol ('x' ).y\r\n```\r\n\r\nFull trace:\r\n\r\n```\r\nFAILED                   [100%]\r\n        class C:\r\n            def __repr__(self):\r\n                return 'x.y'\r\n    \r\n>       _ = sympy.Symbol('x') == C()\r\n\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \r\nsympy/core/expr.py:124: in __eq__\r\n    other = sympify(other)\r\nsympy/core/sympify.py:385: in sympify\r\n    expr = parse_expr(a, local_dict=locals, transformations=transformations, evaluate=evaluate)\r\nsympy/parsing/sympy_parser.py:1011: in parse_expr\r\n    return eval_expr(code, local_dict, global_dict)\r\nsympy/parsing/sympy_parser.py:906: in eval_expr\r\n    code, global_dict, local_dict)  # take local objects in preference\r\n_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ \r\n\r\n>   ???\r\nE   AttributeError: 'Symbol' object has no attribute 'y'\r\n\r\n<string>:1: AttributeError\r\n```\r\n\r\nRelated issue: an unknown object whose repr is `x` will incorrectly compare as equal to a sympy symbol x:\r\n\r\n```\r\n    class C:\r\n        def __repr__(self):\r\n            return 'x'\r\n\r\n    assert sympy.Symbol('x') != C()  # fails\r\n```",
      "issue_closed_at": "2019-12-18T00:18:29Z",
      "base_commit": "e8f3ded02ec7a92ae7931d2fbd379853d483e143",
      "changes": [
        {
          "file": "sympy/release.py",
          "type": "line",
          "name": "line 1",
          "code": "__version__ = \"1.5\""
        }
      ]
    },
    {
      "pr_number": 9009,
      "pr_title": "MatrixExpr: add MatPow doit(), changes to doit for MatAdd, MatMul, Trace",
      "pr_body": "I'm been looking at `doit()` support in MatrixExpr.  In particular, I'm interested in cases where these have ImmutableMatrices inside and they could be evaluated (e.g., after a substitution).\n\nHere are some fixes:\n- MatPow: added `doit()`.\n- MatPow: refactor my older `.as_explicit()` code to use the the `doit()`.\n- MatAdd: had rather ineffective `doit()`, improved.\n- MatMul: change the default from `deep=False` to `deep=True`.  I cannot find a reason for it, so I've switched it.\n- MatMul: clean up test code.\n- Trace: change the default to `deep=True`.\n\nThe `deep=True` changes might be controversial: if someone knows why it `deep=False` before, I could always revert that (and add a comment to the code!)\n\nAnyway, here is what it does:\n\n```\nIn [6]: A = Matrix([[1,2],[3,4]])\n\nIn [7]: B = Matrix([[2,3],[4,5]])\n\nIn [8]: n = Symbol('n', integer=True)\n\nIn [9]: w = MatPow(A, n) + MatMul(A, MatPow(B,2*n))\n\nIn [10]: pprint(w)\n               2\u22c5n           n\n\u23a11  2\u23a4\u22c5\u239b\u23a12  3\u23a4\u239e    + \u239b\u23a11  2\u23a4\u239e \n\u23a2    \u23a5 \u239c\u23a2    \u23a5\u239f      \u239c\u23a2    \u23a5\u239f \n\u23a33  4\u23a6 \u239d\u23a34  5\u23a6\u23a0      \u239d\u23a33  4\u23a6\u23a0 \n\nIn [21]: pprint(w.subs(n, 1))\n               2           1\n\u23a11  2\u23a4\u22c5\u239b\u23a12  3\u23a4\u239e  + \u239b\u23a11  2\u23a4\u239e \n\u23a2    \u23a5 \u239c\u23a2    \u23a5\u239f    \u239c\u23a2    \u23a5\u239f \n\u23a33  4\u23a6 \u239d\u23a34  5\u23a6\u23a0    \u239d\u23a33  4\u23a6\u23a0 \n\nIn [22]: pprint(w.subs(n, 1).doit())    % these fixes make this work\n\u23a173   97 \u23a4\n\u23a2        \u23a5\n\u23a3163  215\u23a6\n```\n",
      "issue_id": 8138,
      "issue_title": "MatExpr.doit: deep default should be True for Expr (and still False for MatExpr?)",
      "issue_body": "I notice `MatExpr.doit()` has deep defaulting to False.  I assume that is deliberate (forget where but recall it looked deliberate).\n\nAnyway, deep should probably still default to True for any `Expr` (i.e., non-Matrix) it encounters.  \n\nConsider the following current behaviour:\n\n```\nx = S('x')\nn = S('n')\nA = MatrixSymbol('A', n, n)\nfive = Add(2, 3, evaluate=False)\n\nf = five*x\nG = five*A\n\nf.doit()\n# gives: 5*x\n\nG.doit()\n# gives: (2 + 3)*A\n```\n\nSame for `MatPow` where I saw this.\n",
      "issue_closed_at": "2015-02-19T04:28:17Z",
      "base_commit": "cf171b2f088bc6985f5973972425fa0a9fc65f31",
      "changes": [
        {
          "file": "sympy/matrices/expressions/matadd.py",
          "type": "function",
          "name": "_eval_trace",
          "class_name": "MatAdd",
          "code": "def _eval_trace(self):\n        from trace import Trace\n        return MatAdd(*[Trace(arg) for arg in self.args]).doit()"
        },
        {
          "file": "sympy/matrices/expressions/matmul.py",
          "type": "function",
          "name": "_eval_inverse",
          "class_name": "MatMul",
          "code": "def _eval_inverse(self):\n        try:\n            return MatMul(*[\n                arg.inverse() if isinstance(arg, MatrixExpr) else arg**-1\n                    for arg in self.args[::-1]]).doit()\n        except ShapeError:\n            from sympy.matrices.expressions.inverse import Inverse\n            return Inverse(self)"
        },
        {
          "file": "sympy/matrices/expressions/matpow.py",
          "type": "function",
          "name": "shape",
          "class_name": "MatPow",
          "code": "def shape(self):\n        return self.base.shape"
        },
        {
          "file": "sympy/matrices/expressions/trace.py",
          "type": "function",
          "name": "arg",
          "class_name": "Trace",
          "code": "def arg(self):\n        return self.args[0]"
        }
      ]
    },
    {
      "pr_number": 10889,
      "pr_title": "Fixed bug in Latex printing",
      "pr_body": "This should fix #10821; the Latex _print_Mul function was inserting a negative sign at the beginning of a negative expression without worrying about parenthesis.\n",
      "issue_id": 10821,
      "issue_title": "latex bug for commutator output",
      "issue_body": "There is a latex bug in the output of the function sympy.physics.quantum.commutator.doit that gives incorrect result if there is overall negative sign involved. For example, the following code does not give the correct expression for the latex output.\n\n``` python\nfrom sympy.physics.quantum import Commutator, Operator\nimport sympy\nA = Operator('A')\nB = Operator('B')\ncomm = Commutator(B, A)\nprint comm.doit()\nsympy.latex(comm.doit())\n```\n",
      "issue_closed_at": "2016-03-23T20:40:37Z",
      "base_commit": "f7a8dbec25b04767a3a6996c11a03781184d45d7",
      "changes": [
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "_print_Float",
          "class_name": "LatexPrinter",
          "code": "def _print_Float(self, expr):\n        # Based off of that in StrPrinter\n        dps = prec_to_dps(expr._prec)\n        str_real = mlib.to_str(expr._mpf_, dps, strip_zeros=True)\n\n        # Must always have a mul symbol (as 2.5 10^{20} just looks odd)\n        # thus we use the number separator\n        separator = self._settings['mul_symbol_latex_numbers']\n\n        if 'e' in str_real:\n            (mant, exp) = str_real.split('e')\n\n            if exp[0] == '+':\n                exp = exp[1:]\n\n            return r\"%s%s10^{%s}\" % (mant, separator, exp)\n        elif str_real == \"+inf\":\n            return r\"\\infty\"\n        elif str_real == \"-inf\":\n            return r\"- \\infty\"\n        else:\n            return str_real"
        },
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "convert",
          "class_name": "LatexPrinter",
          "code": "def convert(expr):\n            if not expr.is_Mul:\n                return str(self._print(expr))\n            else:\n                _tex = last_term_tex = \"\"\n\n                if self.order not in ('old', 'none'):\n                    args = expr.as_ordered_factors()\n                else:\n                    args = expr.args\n\n                for i, term in enumerate(args):\n                    term_tex = self._print(term)\n\n                    if self._needs_mul_brackets(term, first=(i == 0),\n                                                last=(i == len(args) - 1)):\n                        term_tex = r\"\\left(%s\\right)\" % term_tex\n\n                    if re.search(\"[0-9][} ]*$\", last_term_tex) and \\\n                            re.match(\"[{ ]*[-+0-9]\", term_tex):\n                        # between two numbers\n                        _tex += numbersep\n                    elif _tex:\n                        _tex += separator\n\n                    _tex += term_tex\n                    last_term_tex = term_tex\n                return _tex"
        }
      ]
    }
  ]
}