{
  "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 A is the most helpful due to its exploration of operations involving symbolic quantities and addition, which overlaps with the CURRENT bug’s context of simplifying trigonometric expressions. The issue with inconsistent behavior, particularly when given certain inputs, may provide insights into similar handling of mathematical expressions in the CURRENT bug. Furthermore, both bugs involve failure scenarios related to symbolic manipulation, making Candidate A's solutions relevant for debugging the CURRENT simplify failure.",
  "instance_id": "sympy__sympy-18087",
  "repo": "sympy/sympy",
  "created_at": "2019-12-20T12:38:00Z",
  "problem_statement": "Simplify of simple trig expression fails\ntrigsimp in various versions, including 1.5, incorrectly simplifies cos(x)+sqrt(sin(x)**2) as though it were cos(x)+sin(x) for general complex x. (Oddly it gets this right if x is real.)\r\n\r\nEmbarrassingly I found this by accident while writing sympy-based teaching material...\r\n\n",
  "patch": "diff --git a/sympy/core/exprtools.py b/sympy/core/exprtools.py\n--- a/sympy/core/exprtools.py\n+++ b/sympy/core/exprtools.py\n@@ -358,8 +358,8 @@ def __init__(self, factors=None):  # Factors\n             for f in list(factors.keys()):\n                 if isinstance(f, Rational) and not isinstance(f, Integer):\n                     p, q = Integer(f.p), Integer(f.q)\n-                    factors[p] = (factors[p] if p in factors else 0) + factors[f]\n-                    factors[q] = (factors[q] if q in factors else 0) - factors[f]\n+                    factors[p] = (factors[p] if p in factors else S.Zero) + factors[f]\n+                    factors[q] = (factors[q] if q in factors else S.Zero) - factors[f]\n                     factors.pop(f)\n             if i:\n                 factors[I] = S.One*i\n@@ -448,14 +448,12 @@ def as_expr(self):  # Factors\n         args = []\n         for factor, exp in self.factors.items():\n             if exp != 1:\n-                b, e = factor.as_base_exp()\n-                if isinstance(exp, int):\n-                    e = _keep_coeff(Integer(exp), e)\n-                elif isinstance(exp, Rational):\n+                if isinstance(exp, Integer):\n+                    b, e = factor.as_base_exp()\n                     e = _keep_coeff(exp, e)\n+                    args.append(b**e)\n                 else:\n-                    e *= exp\n-                args.append(b**e)\n+                    args.append(factor**exp)\n             else:\n                 args.append(factor)\n         return Mul(*args)\n"
}