diff options
Diffstat (limited to 'Elementary_Principles_of_Chemical_Processes/Chapter4.ipynb')
-rwxr-xr-x | Elementary_Principles_of_Chemical_Processes/Chapter4.ipynb | 1771 |
1 files changed, 1771 insertions, 0 deletions
diff --git a/Elementary_Principles_of_Chemical_Processes/Chapter4.ipynb b/Elementary_Principles_of_Chemical_Processes/Chapter4.ipynb new file mode 100755 index 00000000..0ee3fbef --- /dev/null +++ b/Elementary_Principles_of_Chemical_Processes/Chapter4.ipynb @@ -0,0 +1,1771 @@ +{ + "metadata": { + "name": "", + "signature": "sha256:cf9c0d91c794ab27af5e7da425a28b836daf2f988940f28c4a10f4b42bda95d5" + }, + "nbformat": 3, + "nbformat_minor": 0, + "worksheets": [ + { + "cells": [ + { + "cell_type": "heading", + "level": 1, + "metadata": {}, + "source": [ + "Chapter 4: Fundamentals of Material Balances" + ] + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.2-1, page no. 85" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initialization of variables\n", + "input=50000 #ppl/yr\n", + "generation=22000 #ppl/yr\n", + "consumption=19000 #ppl/yr\n", + "output=75000 #ppl/yr\n", + "print (\"All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "#Calculations and printing:\n", + "accumulation = input+generation-output-consumption\n", + "print (\" We know that accumulation=input+generation-output-consumption\")\n", + "print '%s %d %s' %('Hence, Each year population decreases by', -accumulation, 'people')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " We know that accumulation=input+generation-output-consumption\n", + "Hence, Each year population decreases by 22000 people\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 1, + "text": [ + "''" + ] + } + ], + "prompt_number": 1 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.2-2, page no. 86" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "inputBenzene=500 #kg/h\n", + "inputToluene=500 #kg/h\n", + "UpStreamBenzene=450 #kg/h\n", + "DownStreamToluene=475 #kg/h\n", + "#Calculations and printing:\n", + "print(\"All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Using benzene balance,\")\n", + "m2dot=inputBenzene-UpStreamBenzene\n", + "print ' %s %d %s' %(' m2dot= ', m2dot, ' kg B/h')\n", + "print(\"Using Toluene balance\")\n", + "m1dot=inputToluene-DownStreamToluene\n", + "print ' %s %d %s' %(' m1dot= ', m1dot, ' kg T/h')\n", + "print(\"To check we can perform Overall mass balance\")\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Using benzene balance,\n", + " m2dot= 50 kg B/h\n", + "Using Toluene balance\n", + " m1dot= 25 kg T/h\n", + "To check we can perform Overall mass balance\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 2, + "text": [ + "''" + ] + } + ], + "prompt_number": 2 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.2-3, page no. 87" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initialization of variables\n", + "m1=200 #g\n", + "m2=150 #g\n", + "x1=0.4 #methanol/g\n", + "x2=0.7 #methanol/g\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "m=m1+m2\n", + "print '%s %d %s' %(' Total mass after mixing m=',m, 'g',)\n", + "x=(m1*x1 + m2*x2)/m\n", + "print'%s %.2f %s %.2f' %(' The composition of the methanol in the product is', x ,' and water is', 1-x)\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " Total mass after mixing m= 350 g\n", + " The composition of the methanol in the product is 0.53 and water is 0.47\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 3, + "text": [ + "''" + ] + } + ], + "prompt_number": 3 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.2-4, page no. 88" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "rate=0.1 #kmol/min\n", + "x1=0.1 #mole fraction hexane vapour\n", + "vol=10 #m^3\n", + "d=0.659 #kg/L\n", + "M=86.2 #Kg/kmol\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "ndot=rate/(1-x1)\n", + "deltaN= -vol*d*1000 /M\n", + "tf=deltaN/(-0.1 * ndot)\n", + "print '%s %.2f %s' %(' The time Required for the Total process= ',tf, 'min')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " The time Required for the Total process= 6880.51 min\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 5, + "text": [ + "''" + ] + } + ], + "prompt_number": 5 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.3-1, page no. 92" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "Vdot=20 #CC/min\n", + "x=0.015\n", + "MH2O=18.02 #g\n", + "DH2O=1 #g/CC\n", + "x1=0.2\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "n2=Vdot*DH2O/MH2O\n", + "print'%s %.2f %s' %('n2=', n2, ' mol/min')\n", + "print(\"Using Water Balance,\")\n", + "n3=n2/x\n", + "print'%s %.2f %s' %('n3=', n3, ' mol/min')\n", + "print(\"Using total mole balance,\")\n", + "n1=(n3-n2)/(1+x1)\n", + "print'%s %.2f %s' %('n1=', n1, ' mol/min')\n", + "print(\"Using N2 balance,\")\n", + "y=1-x-0.79*n1/n3\n", + "print '%s %.2f %s' %('y=',y,' mol O2/mol')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "n2= 1.11 mol/min\n", + "Using Water Balance,\n", + "n3= 73.99 mol/min\n", + "Using total mole balance,\n", + "n1= 60.73 mol/min\n", + "Using N2 balance,\n", + "y= 0.34 mol O2/mol\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 6, + "text": [ + "''" + ] + } + ], + "prompt_number": 6 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.3-2, page no. 94" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #mol\n", + "FinalBasis=1250.0 #lb-moles/h\n", + "#Calulations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "multiply=FinalBasis/basis\n", + "Feed=100*multiply\n", + "TopStream=50*multiply\n", + "BottomStream1=12.5*multiply\n", + "BottomStream2=37.5*multiply\n", + "print '%s %.2f %s' %(' Final Basis=',Feed,' lb-moles /h')\n", + "print '%s %.2f %s' %(' Final Top Stream Feed=',TopStream, 'lb-moles /h')\n", + "print '%s %.2f %s' %(' Final Bottom Stream Feed 1 =', BottomStream1,'lb-moles A/h')\n", + "print '%s %.2f %s' %(' Final Bottom Stream Feed 2 =' ,BottomStream2,' lb-moles B/h')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " Final Basis= 1250.00 lb-moles /h\n", + " Final Top Stream Feed= 625.00 lb-moles /h\n", + " Final Bottom Stream Feed 1 = 156.25 lb-moles A/h\n", + " Final Bottom Stream Feed 2 = 468.75 lb-moles B/h\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 7, + "text": [ + "''" + ] + } + ], + "prompt_number": 7 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.3-3, page no. 97" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #kg\n", + "inputx=0.2\n", + "outputx=0.08\n", + "D=1 #kg/L\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Using NaOH balance\")\n", + "m2=inputx*basis/outputx\n", + "print '%s %.2f %s' %('m2=',m2 ,'Kg NaOH')\n", + "print(\"Using Total mass balance\")\n", + "m1=m2-basis\n", + "print '%s %.2f %s' %('m1=',m1, 'Kg Water')\n", + "V1=m1/D\n", + "print '%s %.2f %s' %(' V1=',V1 ,'Litres')\n", + "Ratio1=V1/basis\n", + "Ratio2=m2/basis\n", + "print '%s %.2f %s' %(' Ratio of lt water/Kg Feed =', Ratio1,' lt water/Kg Feed')\n", + "print '%s %.2f %s' %(' Ratio of Kg product/Kg Feed =', Ratio2 ,'Kg product/Kg Feed')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Using NaOH balance\n", + "m2= 250.00 Kg NaOH\n", + "Using Total mass balance\n", + "m1= 150.00 Kg Water\n", + " V1= 150.00 Litres\n", + " Ratio of lt water/Kg Feed = 1.50 lt water/Kg Feed\n", + " Ratio of Kg product/Kg Feed = 2.50 Kg product/Kg Feed\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 8, + "text": [ + "''" + ] + } + ], + "prompt_number": 8 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.3-5, page no. 102" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "inputx=0.45\n", + "outputx=0.95\n", + "basis=2000 #L/h\n", + "outputBasis=100 #Kmol\n", + "M1=78.11\n", + "M2=92.13\n", + "D=0.872\n", + "z=0.08\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "mass1=outputBasis*M1*outputx\n", + "mass2=outputBasis*M2*(1-outputx)\n", + "mass=mass1+mass2\n", + "yB2=mass1/mass\n", + "m1=basis*D\n", + "print '%s %.2f %s' %(' m1=',m1,' Kg/h')\n", + "mB3=z*inputx*m1\n", + "print '%s %.2f %s' %(' mB3=',mB3,' Kg/h')\n", + "print(\"Using Benzene balance,\")\n", + "m2=(inputx*m1-mB3)/yB2\n", + "print '%s %.2f %s' %(' m2=',m2, 'Kg/h')\n", + "print(\"Using Toluene balance,\")\n", + "mT3=(1-inputx)*m1-(1-yB2)*m2\n", + "print '%s %.2f %s' %(' mT3=',mT3,' Kg/h')\n", + "m3=mB3+mT3\n", + "print '%s %.2f %s' %(' m3=',m3,' Kg/h')\n", + "yB3=mB3/m3\n", + "print '%s %.2f %s' %(' yB3=',yB3,' kg B/kg')\n", + "yT3=1-yB3\n", + "print '%s %.2f %s' %(' yT3=',yT3, 'kg T/kg')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " m1= 1744.00 Kg/h\n", + " mB3= 62.78 Kg/h\n", + "Using Benzene balance,\n", + " m2= 766.84 Kg/h\n", + "Using Toluene balance,\n", + " mT3= 914.38 Kg/h\n", + " m3= 977.16 Kg/h\n", + " yB3= 0.06 kg B/kg\n", + " yT3= 0.94 kg T/kg\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 10, + "text": [ + "''" + ] + } + ], + "prompt_number": 10 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.4-1, page no. 105" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "inputMass1=100 #Kg/h\n", + "inputMass2=30 #Kg/h\n", + "outputMass1=40 #Kg/h\n", + "outputMass2=30 #Kg/h\n", + "inputx1=0.5\n", + "inputx2=0.3\n", + "outputx1=0.9\n", + "outputx2=0.6\n", + "#Calculations and printing\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"using Overall Mass balance, \")\n", + "m3=inputMass1+inputMass2-outputMass1-outputMass2\n", + "print '%s %d %s' %('m3=',m3,' Kg/h')\n", + "print(\"using Overall balance on A, \")\n", + "x3=(inputMass1*inputx1+inputMass2*inputx2-outputMass1*outputx1-outputMass2*outputx2)/m3\n", + "print '%s %.2f %s' %('x3=',x3,' Kg A/kg')\n", + "print(\"using Mass balance on Unit 1, \")\n", + "m1=inputMass1-outputMass1\n", + "print '%s %d %s' %('m1=',m1,' Kg/h')\n", + "print(\"using A balance on Unit 1, \")\n", + "x1=(inputMass1*inputx1-outputMass1*outputx1)/m1\n", + "print '%s %.2f %s' %('x1=',x1,' Kg A/kg')\n", + "print(\"using Mass balance on mixing point, \")\n", + "m2=inputMass2+m1\n", + "print '%s %d %s' %('m2=',m2,'Kg/h')\n", + "print(\"using A balance on mixing point, \")\n", + "x2=(inputMass2*inputx2+m1*x1)/m2\n", + "print '%s %.2f %s' %('x2=',x2 ,'Kg A/kg')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "using Overall Mass balance, \n", + "m3= 60 Kg/h\n", + "using Overall balance on A, \n", + "x3= 0.08 Kg A/kg\n", + "using Mass balance on Unit 1, \n", + "m1= 60 Kg/h\n", + "using A balance on Unit 1, \n", + "x1= 0.23 Kg A/kg\n", + "using Mass balance on mixing point, \n", + "m2= 90 Kg/h\n", + "using A balance on mixing point, \n", + "x2= 0.26 Kg A/kg\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 12, + "text": [ + "''" + ] + } + ], + "prompt_number": 12 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.4-2, page no. 107" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "from numpy import matrix, array, dot\n", + "from numpy.linalg import inv\n", + "import math\n", + "massin=100 #kg\n", + "M1=100 #kg\n", + "M2=75 #Kg\n", + "massout=43.1 #kg\n", + "inputx=0.5\n", + "outputxA=0.053\n", + "outputxM=0.016\n", + "m1xA=0.275\n", + "m1xM=0.725\n", + "m3xW=0.03\n", + "m3xA=0.09\n", + "m3xM=0.88\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Using Balances around two-extraxtor system,\")\n", + "print(\"Balance on total mass,\")\n", + "\n", + "A=array([[1,1],[m1xA,m3xA]])\n", + "b=array([[massin+M1+M2-massout],[massin*inputx - massout*outputxA]])\n", + "C=dot(inv(A),b)\n", + "m1=C[0,0]\n", + "m3=C[1,0]\n", + "print '%s %.2f %s' %(' m1=',m1,' Kg')\n", + "print '%s %.2f %s' %(' m3=',m3,' Kg')\n", + "print(\"Balance on M\")\n", + "xM1=(massin+M2-massout*outputxM-m3*m3xM)/m1\n", + "print '%s %.2f %s' %(' xM1=',xM1,' kg MIBK/kg')\n", + "print(\"Balances around Extract mixing point, \")\n", + "print(\"Balance on A\")\n", + "mA4=m1*m1xA+m3*m3xA\n", + "print '%s %.2f %s' %(' mA4=',mA4 ,'Kg Acetone')\n", + "print(\"Balance on M\")\n", + "mM4=m1*xM1+m3*m3xM\n", + "print '%s %.2f %s' %(' mM4=',mM4,' Kg MIBK')\n", + "print(\"Balance on W\")\n", + "mW4=m1*(m1xM-xM1) + m3*m3xW\n", + "print '%s %.2f %s' %(' mW4=',mW4 ,'Kg Water')\n", + "print(\"Balances around the First extractor\")\n", + "print(\"Balance on A\")\n", + "mA2=massin*inputx-m1*m1xA\n", + "print '%s %.2f %s' %(' mA2=',mA2,' Kg Acetone')\n", + "print(\"Balance on M\")\n", + "mM2=massin-m1*xM1\n", + "print '%s %.2f %s' %(' xM1=',xM1, 'Kg MIBK')\n", + "print(\"Balance on W\")\n", + "mW2=massin*inputx- m1*(m1xM-xM1)\n", + "print '%s %.2f %s' %(' mW2=',mW2,'Kg Water')\n", + "\n" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Using Balances around two-extraxtor system,\n", + "Balance on total mass,\n", + " m1= 145.11 Kg\n", + " m3= 86.79 Kg\n", + "Balance on M\n", + " xM1= 0.67 kg MIBK/kg\n", + "Balances around Extract mixing point, \n", + "Balance on A\n", + " mA4= 47.72 Kg Acetone\n", + "Balance on M\n", + " mM4= 174.31 Kg MIBK\n", + "Balance on W\n", + " mW4= 9.87 Kg Water\n", + "Balances around the First extractor\n", + "Balance on A\n", + " mA2= 10.10 Kg Acetone\n", + "Balance on M\n", + " xM1= 0.67 Kg MIBK\n", + "Balance on W\n", + " mW2= 42.73 Kg Water\n" + ] + } + ], + "prompt_number": 6 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.5-1, page no. 110" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "import math\n", + "import numpy\n", + "from numpy import linalg\n", + "x1=0.960\n", + "x2=0.977\n", + "x3=0.983\n", + "basis=100 #mol\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Overall dry Air balance,\")\n", + "n1=x3*basis/x1\n", + "print '%s %.2f %s' %('n1=',n1,' mol Fresh feed')\n", + "print(\"Overall mole balance,\")\n", + "n3=n1-basis\n", + "print '%s %.2f %s' %('n3=',n3,' mol Water condensed')\n", + "print(\"Mole balance on mixing point,\")\n", + "print(\"n1+n5=n2\")\n", + "print(\"Water balance on mixing point\")\n", + "print ' %.2f %s %.2f %s %.2f %s' %(1-x1,' n1+ ', 1-x3,' n5 =', 1-x2,'n2')\n", + "A=([[1 ,-1],[1-x2,-(1-x3)]])\n", + "b=([[n1],[(1-x1)*n1]])\n", + "C=numpy.dot(linalg.inv(A),b)\n", + "n2=C[0,0]\n", + "n5=C[1,0]\n", + "print '%s %.2f %s' %(' \\n n2=',n2,' mol')\n", + "print '%s %.2f %s' %(' \\n n5=',n5,' mol Recycled')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Overall dry Air balance,\n", + "n1= 102.40 mol Fresh feed\n", + "Overall mole balance,\n", + "n3= 2.40 mol Water condensed\n", + "Mole balance on mixing point,\n", + "n1+n5=n2\n", + "Water balance on mixing point\n", + " 0.04 n1+ 0.02 n5 = 0.02 n2\n", + " \n", + " n2= 392.52 mol\n", + " \n", + " n5= 290.12 mol Recycled\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 15, + "text": [ + "''" + ] + } + ], + "prompt_number": 15 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.5-2, page no. 112" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "import math\n", + "import numpy\n", + "from numpy import linalg\n", + "feed=4500 #kg/h\n", + "feedx=0.333\n", + "m3x=0.494\n", + "m5x=0.364\n", + "x=0.95\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "m6x=m5x\n", + "print '%s %.2f %s' %('Given, m4=',x,' (m4+m5)')\n", + "print(\"using Overall K2CrO4 balance, \")\n", + "print ' %.2f %s %.2f %s %.2f %s' %(feedx,' *', feed ,'= m4+', m6x,'m5')\n", + "A=([[1-x,-x],[1,m6x]])\n", + "b=([[0],[feedx*feed]])\n", + "C=numpy.dot(linalg.inv(A),b)\n", + "m4=C[0,0]\n", + "m5=C[1,0]\n", + "print '%s %.2f %s' %(' \\n m4=',m4,' K2CrO4 crystals/h')\n", + "print '%s %.2f %s' %(' \\n m5=',m5,' entrained solution/h')\n", + "print(\"Overall Total mass balance , \")\n", + "m2=feed-m4-m5\n", + "print '%s %.2f %s' %('m2=',m2,' Kg H2O evaporated/h')\n", + "print(\"Mass balance around the crystallizer,\")\n", + "print(\"m3=m4+m5+m6\")\n", + "print(\"Water balance around the crystallizer, \")\n", + "print ' %.2f %s %.2f %s %.2f %s' %(1-m3x, 'm3=', 1-m5x,' m5 + ',1-m6x,' m6')\n", + "D=([[1,-1],[1,(-1+m6x)/(1-m3x)]])\n", + "e=([[m4+m5],[(1-m5x)*m5/(1-m3x)]])\n", + "F=numpy.dot(linalg.inv(D),e)\n", + "m3=F[0,0]\n", + "m6=F[1,0]\n", + "print '%s %.2f %s' %(' \\n m3=',m3,' Kg/h fed to the crystallizer')\n", + "print '%s %.2f %s' %(' \\n m6=',m6,' Kg/h')\n", + "ratio=m6/feed\n", + "print '%s %.2f %s' %(' \\n ratio=',ratio,' Kg recycle/ Kg fresh feed')\n", + "print(\"mass balance around Recycle-fresh feed mixing point, \")\n", + "m1=feed+m6\n", + "print '%s %.2f %s' %('m1=',m1,' kg/h feed to the evaporator')\n", + "print(\"With out recycle, \")\n", + "print(\"m3=622 Kg/h\")\n", + "print(\"m5=2380 Kg/h\")\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Given, m4= 0.95 (m4+m5)\n", + "using Overall K2CrO4 balance, \n", + " 0.33 * 4500.00 = m4+ 0.36 m5\n", + " \n", + " m4= 1470.33 K2CrO4 crystals/h\n", + " \n", + " m5= 77.39 entrained solution/h\n", + "Overall Total mass balance , \n", + "m2= 2952.28 Kg H2O evaporated/h\n", + "Mass balance around the crystallizer,\n", + "m3=m4+m5+m6\n", + "Water balance around the crystallizer, \n", + " 0.51 m3= 0.64 m5 + 0.64 m6\n", + " \n", + " m3= 7193.31 Kg/h fed to the crystallizer\n", + " \n", + " m6= 5645.60 Kg/h\n", + " \n", + " ratio= 1.25 Kg recycle/ Kg fresh feed\n", + "mass balance around Recycle-fresh feed mixing point, \n", + "m1= 10145.60 kg/h feed to the evaporator\n", + "With out recycle, \n", + "m3=622 Kg/h\n", + "m5=2380 Kg/h\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 16, + "text": [ + "''" + ] + } + ], + "prompt_number": 16 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.6-1, page no. 120" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #mol\n", + "xP=0.1\n", + "xN=0.12\n", + "xA=0.78\n", + "x=0.3\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "nP=basis*xP\n", + "nN=basis*xN\n", + "nO2=basis*xA*0.21\n", + "nN2=basis-nP-nN-nO2\n", + "if nN/nP>1:\n", + " print(\"NH3 is in excess\")\n", + "else:\n", + " print(\"Propene is in excess\")\n", + "\n", + "if nO2/nP>1:\n", + " print(\"O2 is in excess\")\n", + "else:\n", + " print(\"propene is in excess\")\n", + "\n", + "nO2reacted=nP*1.5\n", + "nNreacted=nP*1\n", + "ExcessAmmonia=(nN-nNreacted)*100/nNreacted\n", + "ExcessO2=(nO2-nO2reacted)*100/nO2reacted\n", + "print '%s %.2f' %(' \\n percentage excess Ammonia=',ExcessAmmonia)\n", + "print '%s %.2f' %(' \\n percentage excess Oxygen=',ExcessO2)\n", + "nPout=(1-x)*nP\n", + "print '%s %.2f %s' %(' \\n no.of moles of Propylene left=', nPout,' mol')\n", + "E=nP-nPout\n", + "nNout=nN-E\n", + "nO2out=nO2-1.5*E\n", + "nAc=E\n", + "nW=3*E\n", + "print'%s %.2f %s' %(' \\n no.of moles of Ammonia left=', nNout,' mol')\n", + "print'%s %.2f %s' %(' \\n no.of moles of oxygen left=' ,nO2out,' mol')\n", + "print'%s %.2f %s' %(' \\n no.of moles of ACN formed= ',nAc ,'mol')\n", + "print'%s %.2f %s' %(' \\n no.of moles of water formed=', nW ,'mol')\n", + "print'%s %.2f %s' %(' \\n no.of moles of Nirtogen present= ',nN2 ,'mol')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "NH3 is in excess\n", + "O2 is in excess\n", + " \n", + " percentage excess Ammonia= 20.00\n", + " \n", + " percentage excess Oxygen= 9.20\n", + " \n", + " no.of moles of Propylene left= 7.00 mol\n", + " \n", + " no.of moles of Ammonia left= 9.00 mol\n", + " \n", + " no.of moles of oxygen left= 11.88 mol\n", + " \n", + " no.of moles of ACN formed= 3.00 mol\n", + " \n", + " no.of moles of water formed= 9.00 mol\n", + " \n", + " no.of moles of Nirtogen present= 61.62 mol\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 17, + "text": [ + "''" + ] + } + ], + "prompt_number": 17 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.6-2, page no. 122" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initialization of variables\n", + "import math\n", + "import numpy\n", + "from numpy import linalg\n", + "print(\"Given, Reaction is CO(g)+ H2O(g) --> CO2(g)+ H2(g)\")\n", + "nCO=1.\n", + "nH2O=2.\n", + "#Calculations and printing:\n", + "nt=nCO+nH2O\n", + "print(\"\\n It is found that Ee=0.667\")\n", + "Ee=0.667\n", + "yCO=(nCO-Ee)/nt\n", + "yH2O=(nH2O-Ee)/nt\n", + "yCO2=Ee/nt\n", + "yH2=Ee/nt\n", + "print(\"\\n Ee is obtained by solving the quadratic yCO2*yH2/(yCO*yH2O)=1\")\n", + "print(\"\\n Limiting reactant is CO\")\n", + "print '%s %.3f' %(\"\\n yCO = \",yCO)\n", + "print '%s %.3f' %(\"\\n yCO2 = \",yCO2)\n", + "print '%s %.3f' %(\"\\n yH2O = \",yH2O)\n", + "print '%s %.3f' %(\"\\n yH2 = \",yH2)\n", + "nCOF=yCO*nt\n", + "fCO=(nCO-nCOF)/nCO\n", + "print '%s %.3f' %(\"\\n Fractional conversion of CO at equilibrium is \", fCO)\n", + "raw_input('press enter key to exit')" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "Given, Reaction is CO(g)+ H2O(g) --> CO2(g)+ H2(g)\n", + "\n", + " It is found that Ee=0.667\n", + "\n", + " Ee is obtained by solving the quadratic yCO2*yH2/(yCO*yH2O)=1\n", + "\n", + " Limiting reactant is CO\n", + "\n", + " yCO = 0.111\n", + "\n", + " yCO2 = 0.222\n", + "\n", + " yH2O = 0.444\n", + "\n", + " yH2 = 0.222\n", + "\n", + " Fractional conversion of CO at equilibrium is 0.667\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "press enter key to exit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 18, + "text": [ + "''" + ] + } + ], + "prompt_number": 18 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.6-3, page no. 124" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #mol\n", + "x=0.850\n", + "conv1=0.501\n", + "conv2=0.471\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "n1=(1-conv1)*basis*x\n", + "n2=conv2*basis*x\n", + "E1=n2\n", + "E2=basis*x - E1-n1\n", + "n3=E1-E2\n", + "n4=2*E2\n", + "n5=basis*(1-x)\n", + "nt=n1+n2+n3+n4+n5\n", + "selectivity=n2/n4\n", + "print '%s %.2f %s ' %('selectivity=',selectivity,' mol Ethene/mol methane')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "selectivity= 7.85 mol Ethene/mol methane \n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 19, + "text": [ + "''" + ] + } + ], + "prompt_number": 19 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.7-2, page no. 135" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #mol\n", + "x=0.850\n", + "conv1=0.501\n", + "conv2=0.471\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "n1=(1-conv1)*basis*x\n", + "n2=conv2*basis*x\n", + "E1=n2\n", + "E2=basis*x - E1-n1\n", + "n3=E1-E2\n", + "n4=2*E2\n", + "n5=basis*(1-x)\n", + "nt=n1+n2+n3+n4+n5\n", + "selectivity=n2/n4\n", + "print '%s %.2f %s ' %('selectivity=',selectivity,' mol Ethene/mol methane')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "selectivity= 7.85 mol Ethene/mol methane \n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 20, + "text": [ + "''" + ] + } + ], + "prompt_number": 20 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.7-3, page no. 139" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "import math\n", + "import numpy\n", + "from numpy import linalg\n", + "x0=0.996\n", + "basis=100 #mol combined feed to the reactor\n", + "inputxH2=0.7\n", + "single_pass=0.6\n", + "inputxCO2=0.28\n", + "molI=2\n", + "Ix=0.004\n", + "final=155 #kmol/h\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Reactor analysis, \")\n", + "n2=(1-single_pass)*basis*inputxH2\n", + "print '%s %.2f %s' %('n2=',n2,' mol H2')\n", + "print(\"H2 balance\")\n", + "consH2=basis*inputxH2-n2\n", + "print '%s %.2f %s' %('H2 moles consumed=',consH2,' mol H2')\n", + "print(\"CO2 balance\")\n", + "n1=basis*inputxCO2-consH2/3\n", + "print '%s %.2f %s' %('n1=',n1,'mol CO2')\n", + "print(\"Methanol balance\")\n", + "n3=consH2/3\n", + "print '%s %.2f %s' %('n3=',n3,'mol Methanol')\n", + "print(\"H2O balance\")\n", + "n4=consH2/3\n", + "print '%s %.2f %s' %('n4=',n4,' mol H2O')\n", + "print(\"condenser analysis\")\n", + "print(\"Total mole balance\")\n", + "n5=n1+n2+molI\n", + "print '%s %.2f %s' %('n5=',n5 ,'mol')\n", + "print(\"CO2 balance\")\n", + "x5C=n1/n5\n", + "print '%s %.2f %s' %('x5C=',x5C,' mol CO2/mol')\n", + "print(\"H2 balance\")\n", + "x5H=n2/n5\n", + "print '%s %.2f %s' %('x5H=', x5H,'mol CO2/mol')\n", + "x1=1-x5C-x5H\n", + "print '%s %.2f %s' %('x1=',x1,' mol I/mol')\n", + "print(\"Fresh Feed-Recycle mixing point analysis\")\n", + "print(\"Total mole balance\")\n", + "print '%s %.2f' %('n0+nr=',basis)\n", + "print(\"I balance\")\n", + "print '%s %.2f %s %.2f %s %.2f' %('n0', Ix,' + nr ',x1,' = ',molI)\n", + "A=([[1, 1],[Ix, x1]])\n", + "b=([[basis],[molI]])\n", + "C=numpy.dot(linalg.inv(A),b) #Here We solve two linear equations simultaneously\n", + "n0=C[0,0]\n", + "nr=C[1,0]\n", + "print '%s %.2f %s' %(' \\n n0=',n0,' mol fresh feed')\n", + "print '%s %.2f %s' %(' \\n nr=', nr ,'mol recycle')\n", + "x0C=(basis*inputxCO2-nr*x5C)/n0\n", + "print '%s %.2f %s' %(' \\n x0C=',x0C,' mol CO2/mol')\n", + "x0H=1-x0C-Ix\n", + "print '%s %.2f %s' %(' \\n x0H=',x0H ,'mol H2/mol')\n", + "print(\"Recycle-Purge splitting Analysis\")\n", + "print(\"Total mole balance\")\n", + "np=n5-nr\n", + "print '%s %.2f %s' %('np=',np,' mol purge')\n", + "print(\"Flow chart scaling\")\n", + "Factor=final/n3\n", + "print '%s %.2f %s' %('Factor for scaling=',Factor,' Kmol/h/mol')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Reactor analysis, \n", + "n2= 28.00 mol H2\n", + "H2 balance\n", + "H2 moles consumed= 42.00 mol H2\n", + "CO2 balance\n", + "n1= 14.00 mol CO2\n", + "Methanol balance\n", + "n3= 14.00 mol Methanol\n", + "H2O balance\n", + "n4= 14.00 mol H2O\n", + "condenser analysis\n", + "Total mole balance\n", + "n5= 44.00 mol\n", + "CO2 balance\n", + "x5C= 0.32 mol CO2/mol\n", + "H2 balance\n", + "x5H= 0.64 mol CO2/mol\n", + "x1= 0.05 mol I/mol\n", + "Fresh Feed-Recycle mixing point analysis\n", + "Total mole balance\n", + "n0+nr= 100.00\n", + "I balance\n", + "n0 0.00 + nr 0.05 = 2.00\n", + " \n", + " n0= 61.40 mol fresh feed\n", + " \n", + " nr= 38.60 mol recycle\n", + " \n", + " x0C= 0.26 mol CO2/mol\n", + " \n", + " x0H= 0.74 mol H2/mol\n", + "Recycle-Purge splitting Analysis\n", + "Total mole balance\n", + "np= 5.40 mol purge\n", + "Flow chart scaling\n", + "Factor for scaling= 11.07 Kmol/h/mol\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 21, + "text": [ + "''" + ] + } + ], + "prompt_number": 21 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.8-1, page no. 143" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "xN2wet=0.6\n", + "xCO2wet=0.15\n", + "xO2wet=0.1\n", + "xH2O=0.15\n", + "basis=100 #mol Wet gas \n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"part 1\")\n", + "wet=xN2wet+xCO2wet+xO2wet\n", + "xN2dry=xN2wet/wet\n", + "xCO2dry=xCO2wet/wet\n", + "xO2dry=xO2wet/wet\n", + "print '%s %f %s' %(' \\n xN2 dry =', xN2dry,' mol N2/mol dry gas')\n", + "print '%s %f %s' %(' \\n xO2 dry =',xO2dry,' mol O2/mol dry gas')\n", + "print '%s %f %s' %(' \\n xCO2 dry =', xCO2dry ,'mol CO2/mol dry gas')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "part 1\n", + " \n", + " xN2 dry = 0.705882 mol N2/mol dry gas\n", + " \n", + " xO2 dry = 0.117647 mol O2/mol dry gas\n", + " \n", + " xCO2 dry = 0.176471 mol CO2/mol dry gas\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 22, + "text": [ + "''" + ] + } + ], + "prompt_number": 22 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.8-2, page no. 145" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basisButane=100. #mol/h butane\n", + "basisAir=5000. #mol/h\n", + "#calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "nO2Theoretical=basisButane*6.5\n", + "nAirTheoretical=nO2Theoretical*4.76\n", + "percent=(basisAir-nAirTheoretical)*100/nAirTheoretical\n", + "print '%s %.2f' %(' \\n percent excess air=',percent)\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " \n", + " percent excess air= 61.60\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 23, + "text": [ + "''" + ] + } + ], + "prompt_number": 23 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.8-3, page no. 147" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100. #mol ethane feed\n", + "E1=0.9\n", + "E2=0.25\n", + "excess=0.5\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\" 50percent excess air\")\n", + "nO2theoretical=basis*3.5\n", + "n0=nO2theoretical*(1+excess)/0.21\n", + "print '%s %.4f %s' %(' n0=',n0,' mol air fed')\n", + "print(\"90% ethane conversion\")\n", + "n1=(1-E1)*basis\n", + "print '%s %.4f' %('No. of moles of ethane unreacted=',n1)\n", + "print(\"25% conversion to CO\")\n", + "n4=E2*(basis-n1)*2\n", + "print '%s %.4f %s' %('n4=', n4 ,'mol CO')\n", + "print(\"nitrogen balance\")\n", + "n3=0.79*n0\n", + "print '%s %.4f %s' %('n3=', n3,' mol N2')\n", + "print(\"Atomic carbon balance\")\n", + "n5=2*basis-2*n1-n4\n", + "print '%s %.4f %s' %('n5=', n5 ,'mol CO2')\n", + "print(\"Atomic hydrogen balance\")\n", + "n6=(basis*6-n1*6)/2\n", + "print '%s %.4f %s' %('n6=', n6,' mol H2O')\n", + "print(\"Atomic oxygen balance\")\n", + "n2=(nO2theoretical*1.5*2-n4-n5*2-n6)/2\n", + "print '%s %.4f %s' %('n2=', n2 ,'mol O2')\n", + "dry=n1+n2+n3+n4+n5\n", + "wet=dry+n6\n", + "y1=n1/dry\n", + "print '%s %.4f %s' %('\\n y1=', y1,' mol C2H6/mol')\n", + "y2=n2/dry\n", + "print '%s %.4f %s' %('\\n y2=', y2 ,'mol O2/mol')\n", + "y3=n3/dry\n", + "print '%s %.4f %s' %('\\n y3=', y3,' mol N2/mol')\n", + "y4=n4/dry\n", + "print '%s %.4f %s' %('\\n y4=', y4 ,'mol CO/mol')\n", + "y5=n5/dry\n", + "print '%s %.4f %s' %('\\n y5=',y5,' mol CO2/mol')\n", + "ratio=n6/dry\n", + "print '%s %.4f %s' %(' \\n ratio=',ratio,' mol H2O/mol dry stack gas')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + " 50percent excess air\n", + " n0= 2500.0000 mol air fed\n", + "90% ethane conversion\n", + "No. of moles of ethane unreacted= 10.0000\n", + "25% conversion to CO\n", + "n4= 45.0000 mol CO\n", + "nitrogen balance\n", + "n3= 1975.0000 mol N2\n", + "Atomic carbon balance\n", + "n5= 135.0000 mol CO2\n", + "Atomic hydrogen balance\n", + "n6= 270.0000 mol H2O\n", + "Atomic oxygen balance\n", + "n2= 232.5000 mol O2\n", + "\n", + " y1= 0.0042 mol C2H6/mol\n", + "\n", + " y2= 0.0970 mol O2/mol\n", + "\n", + " y3= 0.8238 mol N2/mol\n", + "\n", + " y4= 0.0188 mol CO/mol\n", + "\n", + " y5= 0.0563 mol CO2/mol\n", + " \n", + " ratio= 0.1126 mol H2O/mol dry stack gas\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 24, + "text": [ + "''" + ] + } + ], + "prompt_number": 24 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.8-4, page no. 149" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "basis=100 #mol pf product gas\n", + "xCO=0.015\n", + "xCO2=0.060\n", + "xO2=0.082\n", + "xN2=0.843\n", + "#Calculations and printing:\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"N2 balance\")\n", + "na=basis*xN2/0.79\n", + "print '%s %.2f %s' %('na=',na,' mol air')\n", + "print(\"Atomic C balance\")\n", + "nc=basis*xCO + basis*xCO2\n", + "print '%s %.2f %s' %('nc=',nc ,'mol C')\n", + "print(\"Atomic O balance\")\n", + "nw=0.21*na*2-basis*(xCO + xCO2*2 + xO2*2)\n", + "print '%s %.2f %s' %('nw=',nw,' mol oxygen')\n", + "print(\"Atomic H2 balance\")\n", + "nh=nw*2\n", + "print '%s %.2f %s' %('nh=',nh ,'mol H2')\n", + "ratio=nh/nc\n", + "print '%s %.2f %s' %('\\n C/H ratio in fuel=',ratio,' mol H/mol C')\n", + "print(\"percent excess air\")\n", + "nO2theoretical=nc + nh/4\n", + "print '%s %.2f %s' %('nO2 theoretical=',nO2theoretical ,'mol O2')\n", + "nO2fed=0.21*na\n", + "print '%s %.2f %s' %(' \\n nO2fed=',nO2fed,' mol O2')\n", + "percent=(nO2fed-nO2theoretical)*100/nO2theoretical\n", + "print '%s %.2f %s' %('\\n percentage excess air=',percent ,'excess air')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "N2 balance\n", + "na= 106.71 mol air\n", + "Atomic C balance\n", + "nc= 7.50 mol C\n", + "Atomic O balance\n", + "nw= 14.92 mol oxygen\n", + "Atomic H2 balance\n", + "nh= 29.84 mol H2\n", + "\n", + " C/H ratio in fuel= 3.98 mol H/mol C\n", + "percent excess air\n", + "nO2 theoretical= 14.96 mol O2\n", + " \n", + " nO2fed= 22.41 mol O2\n", + "\n", + " percentage excess air= 49.80 excess air\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "stream": "stdout", + "text": [ + "Press the Enter key to quit\n" + ] + }, + { + "metadata": {}, + "output_type": "pyout", + "prompt_number": 25, + "text": [ + "''" + ] + } + ], + "prompt_number": 25 + }, + { + "cell_type": "heading", + "level": 2, + "metadata": {}, + "source": [ + "Example 4.9-1, page no. 151" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "\n", + "\n", + "#Initilization of variables\n", + "feed=59.6 #mol/s\n", + "x=0.2\n", + "TopFlow1=48.7 #mol/s\n", + "outputx1=0.021\n", + "BottomFlow1=10.9\n", + "TopFlow2=48.3\n", + "outputx2=0.063\n", + "BottomFlow2=6.4\n", + "print(\" All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\")\n", + "print(\"Design\")\n", + "MEKin1=feed*x\n", + "MEKout1=TopFlow1*outputx1 + BottomFlow1\n", + "closure1=MEKout1*100/MEKin1\n", + "print '%s %d %s' %('closure1=',closure1,' percent')\n", + "print(\"Experiment\")\n", + "MEKin2=feed*x\n", + "MEKout2=TopFlow2*outputx2 + BottomFlow2\n", + "closure2=MEKout2*100/MEKin2\n", + "print '%s %d %s' %('closure2=',closure2, 'percent')\n", + "raw_input(\"Press the Enter key to quit\")" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + " All the values in the textbook are Approximated hence the values in this code differ from those of Textbook\n", + "Design\n", + "closure1= 100 percent\n", + "Experiment\n", + "closure2= 79 percent\n" + ] + } + ] + } + ], + "metadata": {} + } + ] +}
\ No newline at end of file |