{
  "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",
  "similar_bug_items": [
    {
      "pr_number": 8627,
      "pr_title": "Bug Fix #8626",
      "pr_body": "Let me know if a test case is needed\n",
      "issue_id": 8626,
      "issue_title": "bug in physics/mechanics/lagrange.py",
      "issue_body": "When providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n",
      "issue_closed_at": "2015-01-06T16:57:16Z",
      "base_commit": "65f7c8c2c9c1927eaa8520c4ce06864f93a20ad1",
      "changes": [
        {
          "file": "sympy/physics/mechanics/lagrange.py",
          "type": "function",
          "name": "form_lagranges_equations",
          "class_name": "LagrangesMethod",
          "code": "def form_lagranges_equations(self):\n        \"\"\"Method to form Lagrange's equations of motion.\n\n        Returns a vector of equations of motion using Lagrange's equations of\n        the second kind.\n        \"\"\"\n\n        qds = self._qdots\n        qdd_zero = dict((i, 0) for i in self._qdoubledots)\n        n = len(self.q)\n\n        # Internally we represent the EOM as four terms:\n        # EOM = term1 - term2 - term3 - term4 = 0\n\n        # First term\n        self._term1 = self._L.jacobian(qds)\n        self._term1 = self._term1.diff(dynamicsymbols._t).T\n\n        # Second term\n        self._term2 = self._L.jacobian(self.q).T\n\n        # Third term\n        if self.coneqs:\n            coneqs = self.coneqs\n            m = len(coneqs)\n            # Creating the multipliers\n            self.lam_vec = Matrix(dynamicsymbols('lam1:' + str(m + 1)))\n            self.lam_coeffs = -coneqs.jacobian(qds)\n            self._term3 = self.lam_coeffs.T * self.lam_vec\n            # Extracting the coeffecients of the qdds from the diff coneqs\n            diffconeqs = coneqs.diff(dynamicsymbols._t)\n            self._m_cd = diffconeqs.jacobian(self._qdoubledots)\n            # The remaining terms i.e. the 'forcing' terms in diff coneqs\n            self._f_cd = -diffconeqs.subs(qdd_zero)\n        else:\n            self._term3 = zeros(n, 1)\n\n        # Fourth term\n        if self.forcelist:\n            N = self.inertial\n            self._term4 = zeros(n, 1)\n            flist = zip(*_f_list_parser(self.forcelist, N))\n            for i, qd in enumerate(qds):\n                for obj, force in self.forcelist:\n                    self._term4[i] = sum(v.diff(qd, N) & f for (v, f) in flist)\n        else:\n            self._term4 = zeros(n, 1)\n\n        # Form the dynamic mass and forcing matrices\n        without_lam = self._term1 - self._term2 - self._term4\n        self._m_d = without_lam.jacobian(self._qdoubledots)\n        self._f_d = -without_lam.subs(qdd_zero)\n\n        # Form the EOM\n        self.eom = without_lam - self._term3\n        return self.eom"
        }
      ]
    },
    {
      "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": 12882,
      "pr_title": "Checker functions for orthogonality of coordinate system",
      "pr_body": "This PR introduce additional condition for transformation equation which must be fulfill. \r\nIn `vector` module we are dealing with orthogonal curvilinear coordinate system only, so we need to check if transformation equations are correctly defined.\r\n\r\nCloses #12852",
      "issue_id": 12852,
      "issue_title": "Vector module: make sure that the base vectors remain orthogonal",
      "issue_body": "Given a generic transformation equation, make sure that the base vectors remain orthogonal, if not, raise an exception.",
      "issue_closed_at": "2017-07-05T15:10:49Z",
      "base_commit": "c87c0fbf1223c28db8590f2591f64db75d5bdd66",
      "changes": [
        {
          "file": "sympy/vector/coordsysrect.py",
          "type": "line",
          "name": "line 4",
          "code": "from sympy.core.cache import cacheit\nfrom sympy.core import S\nfrom sympy.vector.scalar import BaseScalar\nfrom sympy import eye, trigsimp, ImmutableMatrix as Matrix, Symbol, sin, cos, sqrt, diff, Tuple\nimport sympy.vector\nfrom sympy import simplify\nfrom sympy.vector.orienters import (Orienter, AxisOrienter, BodyOrienter,"
        },
        {
          "file": "sympy/vector/coordsysrect.py",
          "type": "function",
          "name": "_connect_to_standard_cartesian",
          "class_name": "CoordSys3D",
          "code": "def _connect_to_standard_cartesian(self, curv_coord_type):\n        \"\"\"\n        Change the type of orthogonal curvilinear system. It could be done\n        by tuple of transformation equations or by choosing one of pre-defined\n        coordinate system.\n\n        Parameters\n        ==========\n\n        :param curv_coord_type: str, tuple\n\n        \"\"\"\n        if isinstance(curv_coord_type, string_types):\n            self._set_transformation_equations_mapping(curv_coord_type)\n            self._set_lame_coefficient_mapping(curv_coord_type)\n\n        elif isinstance(curv_coord_type, (tuple, list, Tuple)) and len(curv_coord_type) == 3:\n            self._transformation_eqs = curv_coord_type\n            self._h1, self._h2, self._h3 = self._calculate_lame_coefficients(curv_coord_type)\n\n        elif isinstance(curv_coord_type, (tuple, list, Tuple)) and len(curv_coord_type) == 2:\n            self._transformation_eqs = \\\n            tuple([eq.subs({curv_coord_type[0][0]: self.x,\n                            curv_coord_type[0][1]: self.y,\n                            curv_coord_type[0][2]: self.z}) for eq in curv_coord_type[1]])\n            self._h1, self._h2, self._h3 = self._calculate_lame_coefficients(self._transformation_equations())\n\n        else:\n            raise ValueError(\"Wrong set of parameter.\")"
        }
      ]
    },
    {
      "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\u2514\u2500\u257c ./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']"
        }
      ]
    },
    {
      "pr_number": 7928,
      "pr_title": "give MaxMinBase an evalf routine",
      "pr_body": "Although Or, And, etc... will not have a number as an\nargument, Min and Max can. When the operations version\nof _eval_evalf is called a call to as_independent is\nmade. This creates an x (=1) that is assumed to be an\nargument of the object so Max(0,y).n() becomes Max(1, 0, y) -> Max(1, y).\nTo avoid this an evalf routine was added to handle MaxMinBase separately.\n\nfixes #7233\n",
      "issue_id": 7233,
      "issue_title": "N(Max(0.0, n + m)) returns Max(1.0, n + m)",
      "issue_body": "```\nThe following code does not return what is expected,\n\nn = sympy.Symbol('n')\nm = sympy.Symbol('m')\na = sympy.Max(0.0, n + m)\nprint a\nprint sympy.N(a)\n\noutputs:\n>> Max(0.0, m + n)\n>> Max(1.0, m + n)\n```\n\nOriginal issue for #7233: http://code.google.com/p/sympy/issues/detail?id=4134\nOriginal author: https://code.google.com/u/100679098312105897492/\n",
      "issue_closed_at": "2014-08-29T23:58:03Z",
      "base_commit": "d365f932a26c28c4c57b2b9f6dddee2ca94a5c66",
      "changes": [
        {
          "file": "sympy/functions/elementary/miscellaneous.py",
          "type": "function",
          "name": "_eval_derivative",
          "class_name": "MinMaxBase",
          "code": "def _eval_derivative(self, s):\n        # f(x).diff(s) -> x.diff(s) * f.fdiff(1)(s)\n        i = 0\n        l = []\n        for a in self.args:\n            i += 1\n            da = a.diff(s)\n            if da is S.Zero:\n                continue\n            try:\n                df = self.fdiff(i)\n            except ArgumentIndexError:\n                df = Function.fdiff(self, i)\n            l.append(df * da)\n        return Add(*l)"
        }
      ]
    }
  ]
}