{
  "instance_id": "sympy__sympy-17655",
  "repo": "sympy/sympy",
  "created_at": "2019-09-25T17:04:26Z",
  "problem_statement": "Unexpected exception when multiplying geometry.Point and number\n```python\r\nfrom sympy import geometry as ge\r\nimport sympy\r\n\r\npoint1 = ge.Point(0,0)\r\npoint2 = ge.Point(1,1)\r\n```\r\n\r\nThis line works fine\r\n```python\r\npoint1 + point2 * sympy.sympify(2.0)\r\n```\r\n\r\nBut when I write the same this way it raises an exception\r\n```python\r\npoint1 + sympy.sympify(2.0) * point2\r\n```\r\n\r\n```\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n~/.virtualenvs/test/lib/python3.6/site-packages/sympy/geometry/point.py in __add__(self, other)\r\n    219         try:\r\n--> 220             s, o = Point._normalize_dimension(self, Point(other, evaluate=False))\r\n    221         except TypeError:\r\n\r\n~/.virtualenvs/test/lib/python3.6/site-packages/sympy/geometry/point.py in __new__(cls, *args, **kwargs)\r\n    128                 Expecting sequence of coordinates, not `{}`'''\r\n--> 129                                        .format(func_name(coords))))\r\n    130         # A point where only `dim` is specified is initialized\r\n\r\nTypeError: \r\nExpecting sequence of coordinates, not `Mul`\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nGeometryError                             Traceback (most recent call last)\r\n<ipython-input-20-6dcbddac1ee2> in <module>\r\n----> 1 point1 + sympy.sympify(2.0)* point2\r\n\r\n~/.virtualenvs/test/lib/python3.6/site-packages/sympy/geometry/point.py in __add__(self, other)\r\n    220             s, o = Point._normalize_dimension(self, Point(other, evaluate=False))\r\n    221         except TypeError:\r\n--> 222             raise GeometryError(\"Don't know how to add {} and a Point object\".format(other))\r\n    223 \r\n    224         coords = [simplify(a + b) for a, b in zip(s, o)]\r\n\r\nGeometryError: Don't know how to add 2.0*Point2D(1, 1) and a Point object\r\n```\r\n\r\nThe expected behaviour is, that both lines give the same result\n",
  "patch": "diff --git a/sympy/geometry/point.py b/sympy/geometry/point.py\n--- a/sympy/geometry/point.py\n+++ b/sympy/geometry/point.py\n@@ -278,6 +278,10 @@ def __mul__(self, factor):\n         coords = [simplify(x*factor) for x in self.args]\n         return Point(coords, evaluate=False)\n \n+    def __rmul__(self, factor):\n+        \"\"\"Multiply a factor by point's coordinates.\"\"\"\n+        return self.__mul__(factor)\n+\n     def __neg__(self):\n         \"\"\"Negate the point.\"\"\"\n         coords = [-x for x in self.args]\n",
  "similar_bug_items": [
    {
      "pr_number": 13437,
      "pr_title": "Fix bell(n) for n=oo, and negative/non-integer 'n'",
      "pr_body": "This PR uses commits of #9198 (maintaining ownership to original author). And tries to address the requested changes on PR #9198 .\r\nFixes #9184",
      "issue_id": 9184,
      "issue_title": "bell(n).limit(n, oo) should be oo rather than bell(oo)",
      "issue_body": "`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n",
      "issue_closed_at": "2017-10-13T04:35:13Z",
      "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "_bell_incomplete_poly",
          "class_name": "bell",
          "code": "def _bell_incomplete_poly(n, k, symbols):\n        r\"\"\"\n        The second kind of Bell polynomials (incomplete Bell polynomials).\n\n        Calculated by recurrence formula:\n\n        .. math:: B_{n,k}(x_1, x_2, \\dotsc, x_{n-k+1}) =\n                \\sum_{m=1}^{n-k+1}\n                \\x_m \\binom{n-1}{m-1} B_{n-m,k-1}(x_1, x_2, \\dotsc, x_{n-m-k})\n\n        where\n            B_{0,0} = 1;\n            B_{n,0} = 0; for n>=1\n            B_{0,k} = 0; for k>=1\n\n        \"\"\"\n        if (n == 0) and (k == 0):\n            return S.One\n        elif (n == 0) or (k == 0):\n            return S.Zero\n        s = S.Zero\n        a = S.One\n        for m in range(1, n - k + 2):\n            s += a * bell._bell_incomplete_poly(\n                n - m, k - 1, symbols) * symbols[m - 1]\n            a = a * (n - m) / m\n        return expand_mul(s)"
        }
      ]
    },
    {
      "pr_number": 13744,
      "pr_title": "group theory: correct FreeGroupElement multiplication",
      "pr_body": "At the moment, multiplication of `FreeGroupElement`s treats two elements as non-equal unless the symbols representing them are the same object. But it is sufficient for the symbols to be equal via `==`, and the current behaviour causes problems. For example, the added test fails in master.\r\n\r\nFixes #13737.",
      "issue_id": 13737,
      "issue_title": "coset_table doctest failure (Fatal Python error: Cannot recover from stack overflow.)",
      "issue_body": "See https://travis-ci.org/sympy/sympy/jobs/315588322\r\n\r\n```\r\nsympy/combinatorics/coset_table.py[3] \r\n.\r\nFatal Python error: Cannot recover from stack overflow.\r\nCurrent thread 0x00007f7fef7dd740 (most recent call first):\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/core/symbol.py\", line 257 in assumptions0\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/core/symbol.py\", line 252 in _hashable_content\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/core/basic.py\", line 331 in __eq__\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/core/cache.py\", line 93 in wrapper\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/core/expr.py\", line 111 in __neg__\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 435 in <listcomp>\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 435 in letter_form\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 927 in subword_index\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 964 in is_dependent\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 976 in is_independent\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 663 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 684 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  File \"/home/travis/virtualenv/python3.5.4/lib/python3.5/site-packages/sympy/combinatorics/free_groups.py\", line 687 in eliminate_word\r\n  ...\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 4, in <module>\r\nException: Tests failed\r\n```\r\n\r\nHere is the test header\r\n\r\n```\r\n============================= test process starts ==============================\r\nexecutable:         /home/travis/virtualenv/python3.5.4/bin/python  (3.5.4-final-0) [CPython]\r\narchitecture:       64-bit\r\ncache:              yes\r\nground types:       python \r\nnumpy:              None\r\nhash randomization: on (PYTHONHASHSEED=935966445)\r\n```",
      "issue_closed_at": "2017-12-15T08:43:52Z",
      "base_commit": "ae3d6f647f080240318d114f2c397b99be5cef5f",
      "changes": [
        {
          "file": "sympy/combinatorics/free_groups.py",
          "type": "function",
          "name": "letter_form_to_array_form",
          "class_name": null,
          "code": "def letter_form_to_array_form(array_form, group):\n    \"\"\"\n    This method converts a list given with possible repetitions of elements in\n    it. It returns a new list such that repetitions of consecutive elements is\n    removed and replace with a tuple element of size two such that the first\n    index contains `value` and the second index contains the number of\n    consecutive repetitions of `value`.\n\n    \"\"\"\n    a = list(array_form[:])\n    new_array = []\n    n = 1\n    symbols = group.symbols\n    for i in range(len(a)):\n        if i == len(a) - 1:\n            if a[i] == a[i - 1]:\n                if (-a[i]) in symbols:\n                    new_array.append((-a[i], -n))\n                else:\n                    new_array.append((a[i], n))\n            else:\n                if (-a[i]) in symbols:\n                    new_array.append((-a[i], -1))\n                else:\n                    new_array.append((a[i], 1))\n            return new_array\n        elif a[i] == a[i + 1]:\n            n += 1\n        else:\n            if (-a[i]) in symbols:\n                new_array.append((-a[i], -n))\n            else:\n                new_array.append((a[i], n))\n            n = 1"
        },
        {
          "file": "sympy/combinatorics/rewritingsystem.py",
          "type": "function",
          "name": "add_rule",
          "class_name": "RewritingSystem",
          "code": "def add_rule(self, w1, w2, check=False):\n        new_keys = set()\n\n        if w1 == w2:\n            return new_keys\n\n        if w1 < w2:\n            w1, w2 = w2, w1\n\n        if (w1, w2) in self.rules_cache:\n            return new_keys\n        self.rules_cache.append((w1, w2))\n\n        s1, s2 = w1, w2\n\n        # The following is the equivalent of checking\n        # s1 for overlaps with the implicit reductions\n        # {g*g**-1 -> <identity>} and {g**-1*g -> <identity>}\n        # for any generator g without installing the\n        # redundant rules that would result from processing\n        # the overlaps. See [1], Section 3 for details.\n\n        if len(s1) - len(s2) < 3:\n            if s1 not in self.rules:\n                new_keys.add(s1)\n                if not check:\n                    self._add_rule(s1, s2)\n            if s2**-1 > s1**-1 and s2**-1 not in self.rules:\n                new_keys.add(s2**-1)\n                if not check:\n                    self._add_rule(s2**-1, s1**-1)\n\n        # overlaps on the right\n        while len(s1) - len(s2) > -1:\n            g = s1[len(s1)-1]\n            s1 = s1.subword(0, len(s1)-1)\n            s2 = s2*g**-1\n            if len(s1) - len(s2) < 0:\n                #print(\"this\", len(s1)-len(s2))\n                if s2 not in self.rules:\n                    if not check:\n                        self._add_rule(s2, s1)\n                    new_keys.add(s2)\n            elif len(s1) - len(s2) < 3:\n                new = self.add_rule(s1, s2, check)\n                new_keys.update(new)\n\n        # overlaps on the left\n        while len(w1) - len(w2) > -1:\n            g = w1[0]\n            w1 = w1.subword(1, len(w1))\n            w2 = g**-1*w2\n            if len(w1) - len(w2) < 0:\n                if w2 not in self.rules:\n                    if not check:\n                        self._add_rule(w2, w1)\n                    new_keys.add(w2)\n            elif len(w1) - len(w2) < 3:\n                new = self.add_rule(w1, w2, check)\n                new_keys.update(new)\n\n        return new_keys"
        }
      ]
    },
    {
      "pr_number": 13103,
      "pr_title": "fixed cos.rewrite(sqrt) sometimes not fully rewriting",
      "pr_body": "See #13066\r\n`functions.elementary.trigonometric.cos._eval_rewrite_as_sqrt` would fail to fully rewrite `cos(pi/51)` on python 3.6 only. This turned out to be an issue with the `_fermatCoords` function which is supposed to factor 51 into fermat primes. Trigonometric expressions with these fermat primes as denominators of pi can be rewritten using squareroots.\r\n\r\nThe function uses `divmod` repeatedly to get the factors. `n` was set to the whole number result of the `divmod`. This is where the bug was, since that would mean that if `n` was not divisible by that particular factor, then `n` would still be changed to the whole number result, which usually ended up being 0, in which case the function would miss the other factors and return `False`. Or in rare cases it would have led to a false factorization.\r\n\r\nThe reason this bug only revealed itself in 3.6 is because the ordering of dicts was changed. Previously for n=51 it so happened that python ordered the dict with 17 first, then 3, which are both divisible.\r\n\r\n<!-- Please give this pull request a descriptive title. Pull requests with descriptive titles are more likely to receive reviews. Describe what you changed! A title that only references an issue number is not descriptive. -->\r\n\r\n<!-- If this pull request fixes an issue please indicate which issue by typing \"Fixes #NNNN\" below. -->\r\nFixes #13066",
      "issue_id": 13066,
      "issue_title": "cos(pi/51).rewrite(sqrt) does not fully rewrite the expression on python 3.6 (test failure)",
      "issue_body": "It currently returns `cos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2`, even though both `cos(6*pi/17)` and `sin(6*pi/17)` can be rewritten using `sqrt`s. The slow test `test_sincos_rewrite_sqrt` in test_trigonometric.py currently fails because it tests that `cos(pi/51).rewrite(sqrt)` returns the full expression in terms of `sqrt`s. I tested on python 3.4 64 bit and python 3.6 64 bit, and it only happens on 3.6, which is odd. I tried a fresh installation for 3.6 to be sure it wasn't anything I changed and it still happened.\r\n```\r\n>>> cos(pi/51).rewrite(sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite(cos, sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite([cos, sin], sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n```",
      "issue_closed_at": "2017-08-10T09:16:46Z",
      "base_commit": "8ff744d843f9dc78c560e61e3edc01f878d1960b",
      "changes": [
        {
          "file": "sympy/functions/elementary/trigonometric.py",
          "type": "function",
          "name": "_fermatCoords",
          "class_name": "cos",
          "code": "def _fermatCoords(n):\n            # if n can be factored in terms of Fermat primes with\n            # multiplicity of each being 1, return those primes, else\n            # False\n            from sympy import chebyshevt\n            primes = []\n            for p_i in cst_table_some:\n                n, r = divmod(n, p_i)\n                if not r:\n                    primes.append(p_i)\n                    if n == 1:\n                        return tuple(primes)\n            return False"
        }
      ]
    },
    {
      "pr_number": 7420,
      "pr_title": "Return oo for harmonic(oo), this fixes #4668",
      "pr_body": "This value is consistent with this reference from the docstring:\nhttp://functions.wolfram.com/GammaBetaErf/HarmonicNumber/\n",
      "issue_id": 4668,
      "issue_title": "support for divergent sums",
      "issue_body": "```\nCurrently, SymPy does not handle divergent sums such as the following:\n\nsum(1/n, (n, 2, oo))\n\nWhen a sum diverges to +infinity or -infinity, sum should report a result\nof oo or -oo, respectively, instead of just generating an error message.\n```\n\nOriginal issue for #4668: http://code.google.com/p/sympy/issues/detail?id=1569\nOriginal author: https://code.google.com/u/111650660370178398564/\n",
      "issue_closed_at": "2014-04-21T15:44:58Z",
      "base_commit": "4d97f3ee3106ac20471f28f6359e81a5a3ddb7d6",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "eval",
          "class_name": "catalan",
          "code": "def eval(cls, n, evaluate=None):\n        if evaluate is None:\n            evaluate = global_evaluate[0]\n        if n.is_Integer and n.is_nonnegative:\n            return 4**n*C.gamma(n + S.Half)/(C.gamma(S.Half)*C.gamma(n + 2))"
        }
      ]
    },
    {
      "pr_number": 16331,
      "pr_title": "Make var names in generated Cython code unique",
      "pr_body": "Previously, the following call to `unfuncify` would result in non-compiling\r\nCython code due to a variable clash:\r\n\r\n    >>> unfuncify((x, y), x + y, backend='Cython')\r\n\r\nThis was because the resulting Cython code looked something like:\r\n\r\n    def autofunc_c(np.ndarray[np.double_t, ndim=1] _x, np.ndarray[np.double_t, ndim=1] _y):\r\n        cdef int _m = _y.shape[0]\r\n        cdef np.ndarray[np.double_t, ndim=1] _y = np.empty((_m))\r\n\r\nwhere the argument `_y` is declared in the function body even though it is\r\nalready passed as an argument. This commit leverages `doprint` within the C code\r\ngenerator to make sure that generated variable names are unique.\r\n\r\n<!-- 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 #15628\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nAdd a new method to `CythonCodeWrapper` that converts unique dummy variables into distinct strings and pass every expression that emits variable names through this expression. \r\n\r\n#### Other comments\r\n\r\n\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* utilities\r\n  * make variable names in generated cython code unique\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 15628,
      "issue_title": "Issue ufuncifying a two argument function with the Cython backend",
      "issue_body": "```\r\n>>> ufuncify((x, y), x + y, backend='Cython')\r\nTraceback (most recent call last):\r\n  File \"./sympy/utilities/autowrap.py\", line 168, in _process_files\r\n    retoutput = check_output(command, stderr=STDOUT)\r\n  File \"/Users/aaronmeurer/anaconda3/lib/python3.5/subprocess.py\", line 316, in check_output\r\n    **kwargs).stdout\r\n  File \"/Users/aaronmeurer/anaconda3/lib/python3.5/subprocess.py\", line 398, in run\r\n    output=stdout, stderr=stderr)\r\nsubprocess.CalledProcessError: Command '['/Users/aaronmeurer/anaconda3/bin/python', 'setup.py', 'build_ext', '--inplace']' returned non-zero exit status 1\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"./sympy/utilities/autowrap.py\", line 1105, in ufuncify\r\n    tempdir, args, flags, verbose, helpers, **kwargs)\r\n  File \"./sympy/utilities/autowrap.py\", line 640, in autowrap\r\n    return code_wrapper.wrap_code(routine, helpers=helps)\r\n  File \"./sympy/utilities/autowrap.py\", line 149, in wrap_code\r\n    self._process_files(routine)\r\n  File \"./sympy/utilities/autowrap.py\", line 172, in _process_files\r\n    \" \".join(command), e.output.decode('utf-8')))\r\nsympy.utilities.autowrap.CodeWrapError: Error while executing command: /Users/aaronmeurer/anaconda3/bin/python setup.py build_ext --inplace. Command output is:\r\n\r\nError compiling Cython file:\r\n------------------------------------------------------------\r\n...\r\n    void autofunc(double *y_4785968, double *x_4785972, double *y_4785973, int m_4785969)\r\n\r\ndef autofunc_c(np.ndarray[np.double_t, ndim=1] _x, np.ndarray[np.double_t, ndim=1] _y):\r\n\r\n    cdef int _m = _y.shape[0]\r\n    cdef np.ndarray[np.double_t, ndim=1] _y = np.empty((_m))\r\n                                        ^\r\n------------------------------------------------------------\r\n\r\nwrapper_module_3.pyx:10:41: '_y' redeclared\r\n\r\nError compiling Cython file:\r\n------------------------------------------------------------\r\n...\r\ncimport numpy as np\r\n\r\ncdef extern from 'wrapped_code_3.h':\r\n    void autofunc(double *y_4785968, double *x_4785972, double *y_4785973, int m_4785969)\r\n\r\ndef autofunc_c(np.ndarray[np.double_t, ndim=1] _x, np.ndarray[np.double_t, ndim=1] _y):\r\n                                                  ^\r\n------------------------------------------------------------\r\n\r\nwrapper_module_3.pyx:7:51: Previous declaration is here\r\nwarning: wrapper_module_3.pyx:10:41: cdef variable '_y' declared after it is used\r\nCompiling wrapper_module_3.pyx because it changed.\r\n[1/1] Cythonizing wrapper_module_3.pyx\r\nTraceback (most recent call last):\r\n  File \"setup.py\", line 19, in <module>\r\n    setup(ext_modules=cythonize(ext_mods, **cy_opts))\r\n  File \"/Users/aaronmeurer/anaconda3/lib/python3.5/site-packages/Cython/Build/Dependencies.py\", line 1026, in cythonize\r\n    cythonize_one(*args)\r\n  File \"/Users/aaronmeurer/anaconda3/lib/python3.5/site-packages/Cython/Build/Dependencies.py\", line 1146, in cythonize_one\r\n    raise CompileError(None, pyx_file)\r\nCython.Compiler.Errors.CompileError: wrapper_module_3.pyx\r\n```\r\n\r\nIt works if the function just has one argument, or if you use a different backend. ",
      "issue_closed_at": "2019-03-20T15:46:53Z",
      "base_commit": "356a73cd676e0c3f1a1c3057a6895db0d82a1be7",
      "changes": [
        {
          "file": "sympy/utilities/autowrap.py",
          "type": "function",
          "name": "dump_pyx",
          "class_name": "CythonCodeWrapper",
          "code": "def dump_pyx(self, routines, f, prefix):\n        \"\"\"Write a Cython file with python wrappers\n\n        This file contains all the definitions of the routines in c code and\n        refers to the header file.\n\n        Arguments\n        ---------\n        routines\n            List of Routine instances\n        f\n            File-like object to write the file to\n        prefix\n            The filename prefix, used to refer to the proper header file.\n            Only the basename of the prefix is used.\n        \"\"\"\n        headers = []\n        functions = []\n        for routine in routines:\n            prototype = self.generator.get_prototype(routine)\n\n            # C Function Header Import\n            headers.append(self.pyx_header.format(header_file=prefix,\n                                                  prototype=prototype))\n\n            # Partition the C function arguments into categories\n            py_rets, py_args, py_loc, py_inf = self._partition_args(routine.arguments)\n\n            # Function prototype\n            name = routine.name\n            arg_string = \", \".join(self._prototype_arg(arg) for arg in py_args)\n\n            # Local Declarations\n            local_decs = []\n            for arg, val in py_inf.items():\n                proto = self._prototype_arg(arg)\n                mat, ind = val\n                local_decs.append(\"    cdef {0} = {1}.shape[{2}]\".format(proto, mat, ind))\n            local_decs.extend([\"    cdef {0}\".format(self._declare_arg(a)) for a in py_loc])\n            declarations = \"\\n\".join(local_decs)\n            if declarations:\n                declarations = declarations + \"\\n\"\n\n            # Function Body\n            args_c = \", \".join([self._call_arg(a) for a in routine.arguments])\n            rets = \", \".join([str(r.name) for r in py_rets])\n            if routine.results:\n                body = '    return %s(%s)' % (routine.name, args_c)\n                if rets:\n                    body = body + ', ' + rets\n            else:\n                body = '    %s(%s)\\n' % (routine.name, args_c)\n                body = body + '    return ' + rets\n\n            functions.append(self.pyx_func.format(name=name, arg_string=arg_string,\n                    declarations=declarations, body=body))\n\n        # Write text to file\n        if self._need_numpy:\n            # Only import numpy if required\n            f.write(self.pyx_imports)\n        f.write('\\n'.join(headers))\n        f.write('\\n'.join(functions))"
        },
        {
          "file": "sympy/utilities/autowrap.py",
          "type": "function",
          "name": "dump_pyx",
          "class_name": "CythonCodeWrapper",
          "code": "def dump_pyx(self, routines, f, prefix):\n        \"\"\"Write a Cython file with python wrappers\n\n        This file contains all the definitions of the routines in c code and\n        refers to the header file.\n\n        Arguments\n        ---------\n        routines\n            List of Routine instances\n        f\n            File-like object to write the file to\n        prefix\n            The filename prefix, used to refer to the proper header file.\n            Only the basename of the prefix is used.\n        \"\"\"\n        headers = []\n        functions = []\n        for routine in routines:\n            prototype = self.generator.get_prototype(routine)\n\n            # C Function Header Import\n            headers.append(self.pyx_header.format(header_file=prefix,\n                                                  prototype=prototype))\n\n            # Partition the C function arguments into categories\n            py_rets, py_args, py_loc, py_inf = self._partition_args(routine.arguments)\n\n            # Function prototype\n            name = routine.name\n            arg_string = \", \".join(self._prototype_arg(arg) for arg in py_args)\n\n            # Local Declarations\n            local_decs = []\n            for arg, val in py_inf.items():\n                proto = self._prototype_arg(arg)\n                mat, ind = val\n                local_decs.append(\"    cdef {0} = {1}.shape[{2}]\".format(proto, mat, ind))\n            local_decs.extend([\"    cdef {0}\".format(self._declare_arg(a)) for a in py_loc])\n            declarations = \"\\n\".join(local_decs)\n            if declarations:\n                declarations = declarations + \"\\n\"\n\n            # Function Body\n            args_c = \", \".join([self._call_arg(a) for a in routine.arguments])\n            rets = \", \".join([str(r.name) for r in py_rets])\n            if routine.results:\n                body = '    return %s(%s)' % (routine.name, args_c)\n                if rets:\n                    body = body + ', ' + rets\n            else:\n                body = '    %s(%s)\\n' % (routine.name, args_c)\n                body = body + '    return ' + rets\n\n            functions.append(self.pyx_func.format(name=name, arg_string=arg_string,\n                    declarations=declarations, body=body))\n\n        # Write text to file\n        if self._need_numpy:\n            # Only import numpy if required\n            f.write(self.pyx_imports)\n        f.write('\\n'.join(headers))\n        f.write('\\n'.join(functions))"
        },
        {
          "file": "sympy/utilities/autowrap.py",
          "type": "function",
          "name": "_prototype_arg",
          "class_name": "CythonCodeWrapper",
          "code": "def _prototype_arg(self, arg):\n        mat_dec = \"np.ndarray[{mtype}, ndim={ndim}] {name}\"\n        np_types = {'double': 'np.double_t',\n                    'int': 'np.int_t'}\n        t = arg.get_datatype('c')\n        if arg.dimensions:\n            self._need_numpy = True\n            ndim = len(arg.dimensions)\n            mtype = np_types[t]\n            return mat_dec.format(mtype=mtype, ndim=ndim, name=arg.name)\n        else:\n            return \"%s %s\" % (t, str(arg.name))"
        },
        {
          "file": "sympy/utilities/autowrap.py",
          "type": "function",
          "name": "_declare_arg",
          "class_name": "CythonCodeWrapper",
          "code": "def _declare_arg(self, arg):\n        proto = self._prototype_arg(arg)\n        if arg.dimensions:\n            shape = '(' + ','.join(str(i[1] + 1) for i in arg.dimensions) + ')'\n            return proto + \" = np.empty({shape})\".format(shape=shape)\n        else:\n            return proto + \" = 0\""
        }
      ]
    }
  ]
}