diff options
Diffstat (limited to 'Higher_Engineering_Mathematics_by_B._S._Grewal/chapter13.ipynb')
-rw-r--r-- | Higher_Engineering_Mathematics_by_B._S._Grewal/chapter13.ipynb | 600 |
1 files changed, 600 insertions, 0 deletions
diff --git a/Higher_Engineering_Mathematics_by_B._S._Grewal/chapter13.ipynb b/Higher_Engineering_Mathematics_by_B._S._Grewal/chapter13.ipynb new file mode 100644 index 00000000..611dcffb --- /dev/null +++ b/Higher_Engineering_Mathematics_by_B._S._Grewal/chapter13.ipynb @@ -0,0 +1,600 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Chapter 13: Linear Differential Equations" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.1, page no. 398" + ] + }, + { + "cell_type": "code", + "execution_count": 26, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differential equation is given by: \n", + "y = c1*exp(-1.28077640640442*x) + c2*exp(0.780776406404415*x)\n" + ] + } + ], + "source": [ + "import sympy, numpy\n", + "\n", + "print \"Solution to the given linear differential equation is given by: \"\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**2+m-2\n", + "r = numpy.roots([2, 1, -2])\n", + "y = c1*sympy.exp(r[0]*x)+c2*sympy.exp(r[1]*x)\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.2, page no. 399" + ] + }, + { + "cell_type": "code", + "execution_count": 24, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "y = (c1 + c2*x)*exp(x*(-1.5 + 1.5*I))\n" + ] + } + ], + "source": [ + "import sympy, numpy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**2+6*m+9;\n", + "r = numpy.roots([2, 6, 9])\n", + "y =(c1+x*c2)*sympy.exp(r[0]*x)\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.3, page no. 401" + ] + }, + { + "cell_type": "code", + "execution_count": 40, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "y = c1*exp(0.105616806777468*x) + c2*exp(0.105616806777468*x) + c3*exp(-0.877900280221601*x)\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "c3 = sympy.Symbol('c3')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**3+m*2+4*m+4;\n", + "r = numpy.roots([3, 2, 4, 4])\n", + "y = c1*sympy.exp(r[0].real*x)+c2*sympy.exp(r[1].real*x)+c3*sympy.exp(r[2].real*x)\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.4, page no. 402" + ] + }, + { + "cell_type": "code", + "execution_count": 61, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "y = c1*exp(-0.707106781186547*x) + c2*exp(-0.707106781186547*x) + c3*exp(0.707106781186547*x) + c4*exp(0.707106781186547*x)\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "c3 = sympy.Symbol('c3')\n", + "c4 = sympy.Symbol('c4')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**4+4;\n", + "r = numpy.roots([4, 0, 0, 0, 4])\n", + "y = c1*sympy.exp(r[0].real*x)+c2*sympy.exp(r[1].real*x)+c3*sympy.exp(r[2].real*x)+c4*sympy.exp(r[3].real*x)\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.5, page no. 402" + ] + }, + { + "cell_type": "code", + "execution_count": 64, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "y = [ 9041.93285661 22.41271075]\n" + ] + } + ], + "source": [ + "import numpy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "m = numpy.poly([0])\n", + "f = m**2+5*m+6\n", + "y = numpy.exp(f)/numpy.polyval(f,1)\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.6, page no. 403" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution of the given linear equation is given by: \n", + "[ 0.25+0.96824584j 0.25-0.96824584j]\n", + "y = 1/f(D)∗[exp(-2x)+exp(x)-exp(-x)\n", + "using 1/f(D)exp(ax) = x/f1(D)∗exp(ax) if f(m)=0\n", + "y = x**2*exp(x)/6 + x*exp(-2*x)/9 + exp(-x)/4\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution of the given linear equation is given by: '\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f =(m+2)*(m-1)**2;\n", + "r = numpy.roots([2, -1, 2])\n", + "print r\n", + "print 'y = 1/f(D)∗[exp(-2x)+exp(x)-exp(-x)'\n", + "print 'using 1/f(D)exp(ax) = x/f1(D)∗exp(ax) if f(m)=0'\n", + "y1 = x*sympy.exp(-2*x)/9\n", + "y2 = sympy.exp(-x)/4\n", + "y3 = x**2*sympy.exp(x)/6\n", + "y = y1+y2+y3\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.7, page no. 404" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution of the given linear equation is given by: \n", + "Using the identity 1/f(D**2)∗sin(ax+b)[or cos(ax+b)]=1/f(-a**2)∗sin(ax+b)[or cos(ax+b)] this equation \n", + "can be redused to y = (4D+1)/65∗cos(2x-1)\n", + "y = -8*sin(2*x - 1)/65 + cos(2*x - 1)/65\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution of the given linear equation is given by: '\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**3+1;\n", + "print '''Using the identity 1/f(D**2)∗sin(ax+b)[or cos(ax+b)]=1/f(-a**2)∗sin(ax+b)[or cos(ax+b)] this equation \n", + "can be redused to''',\n", + "print 'y = (4D+1)/65∗cos(2x-1)'\n", + "y = (sympy.cos(2*x-1)+4*sympy.diff(sympy.cos(2*x-1),x))/65\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.8, page no. 405" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution of the given linear equation is given by: \n", + "Using 1/f(D)exp(ax) = x/f1(D)∗exp(ax) if f(m)=0\n", + "y = x∗1/(3D**2+4)∗sin2x\n", + "Using this identity 1/f(D**2)∗sin(ax+b)[or cos(ax+b)]= 1/f(-a**2)∗sin(ax+b)[or cos (ax+b)] this equation \n", + "can be redused to y = -x/8∗sin2x\n", + "y = -0.113662178353\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution of the given linear equation is given by: '\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**3+4*m\n", + "print 'Using 1/f(D)exp(ax) = x/f1(D)∗exp(ax) if f(m)=0'\n", + "print 'y = x∗1/(3D**2+4)∗sin2x'\n", + "print '''Using this identity 1/f(D**2)∗sin(ax+b)[or cos(ax+b)]= 1/f(-a**2)∗sin(ax+b)[or cos (ax+b)] this equation \n", + "can be redused to''',\n", + "print 'y = -x/8∗sin2x'\n", + "x=1\n", + "y = -x*numpy.sin(2*x)/8\n", + "print \"y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.9, page no. 406" + ] + }, + { + "cell_type": "code", + "execution_count": 8, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution of the given linear equation is given by: \n", + "y = 1/(D(D+1))[x**2+2x+4] can be written as (1−D+D**2)/D[x**2+2x+4] which is combination of\n", + "differentialtion and integration\n", + "y = x**3/3 + 4*x\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution of the given linear equation is given by: '\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "print '''y = 1/(D(D+1))[x**2+2x+4] can be written as (1−D+D**2)/D[x**2+2x+4] which is combination of\n", + "differentialtion and integration'''\n", + "g = x**2+2*x+4\n", + "f = g-sympy.diff(g,x)+sympy.diff(g,x,2)\n", + "y = sympy.integrate(f,x)\n", + "print 'y = ', y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.11, page no. 406" + ] + }, + { + "cell_type": "code", + "execution_count": 13, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "CF + PI\n", + "[-1.]\n", + "CF is given by: \n", + "(c1 + c2*x)*exp(-1.0*x)\n", + "−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−\n", + "PI = 8∗{1/(D−2)**2[exp(2x)]+{1/(D−2)**2[sin(2x)]+{1/(D−2)**2[x**2]}\n", + "Using identitties it reduces to: 4*x**2*exp(2*x) + 4*x + cos(2*x) + 3\n", + "The solution is y = 4*x**2*exp(2*x) + 4*x + (c1 + c2*x)*exp(-1.0*x) + cos(2*x) + 3\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "print 'CF + PI'\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = (m-2)**2;\n", + "r = numpy.roots([2, 2])\n", + "print r\n", + "print 'CF is given by: '\n", + "cf = (c1+c2*x)*sympy.exp(r[0]*x)\n", + "print cf\n", + "print '−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−'\n", + "print 'PI = 8∗{1/(D−2)**2[exp(2x)]+{1/(D−2)**2[sin(2x)]+{1/(D−2)**2[x**2]}'\n", + "print 'Using identitties it reduces to: ',\n", + "pi = 4*x**2*sympy.exp(2*x)+sympy.cos(2*x)+4*x+3\n", + "print pi\n", + "y = cf + pi ;\n", + "print 'The solution is y = ', y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Exampe 13.12, page no. 407" + ] + }, + { + "cell_type": "code", + "execution_count": 19, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "CF + PI\n", + "[-0.+1.41421356j 0.-1.41421356j]\n", + "CF is given by\n", + "c1*exp(1.4142135623731*I*x) + c2*exp(-1.4142135623731*I*x)\n", + "−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−\n", + "PI = 8∗{1/(D**2-4)[x∗sinh(x)]\n", + "Using identities it reduces to: -x*(exp(x) - exp(-x))/6\n", + "The solution is y = c1*exp(1.4142135623731*I*x) + c2*exp(-1.4142135623731*I*x) - x*(exp(x) - exp(-x))/6\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "print 'CF + PI'\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**2-4\n", + "r = numpy.roots([2, 0, 4])\n", + "print r\n", + "print 'CF is given by'\n", + "cf = c1*sympy.exp(r[0]*x)+c2*sympy.exp(r[1]*x)\n", + "print cf\n", + "print '−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−'\n", + "print 'PI = 8∗{1/(D**2-4)[x∗sinh(x)]'\n", + "print 'Using identities it reduces to: ',\n", + "pi = -x/6*(sympy.exp(x)-sympy.exp(-x))-2/18*(sympy.exp(x)+sympy.exp(-x))\n", + "print pi\n", + "y = cf + pi\n", + "print \"The solution is y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.13, page no. 408" + ] + }, + { + "cell_type": "code", + "execution_count": 26, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "CF + PI\n", + "[-0.+0.70710678j 0.-0.70710678j]\n", + "CF is given by\n", + "c1*exp(0.707106781186548*I*x) + c2*exp(-0.707106781186548*I*x)\n", + "−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−\n", + "PI = -1/10∗{1/(D**2-1)[x∗sin(3x)+cos(x)]\n", + "Using identities it reduces to: -x*sin(3*x) - cos(x)/2\n", + "The solution is y = c1*exp(0.707106781186548*I*x) + c2*exp(-0.707106781186548*I*x) - x*sin(3*x) - cos(x)/2\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "print 'CF + PI'\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f = m**2-1\n", + "r = numpy.roots([2, 0, 1])\n", + "print r\n", + "print 'CF is given by'\n", + "cf = c1*sympy.exp(r[0]*x)+c2*sympy.exp(r[1]*x)\n", + "print cf\n", + "print '−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−'\n", + "print 'PI = -1/10∗{1/(D**2-1)[x∗sin(3x)+cos(x)]'\n", + "print 'Using identities it reduces to: ',\n", + "pi = -1/10*(x*sympy.sin(3*x)+3/5*sympy.cos(3*x))-sympy.cos(x)/2\n", + "print pi\n", + "y = cf + pi\n", + "print \"The solution is y = \", y" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Example 13.14, page no. 408" + ] + }, + { + "cell_type": "code", + "execution_count": 31, + "metadata": { + "collapsed": false + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Solution to the given linear differntial equation is given by: \n", + "CF + PI\n", + "(5.55111512313e-17+0.707106781187j)\n", + "CF is given by\n", + "(c1 + c2*x)*exp(5.55111512312578e-17*x) + (c3 + c4*x)*exp(-0.5*x)\n", + "−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−\n", + "PI = ∗{1/(D**4+2∗D+1)[x**2∗cos(x)]\n", + "Using identities it reduces to: 4*x**3*sin(x) - (x**4 - 9*x**2)*cos(x)\n", + "The solution is y = 4*x**3*sin(x) + (c1 + c2*x)*exp(5.55111512312578e-17*x) + (c3 + c4*x)*exp(-0.5*x) - (x**4 - 9*x**2)*cos(x)\n" + ] + } + ], + "source": [ + "import numpy, sympy\n", + "\n", + "print 'Solution to the given linear differntial equation is given by: '\n", + "print 'CF + PI'\n", + "c1 = sympy.Symbol('c1')\n", + "c2 = sympy.Symbol('c2')\n", + "c3 = sympy.Symbol('c3')\n", + "c4 = sympy.Symbol('c4')\n", + "x = sympy.Symbol('x')\n", + "m = numpy.poly([0])\n", + "f =m**4+2*m**2+1\n", + "r = numpy.roots([4, 2, 2, 1])\n", + "print r[0]\n", + "print 'CF is given by'\n", + "cf = ((c1+c2*x)*sympy.exp(r[0].real*x)+(c3+c4*x)*sympy.exp(r[2].real*x))\n", + "print cf\n", + "print '−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−'\n", + "print 'PI = ∗{1/(D**4+2∗D+1)[x**2∗cos(x)]'\n", + "print 'Using identities it reduces to: ',\n", + "pi = -1/48*((x**4-9*x**2)*sympy.cos(x)-4*x**3*sympy.sin(x))\n", + "print pi\n", + "y = cf + pi\n", + "print \"The solution is y = \", y" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 2", + "language": "python", + "name": "python2" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 2 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython2", + "version": "2.7.10" + } + }, + "nbformat": 4, + "nbformat_minor": 0 +} |