{
  "instance_id": "sympy__sympy-15345",
  "repo": "sympy/sympy",
  "created_at": "2018-10-05T06:00:31Z",
  "problem_statement": "mathematica_code gives wrong output with Max\nIf I run the code\r\n\r\n```\r\nx = symbols('x')\r\nmathematica_code(Max(x,2))\r\n```\r\n\r\nthen I would expect the output `'Max[x,2]'` which is valid Mathematica code but instead I get `'Max(2, x)'` which is not valid Mathematica code.\n",
  "patch": "diff --git a/sympy/printing/mathematica.py b/sympy/printing/mathematica.py\n--- a/sympy/printing/mathematica.py\n+++ b/sympy/printing/mathematica.py\n@@ -31,7 +31,8 @@\n     \"asech\": [(lambda x: True, \"ArcSech\")],\n     \"acsch\": [(lambda x: True, \"ArcCsch\")],\n     \"conjugate\": [(lambda x: True, \"Conjugate\")],\n-\n+    \"Max\": [(lambda *x: True, \"Max\")],\n+    \"Min\": [(lambda *x: True, \"Min\")],\n }\n \n \n@@ -101,6 +102,8 @@ def _print_Function(self, expr):\n                     return \"%s[%s]\" % (mfunc, self.stringify(expr.args, \", \"))\n         return expr.func.__name__ + \"[%s]\" % self.stringify(expr.args, \", \")\n \n+    _print_MinMaxBase = _print_Function\n+\n     def _print_Integral(self, expr):\n         if len(expr.variables) == 1 and not expr.limits[0][1:]:\n             args = [expr.args[0], expr.variables[0]]\n",
  "similar_bug_items": [
    {
      "pr_number": 13564,
      "pr_title": "Resolves RecursionError in latex representation",
      "pr_body": "fixes #13559. It was due to factor of `1/1`  \r\n```python\r\nexpr = parse_expr('5/1', evaluate=False)\r\nexpr.args\r\n```\r\nit gives `(5 , 1/1)` , which was not handled properly in latex conversion . So everytime an expression was divided by 1 , it resulted in RecursionError",
      "issue_id": 13559,
      "issue_title": "LaTeX representation raises RecursionError",
      "issue_body": "LaTeX representation of an expression that has division by 1 causes `RecursionError`. SymPy version: 1.1.1.\r\n\r\nCode to reproduce the bug:\r\n```python\r\nfrom sympy import latex\r\nfrom sympy.parsing.sympy_parser import parse_expr\r\n\r\nexpr = parse_expr('2/1', evaluate=False)\r\nlatex(expr)\r\n```\r\nOutput:\r\n```\r\n...\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/printer.py in _print(self, expr, *args, **kwargs)\r\n    255                 printmethod = '_print_' + cls.__name__\r\n    256                 if hasattr(self, printmethod):\r\n--> 257                     return getattr(self, printmethod)(expr, *args, **kwargs)\r\n    258             # Unknown object, fall back to the emptyPrinter.\r\n    259             return self.emptyPrinter(expr)\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in _print_Pow(self, expr)\r\n    466         elif expr.exp.is_Rational and expr.exp.is_negative and expr.base.is_commutative:\r\n    467             # Things like 1/x\r\n--> 468             return self._print_Mul(expr)\r\n    469         else:\r\n    470             if expr.base.is_Function:\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in _print_Mul(self, expr)\r\n    396             # use the original expression here, since fraction() may have\r\n    397             # altered it when producing numer and denom\r\n--> 398             tex += convert(expr)\r\n    399         else:\r\n    400             snumer = convert(numer)\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in convert(expr)\r\n    366         def convert(expr):\r\n    367             if not expr.is_Mul:\r\n--> 368                 return str(self._print(expr))\r\n    369             else:\r\n    370                 _tex = last_term_tex = \"\"\r\n\r\n... last 4 frames repeated, from the frame below ...\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/printer.py in _print(self, expr, *args, **kwargs)\r\n    255                 printmethod = '_print_' + cls.__name__\r\n    256                 if hasattr(self, printmethod):\r\n--> 257                     return getattr(self, printmethod)(expr, *args, **kwargs)\r\n    258             # Unknown object, fall back to the emptyPrinter.\r\n    259             return self.emptyPrinter(expr)\r\n\r\nRecursionError: maximum recursion depth exceeded in comparison\r\n```\r\n",
      "issue_closed_at": "2017-11-09T16:49:04Z",
      "base_commit": "36d9c850c642bec047e2cbad0a07c48f4fc7c779",
      "changes": [
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "_print_Gradient",
          "class_name": "LatexPrinter",
          "code": "def _print_Gradient(self, expr):\n        func = expr._expr\n        return r\"\\nabla\\cdot %s\" % self.parenthesize(func, PRECEDENCE['Mul'])"
        },
        {
          "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 _between_two_numbers_p[0].search(last_term_tex) and \\\n                            _between_two_numbers_p[1].match(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"
        }
      ]
    },
    {
      "pr_number": 2980,
      "pr_title": "Store S.true/false in Interval.left_open/right_open",
      "pr_body": "fixes #6211\n",
      "issue_id": 6211,
      "issue_title": "Interval has non-Basic args",
      "issue_body": "```\nInterval stores bools in its args, which causes problems such as:\n\nIn [1]: Interval(0, 1).free_symbols\n---------------------------------------------------------------------------\nAttributeError                            Traceback (most recent call last)\n/home/ronan/dev/sympy/<ipython-input-1-b6834b9d186c> in <module>()\n----> 1 Interval(0, 1).free_symbols\n\n/home/ronan/dev/sympy/sympy/core/basic.pyc in free_symbols(self)\n    599         method.\"\"\"\n    600         union = set.union\n--> 601         return reduce(union, [arg.free_symbols for arg in self.args], set())\n    602 \n    603     def is_hypergeometric(self, k):\n\nAttributeError: 'bool' object has no attribute 'free_symbols'\n\nThis is an instance of issue 5169 , and issue 5630 isn't a real solution as .left_open and .right_open don't actually have a symbolic interpretation. \n\nOne (not terribly clean) way of dealing with this would be to create 4 subclasses - one each combination of (left_open, right_open).\n```\n\nOriginal issue for #6211: http://code.google.com/p/sympy/issues/detail?id=3112\nOriginal author: https://code.google.com/u/101272611947379421629/\nReferenced issues: #5630\n",
      "issue_closed_at": "2014-03-23T23:34:17Z",
      "base_commit": "89a43fdd75cce7ce3e6ec7e0e7af952e0cefa31d",
      "changes": [
        {
          "file": "sympy/core/sets.py",
          "type": "function",
          "name": "__new__",
          "class_name": "FiniteSet",
          "code": "def __new__(cls, *args, **kwargs):\n        evaluate = kwargs.get('evaluate', True)\n        if evaluate:\n            if len(args) == 1 and iterable(args[0]):\n                args = args[0]\n\n            args = list(map(sympify, args))\n\n            if len(args) == 0:\n                return EmptySet()\n\n\n        args = frozenset(args)  # remove duplicates\n        obj = Basic.__new__(cls, *args)\n        obj._elements = args\n        return obj"
        },
        {
          "file": "sympy/core/sets.py",
          "type": "function",
          "name": "__new__",
          "class_name": "FiniteSet",
          "code": "def __new__(cls, *args, **kwargs):\n        evaluate = kwargs.get('evaluate', True)\n        if evaluate:\n            if len(args) == 1 and iterable(args[0]):\n                args = args[0]\n\n            args = list(map(sympify, args))\n\n            if len(args) == 0:\n                return EmptySet()\n\n\n        args = frozenset(args)  # remove duplicates\n        obj = Basic.__new__(cls, *args)\n        obj._elements = args\n        return obj"
        },
        {
          "file": "sympy/core/sets.py",
          "type": "function",
          "name": "as_relational",
          "class_name": "FiniteSet",
          "code": "def as_relational(self, symbol):\n        \"\"\"Rewrite a FiniteSet in terms of equalities and logic operators. \"\"\"\n        from sympy.core.relational import Eq\n        return Or(*[Eq(symbol, elem) for elem in self])"
        }
      ]
    },
    {
      "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": 14697,
      "pr_title": "Recompute unbranched argument in principal_branch",
      "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 .-->\r\n\r\nFixes #14692 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nmeijerint receives an incorrect value from principal_branch for an argument involving\r\n the inverse of polar_lift of a negative symbol. This is fixed by adding another check.\r\n\r\n",
      "issue_id": 14692,
      "issue_title": "positive != -negative in some integrals",
      "issue_body": "```\r\n>>> a = Symbol('a', positive=True)\r\n>>> b = Symbol('b', negative=True)\r\n>>> laplace_transform(1/(I*t + a), t, s) \r\n(-I*exp(-I*a*s)*expint(1, a*s*exp_polar(-I*pi/2)), 0, True)\r\n>>> laplace_transform(1/(I*t - b), t, s) \r\nLaplaceTransform(1/(-b + I*t), t, s)\r\n```\r\nIt seems that a constant that is used to determine the convergence in `meijerint` is incorrectly evaluated in the latter case.",
      "issue_closed_at": "2018-05-04T18:43:10Z",
      "base_commit": "6e95230e0ee183a4fb8803a7e49d7744f0a0025c",
      "changes": [
        {
          "file": "sympy/functions/elementary/complexes.py",
          "type": "function",
          "name": "mr",
          "class_name": "principal_branch",
          "code": "def mr(expr):\n                if not isinstance(expr, Symbol):\n                    return polar_lift(expr)\n                return expr"
        }
      ]
    },
    {
      "pr_number": 9647,
      "pr_title": "autowrap: Don't fail if we can't delete the temporary directory",
      "pr_body": "Fixes #8432.\n",
      "issue_id": 8432,
      "issue_title": "Tests fail, seems like Cython is not configured to compile with numpy correctly",
      "issue_body": "Following are the standard output:\n\n```\nD:\\sympytest>git clone git@github.com:sympy/sympy.git\nCloning into 'sympy'...\nremote: Counting objects: 153742, done.\nremote: Compressing objects: 100% (4/4), done.\nReceiving objects: 100% (153742/153742), 62.98 MiB | 13.00 KiB/s, done.\n\nResolving deltas: 100% (122073/122073), done.\nChecking connectivity... done\n\nsh-3.1$ cd sympy\n\nsh-3.1$ ./bin/test |tee test.log\n======================================================= test process starts =======================================================\nexecutable:         c:\\Python\\python.exe  (2.7.8-final-0) [CPython]\narchitecture:       32-bit\ncache:              yes\nground types:       python\nrandom seed:        68232668\nhash randomization: on (PYTHONHASHSEED=2780600447)\n\nsympy\\assumptions\\tests\\test_assumptions_2.py[5] .....                                                                         [OK]\nsympy\\assumptions\\tests\\test_context.py[4] ....                                                                                [OK]\nsympy\\assumptions\\tests\\test_matrices.py[19] ..........ff.......                                                               [OK]\n\n\n\n__________________________________________________________ xpassed tests __________________________________________________________\nsympy\\core\\tests\\test_wester.py: test_V12\nsympy\\core\\tests\\test_wester.py: test_T10\nsympy\\printing\\tests\\test_gtk.py: test_1\nsympy\\utilities\\tests\\test_module_imports.py: test_module_imports_are_direct\n\n___________________________________________________________________________________________________________________________________\n_________________________________ sympy\\external\\tests\\test_autowrap.py:test_wrap_twice_c_cython __________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 138, in test_wrap_twice_c_cython\n    runtest_autowrap_twice('C', 'cython')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 51, in runtest_autowrap_twice\n    f = autowrap((((a + b)/c)**5).expand(), language, backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 872, in wrapper\n    result = user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 508, in autowrap\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 151, in wrap_code\n    shutil.rmtree(workdir)\n  File \"c:\\Python\\lib\\shutil.py\", line 252, in rmtree\n    onerror(os.remove, fullname, sys.exc_info())\n  File \"c:\\Python\\lib\\shutil.py\", line 250, in rmtree\n    os.remove(fullname)\nWindowsError: [Error 5] Access is denied: 'c:\\\\users\\\\pecker\\\\appdata\\\\local\\\\temp\\\\tmpgz2ecp_sympy_compile\\\\wrapper_module_1.pyd'\n___________________________________________________________________________________________________________________________________\n_______________________________ sympy\\external\\tests\\test_autowrap.py:test_autowrap_trace_C_Cython ________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 143, in test_autowrap_trace_C_Cython\n    runtest_autowrap_trace('C', 'cython')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 61, in runtest_autowrap_trace\n    trace = autowrap(A[i, i], language, backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 872, in wrapper\n    result = user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 508, in autowrap\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 144, in wrap_code\n    self._process_files(routine)\n  File \"sympy\\utilities\\autowrap.py\", line 163, in _process_files\n    \" \".join(command), e.output.decode()))\nCodeWrapError: Error while executing command: c:\\Python\\python.exe setup.py build_ext --inplace. Command output is:\nrunning build_ext\ncythoning wrapper_module_2.pyx to wrapper_module_2.c\nbuilding 'wrapper_module_2' extension\ncreating build\ncreating build\\temp.win-amd64-2.7\ncreating build\\temp.win-amd64-2.7\\Release\nc:\\Python\\MinGW\\bin\\gcc.exe -DMS_WIN64 -mdll -O -Wall -Ic:\\Python\\include -Ic:\\Python\\PC -c wrapper_module_2.c -o build\\temp.win-amd64-2.7\\Release\\wrapper_module_2.o -std=c99\nwrapper_module_2.c:232:31: fatal error: numpy/arrayobject.h: No such file or directory\ncompilation terminated.\nerror: command 'c:\\\\Python\\\\MinGW\\\\bin\\\\gcc.exe' failed with exit status 1\n\n___________________________________________________________________________________________________________________________________\n___________________________ sympy\\external\\tests\\test_autowrap.py:test_autowrap_matrix_vector_C_cython ____________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 148, in test_autowrap_matrix_vector_C_cython\n    runtest_autowrap_matrix_vector('C', 'cython')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 69, in runtest_autowrap_matrix_vector\n    mv = autowrap(expr, language, backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 872, in wrapper\n    result = user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 508, in autowrap\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 144, in wrap_code\n    self._process_files(routine)\n  File \"sympy\\utilities\\autowrap.py\", line 163, in _process_files\n    \" \".join(command), e.output.decode()))\nCodeWrapError: Error while executing command: c:\\Python\\python.exe setup.py build_ext --inplace. Command output is:\nrunning build_ext\ncythoning wrapper_module_3.pyx to wrapper_module_3.c\nbuilding 'wrapper_module_3' extension\ncreating build\ncreating build\\temp.win-amd64-2.7\ncreating build\\temp.win-amd64-2.7\\Release\nc:\\Python\\MinGW\\bin\\gcc.exe -DMS_WIN64 -mdll -O -Wall -Ic:\\Python\\include -Ic:\\Python\\PC -c wrapper_module_3.c -o build\\temp.win-amd64-2.7\\Release\\wrapper_module_3.o -std=c99\nwrapper_module_3.c:232:31: fatal error: numpy/arrayobject.h: No such file or directory\ncompilation terminated.\nerror: command 'c:\\\\Python\\\\MinGW\\\\bin\\\\gcc.exe' failed with exit status 1\n\n___________________________________________________________________________________________________________________________________\n___________________________ sympy\\external\\tests\\test_autowrap.py:test_autowrap_matrix_matrix_C_cython ____________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 153, in test_autowrap_matrix_matrix_C_cython\n    runtest_autowrap_matrix_matrix('C', 'cython')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 81, in runtest_autowrap_matrix_matrix\n    matmat = autowrap(expr, language, backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 872, in wrapper\n    result = user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 508, in autowrap\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 144, in wrap_code\n    self._process_files(routine)\n  File \"sympy\\utilities\\autowrap.py\", line 163, in _process_files\n    \" \".join(command), e.output.decode()))\nCodeWrapError: Error while executing command: c:\\Python\\python.exe setup.py build_ext --inplace. Command output is:\nrunning build_ext\ncythoning wrapper_module_4.pyx to wrapper_module_4.c\nbuilding 'wrapper_module_4' extension\ncreating build\ncreating build\\temp.win-amd64-2.7\ncreating build\\temp.win-amd64-2.7\\Release\nc:\\Python\\MinGW\\bin\\gcc.exe -DMS_WIN64 -mdll -O -Wall -Ic:\\Python\\include -Ic:\\Python\\PC -c wrapper_module_4.c -o build\\temp.win-amd64-2.7\\Release\\wrapper_module_4.o -std=c99\nwrapper_module_4.c:232:31: fatal error: numpy/arrayobject.h: No such file or directory\ncompilation terminated.\nerror: command 'c:\\\\Python\\\\MinGW\\\\bin\\\\gcc.exe' failed with exit status 1\n\n___________________________________________________________________________________________________________________________________\n__________________________________ sympy\\external\\tests\\test_autowrap.py:test_ufuncify_C_Cython ___________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 158, in test_ufuncify_C_Cython\n    runtest_ufuncify('C', 'cython')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 93, in runtest_ufuncify\n    fabc = ufuncify([a, b, c], a*b + c, backend=backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 857, in wrapper\n    return user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 878, in ufuncify\n    tempdir, args, flags, verbose, helpers)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 857, in wrapper\n    return user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 508, in autowrap\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 144, in wrap_code\n    self._process_files(routine)\n  File \"sympy\\utilities\\autowrap.py\", line 163, in _process_files\n    \" \".join(command), e.output.decode()))\nCodeWrapError: Error while executing command: c:\\Python\\python.exe setup.py build_ext --inplace. Command output is:\nrunning build_ext\ncythoning wrapper_module_5.pyx to wrapper_module_5.c\nbuilding 'wrapper_module_5' extension\ncreating build\ncreating build\\temp.win-amd64-2.7\ncreating build\\temp.win-amd64-2.7\\Release\nc:\\Python\\MinGW\\bin\\gcc.exe -DMS_WIN64 -mdll -O -Wall -Ic:\\Python\\include -Ic:\\Python\\PC -c wrapper_module_5.c -o build\\temp.win-amd64-2.7\\Release\\wrapper_module_5.o -std=c99\nwrapper_module_5.c:232:31: fatal error: numpy/arrayobject.h: No such file or directory\ncompilation terminated.\nerror: command 'c:\\\\Python\\\\MinGW\\\\bin\\\\gcc.exe' failed with exit status 1\n\n___________________________________________________________________________________________________________________________________\n____________________________________ sympy\\external\\tests\\test_autowrap.py:test_ufuncify_numpy ____________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 167, in test_ufuncify_numpy\n    runtest_ufuncify('C', 'numpy')\n  File \"d:\\sympytest\\sympy\\sympy\\external\\tests\\test_autowrap.py\", line 93, in runtest_ufuncify\n    fabc = ufuncify([a, b, c], a*b + c, backend=backend)\n  File \"sympy\\core\\cache.py\", line 91, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"sympy\\core\\compatibility.py\", line 857, in wrapper\n    return user_function(*args, **kwds)\n  File \"sympy\\utilities\\autowrap.py\", line 864, in ufuncify\n    return code_wrapper.wrap_code(routine, helpers=helps)\n  File \"sympy\\utilities\\autowrap.py\", line 151, in wrap_code\n    shutil.rmtree(workdir)\n  File \"c:\\Python\\lib\\shutil.py\", line 252, in rmtree\n    onerror(os.remove, fullname, sys.exc_info())\n  File \"c:\\Python\\lib\\shutil.py\", line 250, in rmtree\n    os.remove(fullname)\nWindowsError: [Error 5] Access is denied: 'c:\\\\users\\\\pecker\\\\appdata\\\\local\\\\temp\\\\tmpqfz1mc_sympy_compile\\\\wrapper_module_6.pyd'\n\n___________________________________________________________________________________________________________________________________\n____________________________ sympy\\interactive\\tests\\test_ipythonprinting.py:test_print_builtin_option ____________________________\n  File \"d:\\sympytest\\sympy\\sympy\\interactive\\tests\\test_ipythonprinting.py\", line 70, in test_print_builtin_option\n    assert text in (\"{pi: 3.14, n_i: 3}\", u('{n\\u1d62: 3, \\u03c0: 3.14}'))\nAssertionError\n___________________________________________________________________________________________________________________________________\n______________________________ sympy\\physics\\vector\\tests\\test_printing.py:test_vector_pretty_print _______________________________\n  File \"d:\\sympytest\\sympy\\sympy\\physics\\vector\\tests\\test_printing.py\", line 45, in test_vector_pretty_print\n    assert expected == pp.doprint(v)\nAssertionError\n___________________________________________________________________________________________________________________________________\n______________________________ sympy\\physics\\vector\\tests\\test_printing.py:test_dyadic_pretty_print _______________________________\n  File \"d:\\sympytest\\sympy\\sympy\\physics\\vector\\tests\\test_printing.py\", line 138, in test_dyadic_pretty_print\n    assert expected == result\nAssertionError\n___________________________________________________________________________________________________________________________________\n___________________________________ sympy\\plotting\\tests\\test_plot_implicit.py:test_matplotlib ____________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\plotting\\tests\\test_plot_implicit.py\", line 63, in test_matplotlib\n    plot_and_save('test')\n  File \"d:\\sympytest\\sympy\\sympy\\plotting\\tests\\test_plot_implicit.py\", line 58, in plot_and_save\n    assert 'No labeled objects found' in str(w[0].message)\nAssertionError\n___________________________________________________________________________________________________________________________________\n____________________________________ sympy\\vector\\tests\\test_printing.py:test_pretty_printing _____________________________________\n  File \"d:\\sympytest\\sympy\\sympy\\vector\\tests\\test_printing.py\", line 78, in test_pretty_printing\n    assert pretty(v[8]) == pretty_v_8\nAssertionError\n\n tests finished: 5678 passed, 5 failed, 138 skipped, 321 expected to fail, 4 expected to fail but passed, 6 exceptions, \nin 3051.11 seconds \nDO *NOT* COMMIT!\n```\n",
      "issue_closed_at": "2015-07-14T00:21:15Z",
      "base_commit": "eb5d3535df47d78d3c6ff95b603e4196fe867f08",
      "changes": [
        {
          "file": "sympy/utilities/autowrap.py",
          "type": "function",
          "name": "wrap_code",
          "class_name": "CodeWrapper",
          "code": "def wrap_code(self, routine, helpers=[]):\n\n        workdir = self.filepath or tempfile.mkdtemp(\"_sympy_compile\")\n        if not os.access(workdir, os.F_OK):\n            os.mkdir(workdir)\n        oldwork = os.getcwd()\n        os.chdir(workdir)\n        try:\n            sys.path.append(workdir)\n            self._generate_code(routine, helpers)\n            self._prepare_files(routine)\n            self._process_files(routine)\n            mod = __import__(self.module_name)\n        finally:\n            sys.path.remove(workdir)\n            CodeWrapper._module_counter += 1\n            os.chdir(oldwork)\n            if not self.filepath:\n                shutil.rmtree(workdir)\n\n        return self._get_wrapped_function(mod, routine.name)"
        }
      ]
    }
  ]
}