{
  "Selected_candidate": {
    "pr_number": 12952,
    "pr_title": "Fix addition of a quantity and a number",
    "pr_body": "closes #12918\r\n\r\ncc @schymans ",
    "issue_id": 12918,
    "issue_title": "Addition of a quantity and a number does not raise an error",
    "issue_body": "If I add two quantities with inconsistent units, sympy rightly returns an error:\r\n```\r\n>>> from sympy.physics.units import kilogram, kelvin\r\n>>> try: print kilogram + kelvin\r\n>>> except Exception, error: print error\r\nsummation of quantities of incompatible dimensions\r\n```\r\nHowever, if one of the terms is a number, no error is raised:\r\n```\r\n>>> try: print kilogram + 1.1\r\n>>> except Exception, error: print error\r\nkilogram + 1.1\r\n```\r\n\r\nIf I add two quantities, one of which does not have a dimension, an error is raised:\r\n```\r\n>>> from sympy.physics.units import Quantity, mass\r\n>>> try: print Quantity('x', mass, kilogram) + Quantity('y', S.One, 1.1)\r\n>>> except Exception, error: print error\r\nsummation of quantities of incompatible dimensions\r\n```\r\n\r\nIf I add a quantity and a number, no error is raised:\r\n```\r\n>>> try: print Quantity('x', mass, kilogram) + Number(1.1)\r\n>>> except Exception, error: print error\r\nx + 1.1\r\n```\r\nI believe that this is a bug, as numbers should be treated like dimensionless quantities whenever they are used alongside with quantities.\r\n",
    "issue_closed_at": "2017-07-12T20:13:26Z",
    "base_commit": "195061bd91f2e888e6449ec05f2caca140067fb2",
    "changes": [
      {
        "file": "sympy/core/power.py",
        "type": "function",
        "name": "_eval_is_rational",
        "class_name": "Pow",
        "code": "def _eval_is_rational(self):\n        p = self.func(*self.as_base_exp())  # in case it's unevaluated\n        if not p.is_Pow:\n            return p.is_rational\n        b, e = p.as_base_exp()\n        if e.is_Rational and b.is_Rational:\n            # we didn't check that e is not an Integer\n            # because Rational**Integer autosimplifies\n            return False\n        if e.is_integer:\n            if b.is_rational:\n                if fuzzy_not(b.is_zero) or e.is_nonnegative:\n                    return True\n                if b == e:  # always rational, even for 0**0\n                    return True\n            elif b.is_irrational:\n                return e.is_zero"
      },
      {
        "file": "sympy/core/power.py",
        "type": "function",
        "name": "_eval_is_algebraic",
        "class_name": "Pow",
        "code": "def _eval_is_algebraic(self):\n        if self.base.is_zero or (self.base - 1).is_zero:\n            return True\n        elif self.exp.is_rational:\n            if self.base.is_algebraic is False:\n                return self.exp.is_nonzero\n            return self.base.is_algebraic\n        elif self.base.is_algebraic and self.exp.is_algebraic:\n            if ((fuzzy_not(self.base.is_zero)\n                and fuzzy_not((self.base - 1).is_zero))\n                or self.base.is_integer is False\n                or self.base.is_irrational):\n                return self.exp.is_rational"
      },
      {
        "file": "sympy/physics/units/quantities.py",
        "type": "function",
        "name": "_Quantity_constructor_postprocessor_Add",
        "class_name": null,
        "code": "def _Quantity_constructor_postprocessor_Add(expr):\n    # Construction postprocessor for the addition,\n    # checks for dimension mismatches of the addends, thus preventing\n    # expressions like `meter + second` to be created.\n\n    deset = {\n        tuple(sorted(Dimension(\n            Quantity.get_dimensional_expr(i)\n        ).get_dimensional_dependencies().items()))\n        for i in expr.args\n        if i.free_symbols == set()  # do not raise if there are symbols\n                    # (free symbols could contain the units corrections)\n        and not i.is_number\n    }\n    # If `deset` has more than one element, then some dimensions do not\n    # match in the sum:\n    if len(deset) > 1:\n        raise ValueError(\"summation of quantities of incompatible dimensions\")\n    return expr"
      }
    ]
  },
  "Justification": "Candidate E directly addresses an issue within the same framework of symmetry and mathematical operations, particularly involving quantities and their behavior in arithmetic operations. The CURRENT bug focuses on the rendering and output related to mathematical expressions. The fact that both bugs deal with non-standard behaviors in the sympy library—whether it's in arithmetic correctness (Candidate E) or in the rendering capabilities (CURRENT bug)—makes bug report E particularly advantageous. It discusses implicit behaviors that affect output, resulting in potentially erroneous results, similar to how the CURRENT bug produces inaccurate rendering based on specific operations. Both reports highlight the need for better handling of mathematical expressions within the library, tying them together through the commonality of operations leading to unexpected outputs.",
  "instance_id": "sympy__sympy-20639",
  "repo": "sympy/sympy",
  "created_at": "2020-12-21T07:42:53Z",
  "problem_statement": "inaccurate rendering of pi**(1/E)\nThis claims to be version 1.5.dev; I just merged from the project master, so I hope this is current.  I didn't notice this bug among others in printing.pretty.\r\n\r\n```\r\nIn [52]: pi**(1/E)                                                               \r\nOut[52]: \r\n-1___\r\n╲╱ π \r\n\r\n```\r\nLaTeX and str not fooled:\r\n```\r\nIn [53]: print(latex(pi**(1/E)))                                                 \r\n\\pi^{e^{-1}}\r\n\r\nIn [54]: str(pi**(1/E))                                                          \r\nOut[54]: 'pi**exp(-1)'\r\n```\r\n\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@@ -1902,12 +1902,12 @@ def _print_Mul(self, product):\n             return prettyForm.__mul__(*a)/prettyForm.__mul__(*b)\n \n     # A helper function for _print_Pow to print x**(1/n)\n-    def _print_nth_root(self, base, expt):\n+    def _print_nth_root(self, base, root):\n         bpretty = self._print(base)\n \n         # In very simple cases, use a single-char root sign\n         if (self._settings['use_unicode_sqrt_char'] and self._use_unicode\n-            and expt is S.Half and bpretty.height() == 1\n+            and root == 2 and bpretty.height() == 1\n             and (bpretty.width() == 1\n                  or (base.is_Integer and base.is_nonnegative))):\n             return prettyForm(*bpretty.left('\\N{SQUARE ROOT}'))\n@@ -1915,14 +1915,13 @@ def _print_nth_root(self, base, expt):\n         # Construct root sign, start with the \\/ shape\n         _zZ = xobj('/', 1)\n         rootsign = xobj('\\\\', 1) + _zZ\n-        # Make exponent number to put above it\n-        if isinstance(expt, Rational):\n-            exp = str(expt.q)\n-            if exp == '2':\n-                exp = ''\n-        else:\n-            exp = str(expt.args[0])\n-        exp = exp.ljust(2)\n+        # Constructing the number to put on root\n+        rpretty = self._print(root)\n+        # roots look bad if they are not a single line\n+        if rpretty.height() != 1:\n+            return self._print(base)**self._print(1/root)\n+        # If power is half, no number should appear on top of root sign\n+        exp = '' if root == 2 else str(rpretty).ljust(2)\n         if len(exp) > 2:\n             rootsign = ' '*(len(exp) - 2) + rootsign\n         # Stack the exponent\n@@ -1954,8 +1953,9 @@ def _print_Pow(self, power):\n             if e is S.NegativeOne:\n                 return prettyForm(\"1\")/self._print(b)\n             n, d = fraction(e)\n-            if n is S.One and d.is_Atom and not e.is_Integer and self._settings['root_notation']:\n-                return self._print_nth_root(b, e)\n+            if n is S.One and d.is_Atom and not e.is_Integer and (e.is_Rational or d.is_Symbol) \\\n+                    and self._settings['root_notation']:\n+                return self._print_nth_root(b, d)\n             if e.is_Rational and e < 0:\n                 return prettyForm(\"1\")/self._print(Pow(b, -e, evaluate=False))\n \n"
}