{
  "Selected_candidate": {
    "pr_number": 11149,
    "pr_title": "Intersection of null Range and an Interval returns EmptySet",
    "pr_body": "A null `Range` is a set with no elements. It is an empty `Range` object.\nHowever, the current implementation doesn't demonstrate this fact in the `intersection` operation.\n\nThis PR is an attempt to reflect this behavior of a null `Range` object. \nCloses #11147 \n\n**Current Implementation**\n\n``` python\nIn []: Intersection(Range(0), Interval(0, 10))\n# results in a NotImplementedError\nIn []: Intersection(S.Integers, Interval(0.2, 0.8))\n# results in a NotImplementedError\n```\n\n **New Implementation**\n\n``` python\nIn []: Intersection(Range(0), FiniteSet(0, 10))\nOut[]: EmptySet()\n\nIn []: Intersection(S.Integers, Interval(0.2, 0.8))\nOut[]: EmptySet()\n```\n\nPing @asmeurer @smichr @hargup @aktech \n",
    "issue_id": 11147,
    "issue_title": "Incorrect result for Intersection of S.Integers( and S.Naturals) with Interval",
    "issue_body": "``` python\nIn []: Intersection(S.Integers, Interval(0.2, 0.8)) # results in a NotImplementedError\n\nIn []: Intersection(S.Naturals, Interval(0.2, 0.8)) # results in a NotImplementedError\n```\n\nThe correct intersection should be an `EmptySet`.\n",
    "issue_closed_at": "2016-05-23T23:43:17Z",
    "base_commit": "db73ed37b955474ad9f1b3d2c5c762e32ce2cbfe",
    "changes": [
      {
        "file": "sympy/sets/fancysets.py",
        "type": "function",
        "name": "_intersect",
        "class_name": "ComplexRegion",
        "code": "def _intersect(self, other):\n\n        if other.is_ComplexRegion:\n            # self in rectangular form\n            if (not self.polar) and (not other.polar):\n                return ComplexRegion(Intersection(self.sets, other.sets))\n\n            # self in polar form\n            elif self.polar and other.polar:\n                r1, theta1 = self.a_interval, self.b_interval\n                r2, theta2 = other.a_interval, other.b_interval\n                new_r_interval = Intersection(r1, r2)\n                new_theta_interval = Intersection(theta1, theta2)\n\n                # 0 and 2*Pi means the same\n                if ((2*S.Pi in theta1 and S.Zero in theta2) or\n                   (2*S.Pi in theta2 and S.Zero in theta1)):\n                    new_theta_interval = Union(new_theta_interval,\n                                               FiniteSet(0))\n                return ComplexRegion(new_r_interval*new_theta_interval,\n                                    polar=True)\n\n        if other is S.Reals:\n            return other\n\n        if other.is_subset(S.Reals):\n            new_interval = []\n\n            # self in rectangular form\n            if not self.polar:\n                for element in self.psets:\n                    if S.Zero in element.args[0]:\n                        new_interval.append(element.args[0])\n                new_interval = Union(*new_interval)\n                return Intersection(new_interval, other)\n\n            # self in polar form\n            elif self.polar:\n                for element in self.psets:\n                    if (0 in element.args[1]) or (S.Pi in element.args[1]):\n                        new_interval.append(element.args[0])\n                new_interval = Union(*new_interval)\n                return Intersection(new_interval, other)"
      }
    ]
  },
  "Justification": "Candidate C directly addresses the Intersection functionality, which is pertinent to the current bug involving duplicate handling. The candidate reflects changes made to how intersections are computed and what results are returned, guiding the developer in understanding correct implementation expectations for handling duplicates within intersections. This parallel to the CURRENT bug about maintaining consistency regardless of duplicates makes it the most useful report for debugging.",
  "instance_id": "sympy__sympy-16988",
  "repo": "sympy/sympy",
  "created_at": "2019-06-07T12:00:00Z",
  "problem_statement": "Intersection should remove duplicates\n```python\r\n>>> Intersection({1},{1},{x})\r\nEmptySet()\r\n>>> Intersection({1},{x})\r\n{1}\r\n```\r\nThe answer should be `Piecewise(({1}, Eq(x, 1)), (S.EmptySet, True))` or remain unevaluated.\r\n\r\nThe routine should give the same answer if duplicates are present; my initial guess is that duplicates should just be removed at the outset of instantiation. Ordering them will produce canonical processing.\n",
  "patch": "diff --git a/sympy/sets/sets.py b/sympy/sets/sets.py\n--- a/sympy/sets/sets.py\n+++ b/sympy/sets/sets.py\n@@ -1260,7 +1260,7 @@ def __new__(cls, *args, **kwargs):\n         evaluate = kwargs.get('evaluate', global_evaluate[0])\n \n         # flatten inputs to merge intersections and iterables\n-        args = _sympify(args)\n+        args = list(ordered(set(_sympify(args))))\n \n         # Reduce sets using known rules\n         if evaluate:\n"
}