{
  "Selected_candidate": {
    "pr_number": 15851,
    "pr_title": "corrected truth value of Unequality(Ne) for simplify",
    "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 . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #15847 \r\n\r\n#### Brief description of what is fixed or changed\r\nsimplify of Ne is giving True after simplification of a = Ne(x*(x+y), x**2 + x*y)(look above issue)\r\nso I just change change little bit simplify function in relation so that it should give False.\r\n\r\n#### Other comment\r\nI have done edits based on above issue .\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n- simplify\r\n   - change simplify function for Ne.\r\n<!-- END RELEASE NOTES -->\r\n",
    "issue_id": 15847,
    "issue_title": "regression: `Ne` simplifies incorrectly",
    "issue_body": "Consider\r\n```\r\na = Ne(x*(x+y), x**2 + x*y)\r\n```\r\nBefore fd63f10ec66c437513bdfd983ce4d62ae7747373, `simplify(a)` gave False.  Now it gives True\r\n\r\nI think it should be False because `Eq(a.lhs, a.rhs)` should (and does) simplify to True.  `Ne` is mathematical inequality, not structural inequality.\r\n\r\nCC @smichr",
    "issue_closed_at": "2019-01-28T14:10:00Z",
    "base_commit": "1e999fc5159b830a9872b86675bc5f3692a9c1be",
    "changes": [
      {
        "file": "sympy/core/relational.py",
        "type": "function",
        "name": "binary_symbols",
        "class_name": "Unequality",
        "code": "def binary_symbols(self):\n        if S.true in self.args or S.false in self.args:\n            if self.lhs.is_Symbol:\n                return set([self.lhs])\n            elif self.rhs.is_Symbol:\n                return set([self.rhs])\n        return set()"
      }
    ]
  },
  "Justification": "Candidate A is the most relevant as it involves a regression related to the behavior of equality checks (similar to how `Symbol` instances behave). While it doesn't directly relate to the `__dict__` issue, the underlying problem involves symbolic representations which can have implications in how attributes are accessed and modified. The similarities in outcomes, especially regarding truth values and simplification, can provide insights into resolving the current bug effectively. Additionally, it impacts the `sympy/core/relational.py`, indirectly indicating a risk of similar bugs in how instances are handled and modified, which aligns well with the current bug involving `Symbol` attributes.",
  "instance_id": "sympy__sympy-20590",
  "repo": "sympy/sympy",
  "created_at": "2020-12-12T18:18:38Z",
  "problem_statement": "Symbol instances have __dict__ since 1.7?\nIn version 1.6.2 Symbol instances had no `__dict__` attribute\r\n```python\r\n>>> sympy.Symbol('s').__dict__\r\n---------------------------------------------------------------------------\r\nAttributeError                            Traceback (most recent call last)\r\n<ipython-input-3-e2060d5eec73> in <module>\r\n----> 1 sympy.Symbol('s').__dict__\r\n\r\nAttributeError: 'Symbol' object has no attribute '__dict__'\r\n>>> sympy.Symbol('s').__slots__\r\n('name',)\r\n```\r\n\r\nThis changes in 1.7 where `sympy.Symbol('s').__dict__` now exists (and returns an empty dict)\r\nI may misinterpret this, but given the purpose of `__slots__`, I assume this is a bug, introduced because some parent class accidentally stopped defining `__slots__`.\n",
  "patch": "diff --git a/sympy/core/_print_helpers.py b/sympy/core/_print_helpers.py\n--- a/sympy/core/_print_helpers.py\n+++ b/sympy/core/_print_helpers.py\n@@ -17,6 +17,11 @@ class Printable:\n     This also adds support for LaTeX printing in jupyter notebooks.\n     \"\"\"\n \n+    # Since this class is used as a mixin we set empty slots. That means that\n+    # instances of any subclasses that use slots will not need to have a\n+    # __dict__.\n+    __slots__ = ()\n+\n     # Note, we always use the default ordering (lex) in __str__ and __repr__,\n     # regardless of the global setting. See issue 5487.\n     def __str__(self):\n"
}