{
  "instance_id": "sympy__sympy-14396",
  "repo": "sympy/sympy",
  "created_at": "2018-03-05T19:18:01Z",
  "problem_statement": "Poly(domain='RR[y,z]') doesn't work\n``` py\nIn [14]: Poly(1.2*x*y*z, x)\nOut[14]: Poly(1.2*y*z*x, x, domain='RR[y,z]')\n\nIn [15]: Poly(1.2*x*y*z, x, domain='RR[y,z]')\n---------------------------------------------------------------------------\nOptionError                               Traceback (most recent call last)\n<ipython-input-15-d83389519ae1> in <module>()\n----> 1 Poly(1.2*x*y*z, x, domain='RR[y,z]')\n\n/Users/aaronmeurer/Documents/Python/sympy/sympy-scratch/sympy/polys/polytools.py in __new__(cls, rep, *gens, **args)\n     69     def __new__(cls, rep, *gens, **args):\n     70         \"\"\"Create a new polynomial instance out of something useful. \"\"\"\n---> 71         opt = options.build_options(gens, args)\n     72\n     73         if 'order' in opt:\n\n/Users/aaronmeurer/Documents/Python/sympy/sympy-scratch/sympy/polys/polyoptions.py in build_options(gens, args)\n    718\n    719     if len(args) != 1 or 'opt' not in args or gens:\n--> 720         return Options(gens, args)\n    721     else:\n    722         return args['opt']\n\n/Users/aaronmeurer/Documents/Python/sympy/sympy-scratch/sympy/polys/polyoptions.py in __init__(self, gens, args, flags, strict)\n    151                     self[option] = cls.preprocess(value)\n    152\n--> 153         preprocess_options(args)\n    154\n    155         for key, value in dict(defaults).items():\n\n/Users/aaronmeurer/Documents/Python/sympy/sympy-scratch/sympy/polys/polyoptions.py in preprocess_options(args)\n    149\n    150                 if value is not None:\n--> 151                     self[option] = cls.preprocess(value)\n    152\n    153         preprocess_options(args)\n\n/Users/aaronmeurer/Documents/Python/sympy/sympy-scratch/sympy/polys/polyoptions.py in preprocess(cls, domain)\n    480                 return sympy.polys.domains.QQ.algebraic_field(*gens)\n    481\n--> 482         raise OptionError('expected a valid domain specification, got %s' % domain)\n    483\n    484     @classmethod\n\nOptionError: expected a valid domain specification, got RR[y,z]\n```\n\nAlso, the wording of error message could be improved\n\n",
  "patch": "diff --git a/sympy/polys/polyoptions.py b/sympy/polys/polyoptions.py\n--- a/sympy/polys/polyoptions.py\n+++ b/sympy/polys/polyoptions.py\n@@ -405,7 +405,7 @@ class Domain(with_metaclass(OptionType, Option)):\n     _re_realfield = re.compile(r\"^(R|RR)(_(\\d+))?$\")\n     _re_complexfield = re.compile(r\"^(C|CC)(_(\\d+))?$\")\n     _re_finitefield = re.compile(r\"^(FF|GF)\\((\\d+)\\)$\")\n-    _re_polynomial = re.compile(r\"^(Z|ZZ|Q|QQ)\\[(.+)\\]$\")\n+    _re_polynomial = re.compile(r\"^(Z|ZZ|Q|QQ|R|RR|C|CC)\\[(.+)\\]$\")\n     _re_fraction = re.compile(r\"^(Z|ZZ|Q|QQ)\\((.+)\\)$\")\n     _re_algebraic = re.compile(r\"^(Q|QQ)\\<(.+)\\>$\")\n \n@@ -459,8 +459,12 @@ def preprocess(cls, domain):\n \n                 if ground in ['Z', 'ZZ']:\n                     return sympy.polys.domains.ZZ.poly_ring(*gens)\n-                else:\n+                elif ground in ['Q', 'QQ']:\n                     return sympy.polys.domains.QQ.poly_ring(*gens)\n+                elif ground in ['R', 'RR']:\n+                    return sympy.polys.domains.RR.poly_ring(*gens)\n+                else:\n+                    return sympy.polys.domains.CC.poly_ring(*gens)\n \n             r = cls._re_fraction.match(domain)\n \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": 13564,
      "pr_title": "Resolves RecursionError in latex representation",
      "pr_body": "fixes #13559. It was due to factor of `1/1`  \r\n```python\r\nexpr = parse_expr('5/1', evaluate=False)\r\nexpr.args\r\n```\r\nit gives `(5 , 1/1)` , which was not handled properly in latex conversion . So everytime an expression was divided by 1 , it resulted in RecursionError",
      "issue_id": 13559,
      "issue_title": "LaTeX representation raises RecursionError",
      "issue_body": "LaTeX representation of an expression that has division by 1 causes `RecursionError`. SymPy version: 1.1.1.\r\n\r\nCode to reproduce the bug:\r\n```python\r\nfrom sympy import latex\r\nfrom sympy.parsing.sympy_parser import parse_expr\r\n\r\nexpr = parse_expr('2/1', evaluate=False)\r\nlatex(expr)\r\n```\r\nOutput:\r\n```\r\n...\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/printer.py in _print(self, expr, *args, **kwargs)\r\n    255                 printmethod = '_print_' + cls.__name__\r\n    256                 if hasattr(self, printmethod):\r\n--> 257                     return getattr(self, printmethod)(expr, *args, **kwargs)\r\n    258             # Unknown object, fall back to the emptyPrinter.\r\n    259             return self.emptyPrinter(expr)\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in _print_Pow(self, expr)\r\n    466         elif expr.exp.is_Rational and expr.exp.is_negative and expr.base.is_commutative:\r\n    467             # Things like 1/x\r\n--> 468             return self._print_Mul(expr)\r\n    469         else:\r\n    470             if expr.base.is_Function:\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in _print_Mul(self, expr)\r\n    396             # use the original expression here, since fraction() may have\r\n    397             # altered it when producing numer and denom\r\n--> 398             tex += convert(expr)\r\n    399         else:\r\n    400             snumer = convert(numer)\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/latex.py in convert(expr)\r\n    366         def convert(expr):\r\n    367             if not expr.is_Mul:\r\n--> 368                 return str(self._print(expr))\r\n    369             else:\r\n    370                 _tex = last_term_tex = \"\"\r\n\r\n... last 4 frames repeated, from the frame below ...\r\n\r\n~/.virtualenvs/sympy/lib/python3.5/site-packages/sympy/printing/printer.py in _print(self, expr, *args, **kwargs)\r\n    255                 printmethod = '_print_' + cls.__name__\r\n    256                 if hasattr(self, printmethod):\r\n--> 257                     return getattr(self, printmethod)(expr, *args, **kwargs)\r\n    258             # Unknown object, fall back to the emptyPrinter.\r\n    259             return self.emptyPrinter(expr)\r\n\r\nRecursionError: maximum recursion depth exceeded in comparison\r\n```\r\n",
      "issue_closed_at": "2017-11-09T16:49:04Z",
      "base_commit": "36d9c850c642bec047e2cbad0a07c48f4fc7c779",
      "changes": [
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "_print_Gradient",
          "class_name": "LatexPrinter",
          "code": "def _print_Gradient(self, expr):\n        func = expr._expr\n        return r\"\\nabla\\cdot %s\" % self.parenthesize(func, PRECEDENCE['Mul'])"
        },
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "convert",
          "class_name": "LatexPrinter",
          "code": "def convert(expr):\n            if not expr.is_Mul:\n                return str(self._print(expr))\n            else:\n                _tex = last_term_tex = \"\"\n\n                if self.order not in ('old', 'none'):\n                    args = expr.as_ordered_factors()\n                else:\n                    args = expr.args\n\n                for i, term in enumerate(args):\n                    term_tex = self._print(term)\n\n                    if self._needs_mul_brackets(term, first=(i == 0),\n                                                last=(i == len(args) - 1)):\n                        term_tex = r\"\\left(%s\\right)\" % term_tex\n\n                    if _between_two_numbers_p[0].search(last_term_tex) and \\\n                            _between_two_numbers_p[1].match(term_tex):\n                        # between two numbers\n                        _tex += numbersep\n                    elif _tex:\n                        _tex += separator\n\n                    _tex += term_tex\n                    last_term_tex = term_tex\n                return _tex"
        }
      ]
    },
    {
      "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": 9256,
      "pr_title": "fixes #7183: rewrite as sqrt, fibonacci(n) and lucas(n)",
      "pr_body": "`Fibonacci` and `Lucas` can now be rewritten using `sqrt`.\n\n```\n>>> fibonacci(n).rewrite(sqrt)\n2**(-n)*sqrt(5)*((1 + sqrt(5))**n - (-sqrt(5) + 1)**n) / 5\n>>> lucas(n).rewrite(sqrt)\n2**(-n)*((1 + sqrt(5))**n + (-sqrt(5) + 1)**n)\n```\n\nFixes #7183\n",
      "issue_id": 7183,
      "issue_title": "fibonacci(n).rewrite(sqrt) returns fibonacci(n)",
      "issue_body": "```\nfibonacci(n).rewrite(sqrt) should return:\n2**(-n)*sqrt(5)*((1 + sqrt(5))**n - (-sqrt(5) + 1)**n)/5\n\nIt seems finbonacci._eval_rewrite_sqrt() is not implemented.\n```\n\nOriginal issue for #7183: http://code.google.com/p/sympy/issues/detail?id=4084\nOriginal author: https://code.google.com/u/118279007905392951376/\n",
      "issue_closed_at": "2015-04-15T19:21:05Z",
      "base_commit": "56c63a9bb0f7c9a70a7fc1d27b21022c0dfb85e9",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "line",
          "name": "line 19",
          "code": "from sympy.functions.elementary.exponential import log\nfrom sympy.functions.elementary.integers import floor\nfrom sympy.functions.elementary.trigonometric import sin, cos, cot\n\nfrom mpmath import bernfrac, workprec\nfrom mpmath.libmp import ifib as _ifib"
        },
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "eval",
          "class_name": "genocchi",
          "code": "def eval(cls, n):\n        if n.is_Number:\n            if (not n.is_Integer) or n.is_nonpositive:\n                raise ValueError(\"Genocchi numbers are defined only for \" +\n                                 \"positive integers\")\n            return 2 * (1 - S(2) ** n) * bernoulli(n)\n\n        if n.is_odd and (n - 1).is_positive:\n            return S.Zero\n\n        if (n - 1).is_zero:\n            return S.One"
        },
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "eval",
          "class_name": "genocchi",
          "code": "def eval(cls, n):\n        if n.is_Number:\n            if (not n.is_Integer) or n.is_nonpositive:\n                raise ValueError(\"Genocchi numbers are defined only for \" +\n                                 \"positive integers\")\n            return 2 * (1 - S(2) ** n) * bernoulli(n)\n\n        if n.is_odd and (n - 1).is_positive:\n            return S.Zero\n\n        if (n - 1).is_zero:\n            return S.One"
        }
      ]
    }
  ]
}