{
  "Selected_candidate": {
    "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⋅n           n\n⎡1  2⎤⋅⎛⎡2  3⎤⎞    + ⎛⎡1  2⎤⎞ \n⎢    ⎥ ⎜⎢    ⎥⎟      ⎜⎢    ⎥⎟ \n⎣3  4⎦ ⎝⎣4  5⎦⎠      ⎝⎣3  4⎦⎠ \n\nIn [21]: pprint(w.subs(n, 1))\n               2           1\n⎡1  2⎤⋅⎛⎡2  3⎤⎞  + ⎛⎡1  2⎤⎞ \n⎢    ⎥ ⎜⎢    ⎥⎟    ⎜⎢    ⎥⎟ \n⎣3  4⎦ ⎝⎣4  5⎦⎠    ⎝⎣3  4⎦⎠ \n\nIn [22]: pprint(w.subs(n, 1).doit())    % these fixes make this work\n⎡73   97 ⎤\n⎢        ⎥\n⎣163  215⎦\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]"
      }
    ]
  },
  "Justification": "Candidate C is the most relevant because it directly deals with the evaluation of expressions and the behavior of symbolic functions, which aligns with the current bug related to the output of `mathematica_code(Max(x,2))`. The current bug indicates an issue with output formatting, which this candidate addresses through its discussion on the evaluation of expressions in the Matrix context, particularly focusing on the `doit()` method. The fixes made in Candidate C involve refining expression handling, which could provide insights into how `Max` should be outputted correctly as valid Mathematica code. This candidate thus emphasizes similar underlying mechanisms of expression evaluation that may assist in rectifying the present issue.",
  "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"
}