{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "#Snippets and Programs from Chapter 4: Algebra and Symbolic Math with SymPy" ] }, { "cell_type": "code", "execution_count": 1, "metadata": { "collapsed": true }, "outputs": [], "source": [ "%matplotlib inline" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P96/97: Basic factorization and expansion\n", "from sympy import Symbol, factor, expand\n", "x = Symbol('x')\n", "y = Symbol('y')\n", "expr = x**2 - y**2\n", "f = factor(expr)\n", "print(f)\n", "# Expand\n", "print(expand(f))" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P97: Factorizing and expanding a complicated identity\n", "from sympy import Symbol, factor, expand\n", "x = Symbol('x')\n", "y = Symbol('y')\n", "expr = x**3 + 3*x**2*y + 3*x*y**2 + y**3 \n", "\n", "print('Original expression: {0}'.format(expr))\n", "factors = factor(expr)\n", "print('Factors: {0}'.format(factors))\n", "\n", "\n", "expanded = expand(factors)\n", "print('Expansion: {0}'.format(expanded))\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P97: Pretty printing\n", "from sympy import Symbol, pprint, init_printing\n", "x = Symbol('x')\n", "expr = x*x + 2*x*y + y*y\n", "pprint(expr)\n", "# Reverse order lexicographical\n", "init_printing(order='rev-lex')\n", "expr = 1 + 2*x + 2*x**2\n", "pprint(expr)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "*Since we have initialized pretty printing above, it will be active for all the output below this.*" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P99: Print a series\n", "\n", "'''\n", "Print the series:\n", "x + x**2 + x**3 + ... + x**n\n", " ____ _____ ____ \n", " 2 3 n\n", "'''\n", "from sympy import Symbol, pprint, init_printing\n", "def print_series(n):\n", " # initialize printing system with\n", " # reverse order\n", " init_printing(order='rev-lex')\n", " x = Symbol('x')\n", " series = x\n", " for i in range(2, n+1):\n", " series = series + (x**i)/i\n", " pprint(series)\n", "\n", "if __name__ == '__main__':\n", " n = input('Enter the number of terms you want in the series: ')\n", " print_series(int(n))" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P100: Substituting in values\n", "from sympy import Symbol\n", "x = Symbol('x')\n", "y = Symbol('y')\n", "expr = x*x + x*y + x*y + y*y\n", "res = expr.subs({x:1, y:2})\n", "res" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P102: Print a series and also calculate its value at a certain point\n", "\n", "'''\n", "Print the series:\n", "\n", "x + x**2 + x**3 + ... + x**n\n", " ____ _____ ____ \n", " 2 3 n\n", " \n", "and calculate its value at a certain value of x.\n", "'''\n", "\n", "from sympy import Symbol, pprint, init_printing\n", "def print_series(n, x_value):\n", " # initialize printing system with\n", " # reverse order\n", " init_printing(order='rev-lex')\n", " x = Symbol('x')\n", " series = x\n", " for i in range(2, n+1):\n", " series = series + (x**i)/i\n", " pprint(series)\n", " # evaluate the series at x_value\n", " series_value = series.subs({x:x_value})\n", " print('Value of the series at {0}: {1}'.format(x_value, series_value))\n", "\n", "if __name__ == '__main__':\n", " n = input('Enter the number of terms you want in the series: ')\n", " x_value = input('Enter the value of x at which you want to evaluate the series: ') \n", " print_series(int(n), float(x_value))" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "# P104: Expression multiplier\n", "\n", "'''\n", "Product of two expressions\n", "'''\n", "\n", "from sympy import expand, sympify\n", "from sympy.core.sympify import SympifyError\n", "def product(expr1, expr2):\n", " prod = expand(expr1*expr2)\n", " print(prod)\n", "\n", "if __name__=='__main__':\n", " expr1 = input('Enter the first expression: ')\n", " expr2 = input('Enter the second expression: ')\n", " try:\n", " expr1 = sympify(expr1)\n", " expr2 = sympify(expr2)\n", " except SympifyError:\n", " print('Invalid input')\n", " else:\n", " product(expr1, expr2)\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P105: Solving a linear equation\n", ">>> from sympy import Symbol, solve \n", ">>> x = Symbol('x')\n", ">>> expr = x - 5 - 7\n", ">>> solve(expr)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P106: Solving a quadratic equation\n", ">>> from sympy import solve \n", ">>> x = Symbol('x')\n", ">>> expr = x**2 + 5*x + 4 \n", ">>> solve(expr, dict=True)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P106: Quadratic equation with imaginary roots\n", ">>> from sympy import Symbol\n", ">>> x=Symbol('x')\n", ">>> expr = x**2 + x + 1\n", ">>> solve(expr, dict=True)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P106/107: Solving for one variable in terms of others\n", ">>> from sympy import Symbol, solve\n", ">>> x = Symbol('x')\n", ">>> a = Symbol('a') \n", ">>> b = Symbol('b')\n", ">>> c = Symbol('c')\n", ">>> expr = a*x*x + b*x + c\n", ">>> solve(expr, x, dict=True)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P107: Express s in terms of u, a, t\n", ">>> from sympy import Symbol, solve, pprint \n", ">>> s = Symbol('s')\n", ">>> u = Symbol('u')\n", ">>> t = Symbol('t')\n", ">>> a = Symbol('a')\n", ">>> expr = u*t + (1/2)*a*t*t - s\n", ">>> t_expr = solve(expr,t, dict=True) \n", ">>> t_expr" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "collapsed": false }, "outputs": [], "source": [ "#P108: Solve a system of Linear equations\n", ">>> from sympy import Symbol\n", ">>> x = Symbol('x')\n", ">>> y = Symbol('y')\n", ">>> expr1 = 2*x + 3*y - 6 \n", ">>> expr2 = 3*x + 2*y - 12\n", ">>> solve((expr1, expr2), dict=True)" ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "collapsed": false }, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/plain": [ "" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P109: Simple plot with SymPy\n", ">>> from sympy.plotting import plot\n", ">>> from sympy import Symbol\n", ">>> x = Symbol('x')\n", ">>> plot(2*x+3)" ] }, { "cell_type": "code", "execution_count": 3, "metadata": { "collapsed": false }, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/plain": [ "" ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P110: Plot in SymPy with range of x as well as other attributes specified\n", ">>> from sympy import plot, Symbol\n", ">>> x = Symbol('x')\n", ">>> plot(2*x + 3, (x, -5, 5), title='A Line', xlabel='x', ylabel='2x+3')" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "collapsed": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Enter your expression in terms of x and y: 2*x + 3*y - 6\n" ] }, { "data": { "image/png": "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\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "#P112: Plot the graph of an input expression\n", "'''\n", "Plot the graph of an input expression\n", "'''\n", "from sympy import Symbol, sympify, solve\n", "from sympy.plotting import plot\n", "\n", "def plot_expression(expr):\n", " y = Symbol('y')\n", " solutions = solve(expr, y)\n", " expr_y = solutions[0]\n", " plot(expr_y)\n", "\n", "if __name__=='__main__':\n", " expr = input('Enter your expression in terms of x and y: ')\n", " try:\n", " expr = sympify(expr)\n", " except SympifyError:\n", " print('Invalid input')\n", " else:\n", " plot_expression(expr)" ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "collapsed": false }, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/plain": [ "" ] }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P113: Plotting multiple functions\n", ">>> from sympy.plotting import plot \n", ">>> from sympy import Symbol\n", ">>> x = Symbol('x')\n", ">>> plot(2*x+3, 3*x+1)" ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "collapsed": false }, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "#P114: Plot of the two lines drawn in a different color\n", ">>> from sympy.plotting import plot \n", ">>> from sympy import Symbol\n", ">>> x = Symbol('x')\n", ">>> p = plot(2*x+3, 3*x+1, legend=True, show=False) \n", ">>> p[0].line_color = 'b'\n", ">>> p[1].line_color = 'r'\n", ">>> p.show()" ] }, { "cell_type": "code", "execution_count": 9, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "3.51206400000000" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P116: Example of summing a series\n", ">>> from sympy import Symbol, summation, pprint \n", ">>> x = Symbol('x')\n", ">>> n = Symbol('n')\n", ">>> s = summation(x**n/n, (n, 1, 5)) \n", ">>> s.subs({x:1.2})" ] }, { "cell_type": "code", "execution_count": 10, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "[(-oo, -2), (2, oo)]" ] }, "execution_count": 10, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P117: Example of solving a polynomial inequality\n", ">>> from sympy import Poly, Symbol, solve_poly_inequality\n", ">>> x = Symbol('x')\n", ">>> ineq_obj = -x**2 + 4 < 0 \n", ">>> lhs = ineq_obj.lhs\n", ">>> p = Poly(lhs, x)\n", ">>> rel = ineq_obj.rel_op\n", ">>> solve_poly_inequality(p, rel)" ] }, { "cell_type": "code", "execution_count": 11, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "(-oo, -2) U (1, oo)" ] }, "execution_count": 11, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P118: Example of solving a rational inequality\n", ">>> from sympy import Symbol, Poly, solve_rational_inequalities\n", ">>> x = Symbol('x')\n", ">>> ineq_obj = ((x-1)/(x+2)) > 0\n", ">>> lhs = ineq_obj.lhs\n", ">>> numer, denom = lhs.as_numer_denom()\n", ">>> p1 = Poly(numer)\n", ">>> p2 = Poly(denom)\n", ">>> rel = ineq_obj.rel_op\n", ">>> solve_rational_inequalities([[((p1, p2), rel)]])" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/plain": [ "(0.643501108793284, 2.49809154479651)" ] }, "execution_count": 12, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#P118: Solve a non-polynomial inequality\n", ">>> from sympy import Symbol, solve, solve_univariate_inequality, sin \n", ">>> x = Symbol('x')\n", ">>> ineq_obj = sin(x) - 0.6 > 0\n", ">>> solve_univariate_inequality(ineq_obj, x, relational=False)" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.4.3" } }, "nbformat": 4, "nbformat_minor": 0 }