{
  "Selected_candidate": {
    "pr_number": 9656,
    "pr_title": "Correctly handle Eq in experimental_lambdify",
    "pr_body": "experimental_lambdify does a str on the expression, but it can't find Eq\nbecause the str of Eq.func is Equation.\n\nFixes #9652.\n",
    "issue_id": 9652,
    "issue_title": "Fail in plot_implicit test on OSX 10.8.5",
    "issue_body": "Sat Jul 11 13:55:27 EDT 2015`\n└─╼ ./setup.py test\n/Users/enzyme/anaconda/envs/sympy/lib/python2.7/site-packages/setuptools-18.0.1-py2.7.egg/setuptools/dist.py:285: UserWarning: Normalizing '0.7.7.dev' to '0.7.7.dev0'\nrunning test\n============================= test process starts ==============================\nexecutable:         /Users/enzyme/anaconda/envs/sympy/bin/python  (2.7.10-final-0) [CPython]\narchitecture:       64-bit\ncache:              yes\nground types:       python \nrandom seed:        1582984\nhash randomization: on (PYTHONHASHSEED=2446129600)`\n\n`sympy/plotting/tests/test_plot.py[3] ./Users/enzyme/anaconda/envs/sympy/lib/python2.7/site-packages/matplotlib/pyplot.py:424: RuntimeWarning: More than 20 figures have been opened. Figures created through the pyplot interface (`matplotlib.pyplot.figure`) are retained until explicitly closed and may consume too much memory. (To control this warning, see the rcParam `figure.max_open_warning`).\n  max_open_warning, RuntimeWarning)\nsympy/plotting/experimental_lambdify.py:165: UserWarning: The evaluation of the expression is problematic. We are trying a failback method that may still work. Please report this as a bug.\n  warnings.warn('The evaluation of the expression is'\n..                                    [OK]\nsympy/plotting/tests/test_plot_implicit.py[2] .E                          [FAIL]`\n\n`````` ________________________________________________________________________________\n__________ sympy/plotting/tests/test_plot_implicit.py:test_matplotlib __________\n  File \"/users/enzyme/mystuff/mypython/mysympy/sympy-sprint/sympy/sympy/plotting/tests/test_plot_implicit.py\", line 70, in test_matplotlib\n    plot_and_save('test')\n  File \"/users/enzyme/mystuff/mypython/mysympy/sympy-sprint/sympy/sympy/plotting/tests/test_plot_implicit.py\", line 22, in plot_and_save\n    plot_implicit(Eq(y, cos(x)), (x, -5, 5), (y, -2, 2)).save(tmp_file(name))\n  File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n    p.show()\n  File \"sympy/plotting/plot.py\", line 185, in show\n    self._backend.show()\n  File \"sympy/plotting/plot.py\", line 1018, in show\n    self.process_series()\n  File \"sympy/plotting/plot.py\", line 921, in process_series\n    points = s.get_raster()\n  File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n    temp = func(xinterval, yinterval)\n  File \"<string>\", line 1, in <lambda>\nNameError: global name 'Eq' is not defined\n```________________________________________________________________________________\n__________________ sympy.plotting.plot_implicit.plot_implicit __________________\nFile \"sympy/plotting/plot_implicit.py\", line 257, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p1 = plot_implicit(Eq(x**2 + y**2, 5))\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[2]>\", line 1, in <module>\n        p1 = plot_implicit(Eq(x**2 + y**2, 5))\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 261, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p2 = plot_implicit(Eq(x**2 + y**2, 3),\n            (x, -3, 3), (y, -3, 3))\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[3]>\", line 2, in <module>\n        (x, -3, 3), (y, -3, 3))\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 266, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p3 = plot_implicit(Eq(x**2 + y**2, 5),\n            (x, -4, 4), (y, -4, 4), depth = 2)\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[4]>\", line 2, in <module>\n        (x, -4, 4), (y, -4, 4), depth = 2)\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 271, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p4 = plot_implicit(Eq(x**2 + y**2, 5),\n            (x, -5, 5), (y, -2, 2), adaptive=False)\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[5]>\", line 2, in <module>\n        (x, -5, 5), (y, -2, 2), adaptive=False)\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 276, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p5 = plot_implicit(Eq(x**2 + y**2, 5),\n            (x, -5, 5), (y, -2, 2),\n            adaptive=False, points=400)\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[6]>\", line 3, in <module>\n        adaptive=False, points=400)\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 291, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p8 = plot_implicit(y - 1, y_var=y)\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[9]>\", line 1, in <module>\n        p8 = plot_implicit(y - 1, y_var=y)\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n**********************************************************************\nFile \"sympy/plotting/plot_implicit.py\", line 292, in sympy.plotting.plot_implicit.plot_implicit\nFailed example:\n    p9 = plot_implicit(x - 1, x_var=x)\nException raised:\n    Traceback (most recent call last):\n      File \"/Users/enzyme/anaconda/envs/sympy/lib/python2.7/doctest.py\", line 1315, in __run\n        compileflags, 1) in test.globs\n      File \"<doctest sympy.plotting.plot_implicit.plot_implicit[10]>\", line 1, in <module>\n        p9 = plot_implicit(x - 1, x_var=x)\n      File \"sympy/plotting/plot_implicit.py\", line 374, in plot_implicit\n        p.show()\n      File \"sympy/plotting/plot.py\", line 185, in show\n        self._backend.show()\n      File \"sympy/plotting/plot.py\", line 1018, in show\n        self.process_series()\n      File \"sympy/plotting/plot.py\", line 921, in process_series\n        points = s.get_raster()\n      File \"sympy/plotting/plot_implicit.py\", line 80, in get_raster\n        temp = func(xinterval, yinterval)\n      File \"<string>\", line 1, in <lambda>\n    NameError: global name 'Eq' is not defined\n\n===== tests finished: 2969 passed, 1 failed, 4 skipped, in 240.72 seconds ======\n``````\n",
    "issue_closed_at": "2015-07-12T22:51:57Z",
    "base_commit": "81603ffb24fb022fe941cda2fa59cd2fe849cd53",
    "changes": [
      {
        "file": "sympy/plotting/experimental_lambdify.py",
        "type": "function",
        "name": "__init__",
        "class_name": "Lambdifier",
        "code": "def __init__(self, args, expr, print_lambda=False, use_evalf=False,\n                 float_wrap_evalf=False, complex_wrap_evalf=False,\n                 use_np=False, use_python_math=False, use_python_cmath=False,\n                 use_interval=False):\n\n        self.print_lambda = print_lambda\n        self.use_evalf = use_evalf\n        self.float_wrap_evalf = float_wrap_evalf\n        self.complex_wrap_evalf = complex_wrap_evalf\n        self.use_np = use_np\n        self.use_python_math = use_python_math\n        self.use_python_cmath = use_python_cmath\n        self.use_interval = use_interval\n\n        # Constructing the argument string\n        # - check\n        if not all([isinstance(a, Symbol) for a in args]):\n            raise ValueError('The arguments must be Symbols.')\n        # - use numbered symbols\n        syms = numbered_symbols(exclude=expr.free_symbols)\n        newargs = [next(syms) for i in args]\n        expr = expr.xreplace(dict(zip(args, newargs)))\n        argstr = ', '.join([str(a) for a in newargs])\n        del syms, newargs, args\n\n        # Constructing the translation dictionaries and making the translation\n        self.dict_str = self.get_dict_str()\n        self.dict_fun = self.get_dict_fun()\n        exprstr = str(expr)\n        newexpr = self.tree2str_translate(self.str2tree(exprstr))\n\n        # Constructing the namespaces\n        namespace = {}\n        namespace.update(self.sympy_atoms_namespace(expr))\n        namespace.update(self.sympy_expression_namespace(expr))\n        # XXX Workaround\n        # Ugly workaround because Pow(a,Half) prints as sqrt(a)\n        # and sympy_expression_namespace can not catch it.\n        from sympy import sqrt\n        namespace.update({'sqrt': sqrt})\n        # End workaround.\n        if use_python_math:\n            namespace.update({'math': __import__('math')})\n        if use_python_cmath:\n            namespace.update({'cmath': __import__('cmath')})\n        if use_np:\n            try:\n                namespace.update({'np': __import__('numpy')})\n            except ImportError:\n                raise ImportError(\n                    'experimental_lambdify failed to import numpy.')\n        if use_interval:\n            namespace.update({'imath': __import__(\n                'sympy.plotting.intervalmath', fromlist=['intervalmath'])})\n            namespace.update({'math': __import__('math')})\n\n        # Construct the lambda\n        if self.print_lambda:\n            print(newexpr)\n        eval_str = 'lambda %s : ( %s )' % (argstr, newexpr)\n        exec_(\"from __future__ import division; MYNEWLAMBDA = %s\" % eval_str, namespace)\n        self.lambda_func = namespace['MYNEWLAMBDA']"
      }
    ]
  },
  "Justification": "Candidate D is particularly relevant because the issue revolves around handling equations (represented by Eq) and is related to the handling of implicit plots in the `plot_implicit` function, much like the current bug involving the `idiff` function which also operates on equations. The structural similarity arises from the fact that both bug reports involve mishandling of variable types (equations versus functions) and raise similar types of errors including `NameError`. The patch implemented in D focuses on ensuring that expressions containing `Eq` are handled correctly, which could provide valuable insights for fixing incorrect behaviors in `idiff`.",
  "instance_id": "sympy__sympy-15678",
  "repo": "sympy/sympy",
  "created_at": "2018-12-20T18:11:56Z",
  "problem_statement": "Some issues with idiff\nidiff doesn't support Eq, and it also doesn't support f(x) instead of y. Both should be easy to correct.\r\n\r\n```\r\n>>> idiff(Eq(y*exp(y), x*exp(x)), y, x)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"./sympy/geometry/util.py\", line 582, in idiff\r\n    yp = solve(eq.diff(x), dydx)[0].subs(derivs)\r\nIndexError: list index out of range\r\n>>> idiff(f(x)*exp(f(x)) - x*exp(x), f(x), x)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"./sympy/geometry/util.py\", line 574, in idiff\r\n    raise ValueError(\"expecting x-dependent symbol(s) but got: %s\" % y)\r\nValueError: expecting x-dependent symbol(s) but got: f(x)\r\n>>> idiff(y*exp(y)- x*exp(x), y, x)\r\n(x + 1)*exp(x - y)/(y + 1)\r\n```\n",
  "patch": "diff --git a/sympy/geometry/util.py b/sympy/geometry/util.py\n--- a/sympy/geometry/util.py\n+++ b/sympy/geometry/util.py\n@@ -570,12 +570,19 @@ def idiff(eq, y, x, n=1):\n         y = y[0]\n     elif isinstance(y, Symbol):\n         dep = {y}\n+    elif isinstance(y, Function):\n+        pass\n     else:\n-        raise ValueError(\"expecting x-dependent symbol(s) but got: %s\" % y)\n+        raise ValueError(\"expecting x-dependent symbol(s) or function(s) but got: %s\" % y)\n \n     f = dict([(s, Function(\n         s.name)(x)) for s in eq.free_symbols if s != x and s in dep])\n-    dydx = Function(y.name)(x).diff(x)\n+\n+    if isinstance(y, Symbol):\n+        dydx = Function(y.name)(x).diff(x)\n+    else:\n+        dydx = y.diff(x)\n+\n     eq = eq.subs(f)\n     derivs = {}\n     for i in range(n):\n"
}