{
  "original_problem": {
    "instance_id": "sympy__sympy-24102",
    "repo": "sympy/sympy",
    "created_at": "2022-10-01T18:41:32Z",
    "problem_statement": "Cannot parse Greek characters (and possibly others) in parse_mathematica\nThe old Mathematica parser `mathematica` in the package `sympy.parsing.mathematica` was able to parse e.g. Greek characters. Hence the following example works fine:\r\n```\r\nfrom sympy.parsing.mathematica import mathematica\r\nmathematica('λ')\r\nOut[]: \r\nλ\r\n```\r\n\r\nAs of SymPy v. 1.11, the `mathematica` function is deprecated, and is replaced by `parse_mathematica`. This function, however, seems unable to handle the simple example above:\r\n```\r\nfrom sympy.parsing.mathematica import parse_mathematica\r\nparse_mathematica('λ')\r\nTraceback (most recent call last):\r\n...\r\nFile \"<string>\", line unknown\r\nSyntaxError: unable to create a single AST for the expression\r\n```\r\n\r\nThis appears to be due to a bug in `parse_mathematica`, which is why I have opened this issue.\r\n\r\nThanks in advance!\nCannot parse Greek characters (and possibly others) in parse_mathematica\nThe old Mathematica parser `mathematica` in the package `sympy.parsing.mathematica` was able to parse e.g. Greek characters. Hence the following example works fine:\r\n```\r\nfrom sympy.parsing.mathematica import mathematica\r\nmathematica('λ')\r\nOut[]: \r\nλ\r\n```\r\n\r\nAs of SymPy v. 1.11, the `mathematica` function is deprecated, and is replaced by `parse_mathematica`. This function, however, seems unable to handle the simple example above:\r\n```\r\nfrom sympy.parsing.mathematica import parse_mathematica\r\nparse_mathematica('λ')\r\nTraceback (most recent call last):\r\n...\r\nFile \"<string>\", line unknown\r\nSyntaxError: unable to create a single AST for the expression\r\n```\r\n\r\nThis appears to be due to a bug in `parse_mathematica`, which is why I have opened this issue.\r\n\r\nThanks in advance!\n",
    "patch": "diff --git a/sympy/parsing/mathematica.py b/sympy/parsing/mathematica.py\n--- a/sympy/parsing/mathematica.py\n+++ b/sympy/parsing/mathematica.py\n@@ -654,7 +654,7 @@ def _from_mathematica_to_tokens(self, code: str):\n             code_splits[i] = code_split\n \n         # Tokenize the input strings with a regular expression:\n-        token_lists = [tokenizer.findall(i) if isinstance(i, str) else [i] for i in code_splits]\n+        token_lists = [tokenizer.findall(i) if isinstance(i, str) and i.isascii() else [i] for i in code_splits]\n         tokens = [j for i in token_lists for j in i]\n \n         # Remove newlines at the beginning\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_18738",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves handling non-dimensional terms, which is unrelated to character parsing or encoding."
      },
      {
        "idx": 2,
        "id": "similar_16628",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about memory consumption in geometric calculations, which does not relate to parsing or encoding issues."
      },
      {
        "idx": 3,
        "id": "similar_24074",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with a deprecated method in threading, unrelated to parsing or character encoding."
      },
      {
        "idx": 4,
        "id": "similar_22954",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on simplifying algebraic field construction, not on parsing or encoding."
      },
      {
        "idx": 5,
        "id": "similar_11102",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about output representation and error handling, not related to parsing or character encoding."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Dimensional analysis: AttributeError in get_dimensional_dependencies with simple example",
        "issue_body": "Hi all, \r\n\r\nI am trying to get a simple example of a dimensional analysis (as described in [this tutorial](https://docs.sympy.org/latest/modules/physics/units/examples.html#dimensional-analysis) ) to work. Unfortunately, an AttributeError is raised inside the method `get_dimensional_dependencies`.\r\n\r\nHere is a minimal example:\r\n```\r\nfrom sympy import init_printing, symbols, sqrt\r\nfrom sympy.physics.units.systems.si import dimsys_SI\r\nfrom sympy.physics.units import length\r\ninit_printing()\r\n\r\na, b = symbols(\"a b\")\r\nc = sqrt(a**2 + b**2)\r\nc_dim = c.subs({a: length, b: length})\r\n\r\nprint(c_dim) \r\n# >> sqrt(2)*Dimension(sqrt(length**2))\r\n\r\ndimsys_SI.equivalent_dims(c_dim, length) \r\n# >> AttributeError: 'NoneType' object has no attribute 'items' \r\n```\r\n\r\nIt seems that `get_dimensional_dependencies` has problems handling non-dimensional terms (i.e. the `sqrt(2)` term in `c_dim` in the above example). Oddly, when I try to do the substitution 'manually', this term is eliminated:\r\n```\r\nc_dim = sqrt(length**2 + length**2)\r\nprint(c_dim) \r\n# >> Dimension(sqrt(length**2))\r\n```\r\n\r\nIs this intended behavior? It does make sense that multiplying a dimension with a dimensionless value should just give back the dimension as result. However, how come the `sqrt(2)`-term is not eliminated when substituting symbols for dimensions using `subs`?\r\n\r\nI hope I haven't just misunderstood the tutorial/docs. Happy for any help or hints. Also, I would be willing to dive into the code if someone would point me into the right direction.\r\n\r\nThis may be related to the bug discussed [here](https://gitter.im/sympy/sympy?at=5dc0c052fb4dab784a65dfb1).\r\n\r\nThe above example was tested with Python 2.7 and 3.7 and sympy 1.5.1.",
        "issue_id": 18738,
        "pr_number": 19705,
        "pr_title": "Fix handling of addition and multiplication of Dimensions for get_dimensional_dependencies",
        "pr_body": "#### References to other Issues or PRs\r\nFixes #18738\r\n\r\n#### Brief description of what is fixed or changed\r\nFixes some cases where the method get_dimensional_dependencies of DimensionSystem raises exceptions when handling adding and multiplying dimensions. This addresses issue #18738 (at least the first half dealing with Dimensions, the second comment dealing with Quantities still doesn't work).\r\n\r\nThe following example previously raised an exception and now works properly:\r\n```\r\nIn [3]: from sympy.physics.units import length, mass, acceleration, time, pressure, force\r\nIn [4]: from sympy.physics.units.systems.si import dimsys_SI\r\nIn [5]: dimsys_SI.get_dimensional_dependencies(mass * length / time**2 + force - pressure * length**2)\r\nOut[5]: {'mass': 1, 'length': 1, 'time': -2}\r\n```\r\n\r\n#### Other comments\r\nAs part of the fix, the following two lines needed to be moved from the beginning of get_dimensional_dependencies to the beginning of _get_dimensional_dependencies_from_name:\r\n```\r\n        if isinstance(name, Dimension):\r\n            name = name.name\r\n\r\n        if isinstance(name, str):\r\n            name = Symbol(name)\r\n```\r\n\r\nThis had to be done to allow the recursion of the multiplication and addition operators to work properly. This is what fixed #18738 even though I was just trying to get the addition case above to work.  Additionally, an exception now gets raised if _def_dimensional_dependencies_for_name does not handle the input so that more useful error messages are provided then what is shown in #18738.\r\n\r\nIf the user attempts to add incompatible dimensions and then calls get_dimensional_dependencies, an exception is raised.  For example the following will raise an exception:\r\n\r\n`In [4]: dimsys_SI.get_dimensional_dependencies(mass * length / time**2 + pressure)`\r\n\r\nTests have been added for issue #18738 and for the addition cases listed above.\r\n\r\n#### Release Notes\r\n<!-- BEGIN RELEASE NOTES -->\r\n* physics.units\r\n  * Fixed some dimensional analysis bugs with the addition and multiplication operators.\r\n<!-- END RELEASE NOTES -->",
        "issue_closed_at": "2020-07-17T11:37:09Z",
        "base_commit": "f46f4488c7cb7aff9666e26ce1bfb980f98e97a7"
      },
      "summary": "### Summary:\nThis issue is related to an AttributeError encountered during a dimensional analysis operation within the SymPy library, specifically when using the method `get_dimensional_dependencies`. The problem arises when the function attempts to handle non-dimensional terms, such as the square root of a constant, which results in the error due to the function returning a `NoneType` object instead of a valid response. This suggests an inability of the method to correctly process expressions that include dimensionless factors, leading to incorrect behavior.\n\nKey symptoms include the failure of `dimsys_SI.equivalent_dims` to execute properly, resulting in an `AttributeError` when faced with expressions involving non-dimensional constants combined with dimensional terms. The issue is noted when substituting symbolic expressions for dimensions, where dimensionless constants are not simplified or eliminated as expected.\n\nThe affected component is the `DimensionSystem` class within the `sympy.physics.units.dimensions` module. The functions `dimensional_dependencies` and `_get_dimensional_dependencies_for_name` were identified as areas requiring fixes to address the problem.\n\nThe potential impact of this issue is moderate, affecting users performing dimensional analysis in SymPy, particularly those using the `equivalent_dims` method. The severity is heightened for users relying on accurate dimension dependency outputs for scientific calculations or unit conversions.\n\nRelevant technical details include the observation that when dimensionless factors are manually substituted, they are eliminated correctly, suggesting an inconsistency or bug in the automatic processing of such expressions by the `subs` method. This indicates a need for improved handling of dimensionless terms within the dimensional analysis functions of SymPy. The issue affects multiple Python versions and SymPy release 1.5.1, requiring updates to the dimension handling logic in the specified functions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Dimensional analysis: AttributeError in get_dimensional_dependencies with simple example\n\nBody:\nHi all, \r\n\r\nI am trying to get a simple example of a dimensional analysis (as described in [this tutorial](https://docs.sympy.org/latest/modules/physics/units/examples.html#dimensional-analysis) ) to work. Unfortunately, an AttributeError is raised inside the method `get_dimensional_dependencies`.\r\n\r\nHere is a minimal example:\r\n```\r\nfrom sympy import init_printing, symbols, sqrt\r\nfrom sympy.physics.units.systems.si import dimsys_SI\r\nfrom sympy.physics.units import length\r\ninit_printing()\r\n\r\na, b = symbols(\"a b\")\r\nc = sqrt(a**2 + b**2)\r\nc_dim = c.subs({a: length, b: length})\r\n\r\nprint(c_dim) \r\n# >> sqrt(2)*Dimension(sqrt(length**2))\r\n\r\ndimsys_SI.equivalent_dims(c_dim, length) \r\n# >> AttributeError: 'NoneType' object has no attribute 'items' \r\n```\r\n\r\nIt seems that `get_dimensional_dependencies` has problems handling non-dimensional terms (i.e. the `sqrt(2)` term in `c_dim` in the above example). Oddly, when I try to do the substitution 'manually', this term is eliminated:\r\n```\r\nc_dim = sqrt(length**2 + length**2)\r\nprint(c_dim) \r\n# >> Dimension(sqrt(length**2))\r\n```\r\n\r\nIs this intended behavior? It does make sense that multiplying a dimension with a dimensionless value should just give back the dimension as result. However, how come the `sqrt(2)`-term is not eliminated when substituting symbols for dimensions using `subs`?\r\n\r\nI hope I haven't just misunderstood the tutorial/docs. Happy for any help or hints. Also, I would be willing to dive into the code if someone would point me into the right direction.\r\n\r\nThis may be related to the bug discussed [here](https://gitter.im/sympy/sympy?at=5dc0c052fb4dab784a65dfb1).\r\n\r\nThe above example was tested with Python 2.7 and 3.7 and sympy 1.5.1.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/physics/units/dimensions.py\n  function: DimensionSystem.dimensional_dependencies\n  function: DimensionSystem._get_dimensional_dependencies_for_name\n  function: DimensionSystem._get_dimensional_dependencies_for_name\n"
    },
    {
      "similar_issue": {
        "issue_title": "Geometry: Line-Segment-Intersection can run into memory problems",
        "issue_body": "Hi,\r\n\r\nwhen determining a line-segment-intersection, depending on the geometry, sympy can take up som much memory that the script will crash.\r\n\r\nI'm on Windows, using CPython 3.7.3 on sympy commit b97cbe99, although the issue exists in version 1.3 too.\r\n\r\nExample code:\r\n<pre>\r\n#!Python -u\r\n\r\nimport sys, os, time, math\r\n\r\nsys.stderr.write(str(os.getpid())+time.strftime(': starting @ %d%b%y, %H:%M\\n'))\r\n\t\r\nfrom sympy.geometry import Point, Point2D, Line, Segment, intersection\r\nfrom sympy import *\r\nimport sympy\r\n\r\nsys.stderr.write('sympy version: '+sympy.__version__+'\\n')\r\n\r\np0=Point2D(249/5, 497999/10000)\r\np1x=3*(-19659028262*sqrt(405639795226) + 676896692394731 + 6704069269*sqrt(630547164901) + 33200*sqrt(255775022850776494562626))/(2000*(sqrt(255775022850776494562626) + 995999*sqrt(405639795226) + 995999*sqrt(630547164901) + 811280586451))\r\np1y=(-498000*sqrt(255775022850776494562626) - 995999*sqrt(630547164901) + 90004251917891999 + 496005510002*sqrt(405639795226))/(10000*(sqrt(255775022850776494562626) + 995999*sqrt(405639795226) + 995999*sqrt(630547164901) + 811280586451))\r\np1=Point2D(p1x, p1y)\r\n\r\n\r\nsys.stderr.write('p1: '+str(p1)+'\\n')\r\n\r\np2=Point2D(497/10, -497/10)\r\np3=Point2D(-497/10, -497/10)\r\n\r\nl=Line(p0,p1)\r\ns=Segment(p2,p3)\r\nints=intersection(l,s)\r\n\r\n\r\nsys.stderr.write(str(os.getpid())+time.strftime(': done @ %d%b%y, %H:%M\\n'))\r\n</pre>",
        "issue_id": 16628,
        "pr_number": 16668,
        "pr_title": "speed up Line/Segment intersections",
        "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\". See\r\nhttps://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n\r\ncloses #16628\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nIntersections will return more quickly for Line/Segment interactions in 2D because a redundant check that the point is in the line has been eliminated.\r\n\r\nPoint containment in a 2D Segment now uses a quick check before using the triangle inequality.\r\n\r\n#### Other comments\r\n\r\nSome tests which were quite fast already were moved out of the slow test.\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- geometry\r\n  * improved response time of 2D Line/Segement interactions and Segment containment of Point\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-04-17T22:08:24Z",
        "base_commit": "96925f549e10ee2d95e592d1fe84cbdd39cec3f4"
      },
      "summary": "### Summary: This issue is related to the SymPy library, specifically within its geometry module, where calculating the intersection of certain geometric entities leads to excessive memory consumption. The problem arises when determining line-segment intersections, particularly with specific complex geometric configurations, causing the script to crash due to insufficient memory. The issue is prevalent across multiple versions of SymPy, including version 1.3 and a specific commit version. The symptoms include high memory usage and script termination when executing the intersection logic. The affected components are primarily the geometric entities such as Line and Segment, and their intersection computations. This can significantly impact users who rely on this functionality for complex geometric calculations, potentially halting processes and requiring additional resources or workarounds. The technical details involve intricate mathematical expressions that lead to heavy computational demands, which are now addressed by revisions in the code, notably in the methods handling intersections and segment containment within the geometry module.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Geometry: Line-Segment-Intersection can run into memory problems\n\nBody:\nHi,\r\n\r\nwhen determining a line-segment-intersection, depending on the geometry, sympy can take up som much memory that the script will crash.\r\n\r\nI'm on Windows, using CPython 3.7.3 on sympy commit b97cbe99, although the issue exists in version 1.3 too.\r\n\r\nExample code:\r\n<pre>\r\n#!Python -u\r\n\r\nimport sys, os, time, math\r\n\r\nsys.stderr.write(str(os.getpid())+time.strftime(': starting @ %d%b%y, %H:%M\\n'))\r\n\t\r\nfrom sympy.geometry import Point, Point2D, Line, Segment, intersection\r\nfrom sympy import *\r\nimport sympy\r\n\r\nsys.stderr.write('sympy version: '+sympy.__version__+'\\n')\r\n\r\np0=Point2D(249/5, 497999/10000)\r\np1x=3*(-19659028262*sqrt(405639795226) + 676896692394731 + 6704069269*sqrt(630547164901) + 33200*sqrt(255775022850776494562626))/(2000*(sqrt(255775022850776494562626) + 995999*sqrt(405639795226) + 995999*sqrt(630547164901) + 811280586451))\r\np1y=(-498000*sqrt(255775022850776494562626) - 995999*sqrt(630547164901) + 90004251917891999 + 496005510002*sqrt(405639795226))/(10000*(sqrt(255775022850776494562626) + 995999*sqrt(405639795226) + 995999*sqrt(630547164901) + 811280586451))\r\np1=Point2D(p1x, p1y)\r\n\r\n\r\nsys.stderr.write('p1: '+str(p1)+'\\n')\r\n\r\np2=Point2D(497/10, -497/10)\r\np3=Point2D(-497/10, -497/10)\r\n\r\nl=Line(p0,p1)\r\ns=Segment(p2,p3)\r\nints=intersection(l,s)\r\n\r\n\r\nsys.stderr.write(str(os.getpid())+time.strftime(': done @ %d%b%y, %H:%M\\n'))\r\n</pre>\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/geometry/line.py\n  function: LinearEntity.intersect_parallel_segments\n  function: Segment.contains\n\nsympy/geometry/polygon.py\n  function: Triangle.bisectors\n"
    },
    {
      "similar_issue": {
        "issue_title": "pygletplot is using deprecated threading.event.isSet()",
        "issue_body": "`isSet()` is deprecated in favour of `is_set()`\r\n\r\nhttps://docs.python.org/3/library/threading.html#threading.Event.is_set\r\n\r\nWhen I try to run `sympy.test(\"sympy/plotting/pygletplot\")`, this causes errors because the threading library interprets a `DeprecationWarning` inside a thread as an exception and `raise`s it outside the thread.\r\n\r\nIt seems like the only place using this function is plot_mode_base.py\r\n\r\nhttps://github.com/sympy/sympy/search?q=isSet\r\n\r\nThe `is_set` alternative was added in Python 2.6, so I don't think we need to use `isSet` for backwards compatibility any more: https://docs.python.org/2.6/library/threading.html#threading.Event.is_set",
        "issue_id": 24074,
        "pr_number": 24078,
        "pr_title": "Replace deprecated .isSet() method with .is_set()",
        "pr_body": "\r\n\r\n#### References to other Issues or PRs\r\nFixes #24074\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nChange pyglet threading code to use `Event.is_set()` which is the approved replacement for `Event.isSet()`\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 between the BEGIN and END\r\nstatements. The basic format is a bulleted list with the name of the subpackage\r\nand the release note for this PR. For example:\r\n\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n\r\n* plotting\r\n  * Replace use of deprecated `Event.isSet()` method\r\n \r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2022-09-23T09:45:57Z",
        "base_commit": "514579c655bf22e2af14f0743376ae1d7befe345"
      },
      "summary": "### Summary: This issue addresses the use of a deprecated method in the Python threading library within the pygletplot module of the SymPy plotting package. The deprecated method, `isSet()`, has been replaced by the recommended `is_set()` function. The problem arises because the outdated method causes a `DeprecationWarning` to be interpreted as an exception when running tests, potentially disrupting multithreaded operations. The primary symptom was errors triggered during the execution of `sympy.test(\"sympy/plotting/pygletplot\")`, caused by a `DeprecationWarning` being raised outside its originating thread. The affected component is located in the `plot_mode_base.py` file within the pygletplot module. The impact is significant during testing and development, as such warnings can lead to interrupted processes and hinder debugging efforts. The issue is resolved by updating the call to the current `is_set()` method, which has been available since Python 2.6, ensuring backward compatibility is not a concern. This technical adjustment enhances code reliability and aligns with best practices in Python programming.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: pygletplot is using deprecated threading.event.isSet()\n\nBody:\n`isSet()` is deprecated in favour of `is_set()`\r\n\r\nhttps://docs.python.org/3/library/threading.html#threading.Event.is_set\r\n\r\nWhen I try to run `sympy.test(\"sympy/plotting/pygletplot\")`, this causes errors because the threading library interprets a `DeprecationWarning` inside a thread as an exception and `raise`s it outside the thread.\r\n\r\nIt seems like the only place using this function is plot_mode_base.py\r\n\r\nhttps://github.com/sympy/sympy/search?q=isSet\r\n\r\nThe `is_set` alternative was added in Python 2.6, so I don't think we need to use `isSet` for backwards compatibility any more: https://docs.python.org/2.6/library/threading.html#threading.Event.is_set\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/plotting/pygletplot/plot_mode_base.py\n  function: PlotModeBase._calculate_all\n  function: PlotModeBase._calculate_verts\n  function: PlotModeBase._calculate_cverts\n  function: PlotModeBase._get_calculating_verts_len\n"
    },
    {
      "similar_issue": {
        "issue_title": "polys/numberfields: Convenience constructors for `AlgebraicField`",
        "issue_body": "I'd like to propose a pair of new constructor methods, to support a couple of common use cases.\r\n\r\n\r\n## Use Case 1\r\n\r\n* You want a number field `Q(a)`,\r\n* AND you have the minimal polynomial `f(x)` for `a`,\r\n* AND you don't care _which_ root of `f` `a` is. (E.g. it's a Galois field, so it doesn't matter.),\r\n* AND, OPTIONALLY you want an `alias` for `a` so that field elements print nicely.\r\n\r\n\r\n## Use Case 2\r\n\r\n* You want the `n`th cyclotomic field.\r\n* You probably want the primitive element to be aliased either `\"zeta\"` or `f\"zeta{n}\"`.\r\n\r\n\r\n\r\n## The Current Situation\r\n\r\nFor Use Case 1, you have to do this:\r\n```python\r\nalpha = AlgebraicNumber(CRootOf(f, -1), alias=\"alpha\")\r\nK = QQ.algebraic_field(alpha)\r\n\r\n```\r\nwhich has several problems:\r\n\r\n* It's too long.\r\n* You shouldn't have to import `CRootOf`.\r\n* You shouldn't have to choose an index for `CRootOf`.\r\n\r\n\r\nUse Case 2 is similar, and you also have to import `cyclotomic_poly`:\r\n\r\n```python\r\nzeta = AlgebraicNumber(CRootOf(cyclotomic_poly(19), -1), alias=\"zeta\")\r\nK = QQ.algebraic_field(zeta)\r\n```\r\n\r\n\r\n\r\n## Proposal\r\n\r\nAlongside the `QQ.algebraic_field()` method (which takes one arg, being an `Expr`) I would propose two additional methods:\r\n\r\n```python\r\n    def alg_field_from_poly(self, poly, alias=None, root_index=-1):\r\n        alpha = AlgebraicNumber(CRootOf(poly, root_index), alias=alias)\r\n        return self.algebraic_field(alpha)\r\n\r\n    def cyclotomic_field(self, n, alias=\"zeta\", ss=False, gen=None, root_index=-1):\r\n        if ss:\r\n            alias += str(n)\r\n        return self.alg_field_from_poly(cyclotomic_poly(n, gen), alias=alias, root_index=root_index)\r\n\r\n```\r\n\r\nThen the above examples become\r\n\r\n```python\r\nK = QQ.alg_field_from_poly(f, \"alpha\")\r\n```\r\n\r\nand\r\n\r\n```python\r\nK = QQ.cyclotomic_field(19)\r\n```\r\n\r\n## Rationale\r\n\r\nFor a \"canonical\" default root, `-1` is the best index to pass to `CRootOf`. In common cases like quadratic or cyclotomic fields, this will select the root you tend to think of: the positive square root, or the square root with positive imaginary part, or `exp(2*I*pi/n)` for the `n`th cyclotomic field.\r\n",
        "issue_id": 22954,
        "pr_number": 22973,
        "pr_title": "Add convenience methods for constructing `AlgebraicField`",
        "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\" (see\r\nhttps://tinyurl.com/auto-closing for more information). Also, please\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n\r\nFixes #22954 \r\n\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nAdds a couple of convenience methods for constructing `AlgebraicField`.\r\n\r\nServes users who don't care about the complex embedding, by choosing an embedding for them.\r\n\r\nIn particular, makes constructing a cyclotomic field much easier.\r\n\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 between the BEGIN and END\r\nstatements. The basic format is a bulleted list with the name of the subpackage\r\nand the release note for this PR. For example:\r\n\r\n* solvers\r\n  * Added a new solver for logarithmic equations.\r\n\r\n* functions\r\n  * Fixed a bug with log of integers.\r\n\r\nor if no release note(s) should be included use:\r\n\r\nNO ENTRY\r\n\r\nSee https://github.com/sympy/sympy/wiki/Writing-Release-Notes for more\r\ninformation on how to write release notes. The bot will check your release\r\nnotes automatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* polys\r\n  * Add convenience constructors for `AlgebraicField`\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2022-02-01T23:03:24Z",
        "base_commit": "c1bfbd69158c4a97ce605a14ee5a00287469e01a"
      },
      "summary": "### Summary: This issue addresses the need for enhanced functionality in constructing algebraic fields within a mathematical software library, specifically focusing on the `AlgebraicField` class. The proposal aims to introduce new constructor methods to simplify the creation of algebraic number fields and cyclotomic fields, streamlining the current process by reducing complexity and eliminating unnecessary steps.\n\n1. **Problem description in general terms**: The current process of constructing algebraic fields in the software is cumbersome and requires users to engage in complex and unintuitive steps. The existing methods are not user-friendly and demand unnecessary knowledge of internal components, impacting the ease of use for common operations involving number fields and cyclotomic fields.\n\n2. **Key symptoms and behaviors observed**: Users are required to import specific modules like `CRootOf` and `cyclotomic_poly` and manually specify indices for roots, which are not always relevant for the tasks at hand. The process is lengthy and not conducive to user-friendly code, creating barriers for users who need to construct these fields for mathematical computations.\n\n3. **Affected components or systems**: The components affected include the construction of algebraic fields within the `AlgebraicField` class in the `sympy/polys` module, specifically affecting methods related to number fields and cyclotomic fields.\n\n4. **Potential impact or severity**: The impact is primarily on user experience and code maintainability. By simplifying the process, the proposed changes could significantly enhance productivity and reduce the learning curve for users. The severity is moderate as it affects usability rather than critical functionality.\n\n5. **Relevant technical details abstracted for broader understanding**: The proposal suggests adding two new methods: `alg_field_from_poly` and `cyclotomic_field`, which would encapsulate the complex steps currently necessary and provide a more intuitive interface for users. These methods aim to abstract away the internal complexities of root selection and imports, thereby simplifying field construction. The default root selection logic is also improved to align with common mathematical conventions.\n\nChanges Summary:\n- In `sympy/polys/domains/domain.py`, modifications were made to the `Domain.algebraic_field` at line 3.\n- Updates in `sympy/polys/numberfields/basis.py` affected the `round_two` function.\n- Changes in `sympy/polys/numberfields/primes.py` impacted the `prime_valuation` function.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: polys/numberfields: Convenience constructors for `AlgebraicField`\n\nBody:\nI'd like to propose a pair of new constructor methods, to support a couple of common use cases.\r\n\r\n\r\n## Use Case 1\r\n\r\n* You want a number field `Q(a)`,\r\n* AND you have the minimal polynomial `f(x)` for `a`,\r\n* AND you don't care _which_ root of `f` `a` is. (E.g. it's a Galois field, so it doesn't matter.),\r\n* AND, OPTIONALLY you want an `alias` for `a` so that field elements print nicely.\r\n\r\n\r\n## Use Case 2\r\n\r\n* You want the `n`th cyclotomic field.\r\n* You probably want the primitive element to be aliased either `\"zeta\"` or `f\"zeta{n}\"`.\r\n\r\n\r\n\r\n## The Current Situation\r\n\r\nFor Use Case 1, you have to do this:\r\n```python\r\nalpha = AlgebraicNumber(CRootOf(f, -1), alias=\"alpha\")\r\nK = QQ.algebraic_field(alpha)\r\n\r\n```\r\nwhich has several problems:\r\n\r\n* It's too long.\r\n* You shouldn't have to import `CRootOf`.\r\n* You shouldn't have to choose an index for `CRootOf`.\r\n\r\n\r\nUse Case 2 is similar, and you also have to import `cyclotomic_poly`:\r\n\r\n```python\r\nzeta = AlgebraicNumber(CRootOf(cyclotomic_poly(19), -1), alias=\"zeta\")\r\nK = QQ.algebraic_field(zeta)\r\n```\r\n\r\n\r\n\r\n## Proposal\r\n\r\nAlongside the `QQ.algebraic_field()` method (which takes one arg, being an `Expr`) I would propose two additional methods:\r\n\r\n```python\r\n    def alg_field_from_poly(self, poly, alias=None, root_index=-1):\r\n        alpha = AlgebraicNumber(CRootOf(poly, root_index), alias=alias)\r\n        return self.algebraic_field(alpha)\r\n\r\n    def cyclotomic_field(self, n, alias=\"zeta\", ss=False, gen=None, root_index=-1):\r\n        if ss:\r\n            alias += str(n)\r\n        return self.alg_field_from_poly(cyclotomic_poly(n, gen), alias=alias, root_index=root_index)\r\n\r\n```\r\n\r\nThen the above examples become\r\n\r\n```python\r\nK = QQ.alg_field_from_poly(f, \"alpha\")\r\n```\r\n\r\nand\r\n\r\n```python\r\nK = QQ.cyclotomic_field(19)\r\n```\r\n\r\n## Rationale\r\n\r\nFor a \"canonical\" default root, `-1` is the best index to pass to `CRootOf`. In common cases like quadratic or cyclotomic fields, this will select the root you tend to think of: the positive square root, or the square root with positive imaginary part, or `exp(2*I*pi/n)` for the `n`th cyclotomic field.\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/polys/domains/domain.py\n  line: line 3\n  function: Domain.algebraic_field\n\nsympy/polys/numberfields/basis.py\n  function: round_two\n\nsympy/polys/numberfields/primes.py\n  function: prime_valuation\n"
    },
    {
      "similar_issue": {
        "issue_title": "fps should print as a formal power series",
        "issue_body": "When I first used `fps`, I didn't realize it really was a formal power series as it claims to be, because it prints like a normal series (same as `series`)\n\n```\nIn [21]: fps(sin(x))\nOut[21]:\n     3     5\n    x     x     ⎛ 6⎞\nx - ── + ─── + O⎝x ⎠\n    6    120\n```\n\nBut if you look at the string form, you see\n\n```\nIn [22]: print(fps(sin(x)))\nFormalPowerSeries(sin(x), x, 0, 1, (SeqFormula(Piecewise(((-1/4)**(_k/2 - 1/2)/(RisingFactorial(3/2, _k/2 - 1/2)*factorial(_k/2 - 1/2)), Eq(Mod(_k, 2), 1)), (0, True)), (_k, 2, oo)), SeqFormula(x**_k, (_k, 0, oo)), x))\n```\n\nThat is, it really does represent it as the formula `Sum((-1)**n/factorial(2*n + 1)*x**n, (n, 0, oo))` (albiet, not simplified). It out to print it like this, so you can see that that's what it's working with.\n\nSide question: if you enter something it can't compute, it just returns the function\n\n```\nIn [25]: fps(tan(x))\nOut[25]: tan(x)\n```\n\nIs that intentional? It seems like it ought to raise an exception in that case. \n\n@leosartaj \n",
        "issue_id": 11102,
        "pr_number": 11384,
        "pr_title": "Update formal power series printing",
        "pr_body": "fixes #11102 \nping @asmeurer \n",
        "issue_closed_at": "2016-07-14T22:47:58Z",
        "base_commit": "496e776108957d8c049cbef49522cef4c1955e2f"
      },
      "summary": "### Summary:\nThis issue pertains to the `fps` function within the software, which is designed to represent formal power series. The primary concern is that while `fps` claims to be a formal power series, its output is indistinguishable from a normal series, particularly when printed. This has led to confusion among users as the printed output does not clearly convey the underlying formal power series representation that the function actually computes. The issue extends to how the function handles cases it cannot compute, where it returns the input function unchanged instead of raising an exception. This behavior may mislead users into thinking the computation was successful when it was not.\n\n1. **Problem description in general terms**: \n   The `fps` function does not clearly indicate its nature as a formal power series in its printed output, causing potential confusion. Additionally, the function's handling of uncomputable inputs—returning the input as is—may not adequately inform users of an issue.\n\n2. **Key symptoms and behaviors observed**: \n   - `fps` outputs resemble those of a normal series, lacking distinct formatting that highlights its formal power series nature.\n   - When unable to compute a series, `fps` returns the input function instead of signaling an error, which could lead to misinterpretation.\n\n3. **Affected components or systems**: \n   - The printing modules of the software, specifically within `sympy/printing/latex.py` and `sympy/printing/pretty/pretty.py`, as they handle the display of series.\n\n4. **Potential impact or severity**: \n   The impact is primarily on user experience and understanding, potentially leading to misinterpretation of results. While not critical in terms of system functionality, it affects the clarity and reliability of the tool for users relying on accurate representations of mathematical series.\n\n5. **Any relevant technical details abstracted for broader understanding**: \n   The issue highlights the need for clear communication of mathematical representations in computational software. It emphasizes the importance of distinct formatting that accurately reflects the nature of the computation, alongside appropriate error handling to inform users when computations cannot be performed.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: fps should print as a formal power series\n\nBody:\nWhen I first used `fps`, I didn't realize it really was a formal power series as it claims to be, because it prints like a normal series (same as `series`)\n\n```\nIn [21]: fps(sin(x))\nOut[21]:\n     3     5\n    x     x     ⎛ 6⎞\nx - ── + ─── + O⎝x ⎠\n    6    120\n```\n\nBut if you look at the string form, you see\n\n```\nIn [22]: print(fps(sin(x)))\nFormalPowerSeries(sin(x), x, 0, 1, (SeqFormula(Piecewise(((-1/4)**(_k/2 - 1/2)/(RisingFactorial(3/2, _k/2 - 1/2)*factorial(_k/2 - 1/2)), Eq(Mod(_k, 2), 1)), (0, True)), (_k, 2, oo)), SeqFormula(x**_k, (_k, 0, oo)), x))\n```\n\nThat is, it really does represent it as the formula `Sum((-1)**n/factorial(2*n + 1)*x**n, (n, 0, oo))` (albiet, not simplified). It out to print it like this, so you can see that that's what it's working with.\n\nSide question: if you enter something it can't compute, it just returns the function\n\n```\nIn [25]: fps(tan(x))\nOut[25]: tan(x)\n```\n\nIs that intentional? It seems like it ought to raise an exception in that case. \n\n@leosartaj \n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/printing/latex.py\n  function: LatexPrinter._print_FourierSeries\n\nsympy/printing/pretty/pretty.py\n  function: PrettyPrinter._print_FourierSeries\n"
    }
  ]
}