{
  "Selected_candidate": {
    "pr_number": 7525,
    "pr_title": "fix indeterminacy in FiniteSet",
    "pr_body": "This fixes #7456. I downloaded 3.4 and found a failing pythonhashseed for test_rv. After applying these mods the test no longer occurs so I think it's taken care of now. I reverted the sorting of random_symbols as it was not needed to fix this issue.\n\nIn addition, I noticed that a deprecation warning from numpy is emitted during testing because non-integer dimensions were being used to create a matrix, so I used randint instead.\n",
    "issue_id": 7456,
    "issue_title": "test_rv fails sometimes on Python 3.4",
    "issue_body": "https://travis-ci.org/debugger22/sympy/jobs/24221323\nhttps://travis-ci.org/sympy/sympy/jobs/24353106\n\n```\nFile \"/home/travis/virtualenv/python3.4.0/lib/python3.4/site-packages/sympy/stats/tests/test_rv.py\", line 50, in test_pspace\n    assert pspace(2*X + Y) == ProductPSpace(Y.pspace, X.pspace)\nAssertionError\n________________________________________________________________________________\n_______________ sympy/stats/tests/test_rv.py:test_ProductPSpace ________________\n  File \"/home/travis/virtualenv/python3.4.0/lib/python3.4/site-packages/sympy/stats/tests/test_rv.py\", line 95, in test_ProductPSpace\n    assert pspace(X + Y) == ProductPSpace(py, px)\nAssertionError\n tests finished: 2608 passed, 2 failed, 43 skipped, 62 expected to fail, \n1 expected to fail but passed, in 2921.03 seconds \nDO *NOT* COMMIT!\nTraceback (most recent call last):\n  File \"<stdin>\", line 3, in <module>\nException: Tests failed\n```\n\n@asmeurer This is what I was talking about.\n",
    "issue_closed_at": "2014-05-26T12:55:04Z",
    "base_commit": "f945422d57a8f6419005d96192eae48d8dd53ce5",
    "changes": [
      {
        "file": "sympy/sets/sets.py",
        "type": "line",
        "name": "line 7",
        "code": "from sympy.core.singleton import Singleton, S\nfrom sympy.core.evalf import EvalfMixin\nfrom sympy.core.numbers import Float\nfrom sympy.core.compatibility import iterable, with_metaclass\nfrom sympy.core.evaluate import global_evaluate\nfrom sympy.core.decorators import deprecated\n"
      },
      {
        "file": "sympy/sets/sets.py",
        "type": "class",
        "name": "FiniteSet",
        "code": "class FiniteSet(Set, EvalfMixin):\n    \"\"\"\n    Represents a finite set of discrete numbers\n\n    Examples\n    ========\n\n        >>> from sympy import FiniteSet\n\n        >>> FiniteSet(1, 2, 3, 4)\n        {1, 2, 3, 4}\n        >>> 3 in FiniteSet(1, 2, 3, 4)\n        True\n\n    References\n    ==========\n    http://en.wikipedia.org/wiki/Finite_set\n    \"\"\"\n    is_FiniteSet = True\n    is_iterable = True\n\n    def __new__(cls, *args, **kwargs):\n        evaluate = kwargs.get('evaluate', global_evaluate[0])\n        if evaluate:\n            if len(args) == 1 and iterable(args[0]):\n                args = args[0]\n\n            args = list(map(sympify, args))\n\n            if len(args) == 0:\n                return EmptySet()\n\n\n        args = frozenset(args)  # remove duplicates\n        args = map(sympify, args)\n        args = frozenset(args)\n        obj = Basic.__new__(cls, *args)\n        obj._elements = args\n        return obj\n\n    def __iter__(self):\n        return iter(self.args)\n\n    def _intersect(self, other):\n        \"\"\"\n        This function should only be used internally\n\n        See Set._intersect for docstring\n        \"\"\"\n        if isinstance(other, self.__class__):\n            return self.__class__(*(self._elements & other._elements))\n        return self.__class__(el for el in self if el in other)\n\n    def _union(self, other):\n        \"\"\"\n        This function should only be used internally\n\n        See Set._union for docstring\n        \"\"\"\n        if other.is_FiniteSet:\n            return FiniteSet(*(self._elements | other._elements))\n\n        # If other set contains one of my elements, remove it from myself\n        if any(other.contains(x) is True for x in self):\n            return set((\n                FiniteSet(x for x in self if other.contains(x) is not True),\n                other))\n\n        return None\n\n    def _contains(self, other):\n        \"\"\"\n        Tests whether an element, other, is in the set.\n\n        Relies on Python's set class. This tests for object equality\n        All inputs are sympified\n\n        >>> from sympy import FiniteSet\n\n        >>> 1 in FiniteSet(1, 2)\n        True\n        >>> 5 in FiniteSet(1, 2)\n        False\n\n        \"\"\"\n        return other in self._elements\n\n    def _eval_imageset(self, f):\n        return FiniteSet(*map(f, self))\n\n    @property\n    def _complement(self):\n        \"\"\"\n        The complement of a real finite set is the Union of open Intervals\n        between the elements of the set.\n\n        >>> from sympy import FiniteSet\n        >>> FiniteSet(1, 2, 3).complement\n        (-oo, 1) U (1, 2) U (2, 3) U (3, oo)\n\n\n        \"\"\"\n        if not all(elem.is_number for elem in self):\n            raise ValueError(\"%s: Complement not defined for symbolic inputs\"\n                    % self)\n\n        # as there are only numbers involved, a straight sort is sufficient;\n        # default_sort_key is not needed\n        args = sorted(self.args)\n\n        intervals = []  # Build up a list of intervals between the elements\n        intervals += [Interval(S.NegativeInfinity, args[0], True, True)]\n        for a, b in zip(args[:-1], args[1:]):\n            intervals.append(Interval(a, b, True, True))  # open intervals\n        intervals.append(Interval(args[-1], S.Infinity, True, True))\n        return Union(intervals, evaluate=False)\n\n    @property\n    def _boundary(self):\n        return self\n\n    @property\n    def _inf(self):\n        from sympy.functions.elementary.miscellaneous import Min\n        return Min(*self)\n\n    @property\n    def _sup(self):\n        from sympy.functions.elementary.miscellaneous import Max\n        return Max(*self)\n\n    @property\n    def measure(self):\n        return 0\n\n    def __len__(self):\n        return len(self.args)\n\n    def __sub__(self, other):\n        return FiniteSet(el for el in self if el not in other)\n\n    def as_relational(self, symbol):\n        \"\"\"Rewrite a FiniteSet in terms of equalities and logic operators. \"\"\"\n        from sympy.core.relational import Eq\n        return Or(*[Eq(symbol, elem) for elem in self])\n\n    @property\n    def is_real(self):\n        return all(el.is_real for el in self)\n\n    def compare(self, other):\n        return (hash(self) - hash(other))\n\n    def _eval_evalf(self, prec):\n        return FiniteSet(elem.evalf(prec) for elem in self)\n\n    def _hashable_content(self):\n        return (self._elements,)\n\n    @property\n    def _sorted_args(self):\n        from sympy.utilities import default_sort_key\n        return sorted(self.args, key=default_sort_key)\n\n    def _eval_powerset(self):\n        return self.func(self.func(s) for s in subsets(self.args))\n\n    def __ge__(self, other):\n        return other.is_subset(self)\n\n    def __gt__(self, other):\n        return self != other and self >= other\n\n    def __le__(self, other):\n        return self.is_subset(other)\n\n    def __lt__(self, other):\n        return self != other and other >= self"
      },
      {
        "file": "sympy/sets/sets.py",
        "type": "function",
        "name": "__new__",
        "class_name": "FiniteSet",
        "code": "def __new__(cls, *args, **kwargs):\n        evaluate = kwargs.get('evaluate', global_evaluate[0])\n        if evaluate:\n            if len(args) == 1 and iterable(args[0]):\n                args = args[0]\n\n            args = list(map(sympify, args))\n\n            if len(args) == 0:\n                return EmptySet()\n\n\n        args = frozenset(args)  # remove duplicates\n        args = map(sympify, args)\n        args = frozenset(args)\n        obj = Basic.__new__(cls, *args)\n        obj._elements = args\n        return obj"
      },
      {
        "file": "sympy/stats/rv.py",
        "type": "line",
        "name": "line 16",
        "code": "\nfrom sympy import (Basic, S, Expr, Symbol, Tuple, And, Add, Eq, lambdify,\n        sympify, Equality, solve, Lambda, DiracDelta)\nfrom sympy.core.compatibility import reduce, ordered\nfrom sympy.sets.sets import FiniteSet, ProductSet\nfrom sympy.abc import x\n"
      },
      {
        "file": "sympy/stats/rv.py",
        "type": "function",
        "name": "as_boolean",
        "class_name": "ProductDomain",
        "code": "def as_boolean(self):\n        return And(*[domain.as_boolean() for domain in self.domains])"
      }
    ]
  },
  "Justification": "Candidate D is the most helpful because it addresses a bug related to inconsistencies in testing and results stemming from sorting and randomness in the `pspace` function. The CURRENT bug report mentions arbitrary order in the `decompose` function, which indicates a sorting issue could be relevant. Additionally, Candidate D highlights how sorting was reverted to fix indeterminacy, which could guide the resolution of the arbitrary order in the list returned by `decompose`. This connection to sorting and testing failures makes it particularly pertinent for debugging the CURRENT bug.",
  "instance_id": "sympy__sympy-13043",
  "repo": "sympy/sympy",
  "created_at": "2017-07-26T00:29:45Z",
  "problem_statement": "decompose() function in intpoly returns a list of arbitrary order\nThe decompose() function, with separate=True, returns `list(poly_dict.values())`, which is ordered arbitrarily.  \r\n\r\nWhat is this used for? It should be sorted somehow, or returning a set (in which case, why not just use the returned dictionary and have the caller take the values). This is causing test failures for me after some changes to the core. \r\n\r\nCC @ArifAhmed1995 @certik \n",
  "patch": "diff --git a/sympy/integrals/intpoly.py b/sympy/integrals/intpoly.py\n--- a/sympy/integrals/intpoly.py\n+++ b/sympy/integrals/intpoly.py\n@@ -556,7 +556,7 @@ def decompose(expr, separate=False):\n     >>> decompose(x**2 + x*y + x + y + x**3*y**2 + y**5)\n     {1: x + y, 2: x**2 + x*y, 5: x**3*y**2 + y**5}\n     >>> decompose(x**2 + x*y + x + y + x**3*y**2 + y**5, True)\n-    [x, y, x**2, y**5, x*y, x**3*y**2]\n+    {x, x**2, y, y**5, x*y, x**3*y**2}\n     \"\"\"\n     expr = S(expr)\n     poly_dict = {}\n@@ -569,7 +569,7 @@ def decompose(expr, separate=False):\n             degrees = [(sum(degree_list(monom, *symbols)), monom)\n                        for monom in expr.args]\n             if separate:\n-                return [monom[1] for monom in degrees]\n+                return {monom[1] for monom in degrees}\n             else:\n                 for monom in degrees:\n                     degree, term = monom\n@@ -593,7 +593,7 @@ def decompose(expr, separate=False):\n         poly_dict[0] = expr\n \n     if separate:\n-        return list(poly_dict.values())\n+        return set(poly_dict.values())\n     return poly_dict\n \n \n"
}