{
    "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 is the most relevant because it deals with the summation of quantities and numbers, pointing out a scenario where an operation unexpectedly does not raise an error, which can be equated to the silent modification issue described in the CURRENT bug report. Both deal with unexpected behavior when manipulating lists or quantities, and the need to handle special cases properly. Identifying such issues in handling arithmetic could provide guidance on managing list operations in the `uniq` function, particularly in ensuring consistent error management when modifications occur during iteration."
}