summaryrefslogtreecommitdiff
path: root/Problems_in_Electrical_Engineering_by_Parker_Smith
diff options
context:
space:
mode:
Diffstat (limited to 'Problems_in_Electrical_Engineering_by_Parker_Smith')
-rw-r--r--Problems_in_Electrical_Engineering_by_Parker_Smith/Chapter1.ipynb3260
-rw-r--r--Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/VgnES.pngbin0 -> 77953 bytes
-rw-r--r--Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/f4att.pngbin0 -> 37338 bytes
-rw-r--r--Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/starNdelta.pngbin0 -> 57025 bytes
4 files changed, 3260 insertions, 0 deletions
diff --git a/Problems_in_Electrical_Engineering_by_Parker_Smith/Chapter1.ipynb b/Problems_in_Electrical_Engineering_by_Parker_Smith/Chapter1.ipynb
new file mode 100644
index 00000000..566ba120
--- /dev/null
+++ b/Problems_in_Electrical_Engineering_by_Parker_Smith/Chapter1.ipynb
@@ -0,0 +1,3260 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Appendix - Solved problems"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 2 Page 340"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 49,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Voltage Gradients :\n",
+ " for A : 1622 V/cm\n",
+ " for B : 1216 V/cm\n",
+ " for C : 811 V/cm\n",
+ "\n",
+ "Energy stored :\n",
+ " for A : 21.9 uJ\n",
+ " for B : 41.1 uJ\n",
+ " for C : 38.3 uJ\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "# Given\n",
+ "t1=2# # mm \n",
+ "t2=5# # mm \n",
+ "t3=7# # mm \n",
+ "eps1=3 # dielectric constant\n",
+ "eps2=4 # dielectric constant\n",
+ "eps3=6# # dielectric constant\n",
+ "eps0=1/36/pi*10**-9# # dielectric constant\n",
+ "d=10/100 # m\n",
+ "V=1500 # V \n",
+ "#E1*t1+E2*t2+E3*t3=V\n",
+ "#Voltage Gradients : \n",
+ "# using eps1*E1=eps2*E2=eps3*E3\n",
+ "E1=V/(t1+(eps1/eps2)*t2+(eps1/eps3)*t3)# V/mm \n",
+ "E1=E1*10 # V/cm\n",
+ "E2=eps1*E1/eps2 # V/cm\n",
+ "E3=eps1*E1/eps3 # V/cm\n",
+ "print \"Voltage Gradients :\\n for A : %.f V/cm\\n for B : %.f V/cm\\n for C : %.f V/cm\"%(E1,E2,E3)\n",
+ "\n",
+ "A = pi*d**2\n",
+ "W1=1/2*eps0*eps1*E1**2*10**4*A*t1*10**-3# # J\n",
+ "W2=1/2*eps0*eps2*E2**2*10**4*A*t2*10**-3# # J\n",
+ "W3=1/2*eps0*eps3*E3**2*10**4*A*t3*10**-3# # J\n",
+ "W1=W1*10**6 # # uJ\n",
+ "W2=W2*10**6 # # uJ\n",
+ "W3=W3*10**6 # # uJ\n",
+ "print \"\\nEnergy stored :\\n for A : %.1f uJ\\n for B : %.1f uJ\\n for C : %.1f uJ\"%(W1,W2,W3)\n",
+ "\n",
+ "\n",
+ "# Answer in the textbook are not accurate"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 3 Page 341"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 50,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Current required = 1.95 A\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "N=680# # turns\n",
+ "fi=1.6*10**3 # Wb\n",
+ "d1=4/100 # m\n",
+ "d2=24/100 # m\n",
+ "l=0.6 # m\n",
+ "mu0=4*pi/10**7 # constant\n",
+ "\n",
+ "\n",
+ "# For air gap : \n",
+ "A=d1**2 # m**2\n",
+ "Bg=fi/A # weber/m**2\n",
+ "Hg=Bg/mu0 # AT/m\n",
+ "mmf1=0.001/mu0 # AT\n",
+ "\n",
+ "# For central limb : \n",
+ "A=d1**2 # m**2\n",
+ "Bc=fi/A # weber/m**2\n",
+ "Hc=900 # AT/m (from magnetization curve)\n",
+ "mmf2=Hc*d2 # AT\n",
+ "\n",
+ "\n",
+ "# For side limb : \n",
+ "fi=1/2*fi # Wb\n",
+ "A=d1**2 # m**2\n",
+ "Bc=fi/A # weber/m**2\n",
+ "Hc=520 # AT/m (from magnetization curve)\n",
+ "mmf3=Hc*l # AT\n",
+ "\n",
+ "mmf_total = mmf1+mmf2+mmf3 # AT\n",
+ "i=mmf_total/N # A\n",
+ "print \"Current required = %0.2f A\"%(i)\n",
+ "\n",
+ "\n",
+ "# Answer in the textbook are not accurate"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 4 Page 343"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 51,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "\t\t\tWithout air gap With air gap\n",
+ "\n",
+ "Exciting current 3.75 A 11.7 A\n",
+ "\n",
+ "Inductance 5.3 mH 1.7 mH\n",
+ "\n",
+ "Stored Energy 0.375 J 1.17 J\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "D=15/100 # m\n",
+ "A=10/10**-4 # m**2\n",
+ "N=200# # turns\n",
+ "fi=1.6*10**3 # Wb\n",
+ "B=1 # weber/m**2\n",
+ "mu0=4*pi/10**7 # constant\n",
+ "mur=500 # constant\n",
+ "lg=2/1000 # m\n",
+ "\n",
+ "\n",
+ "# without air gap\n",
+ "l=pi*D # m\n",
+ "R=l/mu0/mur/A # A/Wb\n",
+ "fi=B*A # Wb\n",
+ "mmf=fi*R # AT\n",
+ "I=mmf/N # A\n",
+ "L=N**2/R/10**6 # mH\n",
+ "E=1/2*L*I**2/100 # J\n",
+ "\n",
+ "\n",
+ "# with air gap\n",
+ "Rg=lg/mu0/A # A/Wb\n",
+ "Rt=R+Rg # A/Wb\n",
+ "fi=B*A # Wb\n",
+ "mmf=fi*Rt # AT\n",
+ "I2=mmf/N # A\n",
+ "L2=N**2/Rt/10**6 # mH\n",
+ "E2=1/2*L2*I2**2/100 # J\n",
+ "\n",
+ "print \"\\t\\t\\tWithout air gap With air gap\"\n",
+ "print \"\\nExciting current %.2f A %.1f A\"%(I,I2)\n",
+ "print \"\\nInductance %.1f mH %.1f mH\"%(L,L2)\n",
+ "print \"\\nStored Energy %.3f J %.2f J\"%(E,E2)\n",
+ "\n",
+ "\n",
+ "# Answer in the textbook are not accurate"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 5 Page 344"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 52,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Voltage acroos 100 ohm = -72.0 V\n",
+ "\n",
+ "R=37.5 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import array\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "VA=60 # V\n",
+ "I=0.6 # A\n",
+ "# (VB-VA)/20+(VB-VC)/20+VB/20-I=0\n",
+ "#3*VB-VC=72 for node B eqn(1)\n",
+ "#(VC-VA)/50+(VC-VB)/30+(VC-12)/50+VC/100=0\n",
+ "#-5*VB+10*VC=144 eqn(2)\n",
+ "A=array([[3, -1],[-5 ,10]])\n",
+ "B=array([[72],[144]])\n",
+ "X=A**-1*B#\n",
+ "VB=X[0,0] # V\n",
+ "VC=X[0,1] # V\n",
+ "print \"Voltage acroos 100 ohm = %.1f V\"%(VC)\n",
+ "VC=24 # V\n",
+ "VB=(72+VC)/3 # from eqn(1)\n",
+ "# Node C \n",
+ "# (VC-VA)/50+(VC-VB)/20+(VC-12)/50+VC/100+VC/R=0 eqn(3)\n",
+ "R=100*VC/(144+5*VB-10*VC) # ohm\n",
+ "print \"\\nR=%.1f ohm\"%(R)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 6 Page 346"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 53,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "\n",
+ "at f = 2.34 kHz, the above filter will have required attenuation.\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,cosh\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "Ro=600 # ohm\n",
+ "fc=2*1000 # Hz\n",
+ "alfa=10 # dB\n",
+ "\n",
+ "\n",
+ "L=Ro/pi/fc*1000 # mH\n",
+ "C=1/(pi*Ro*fc)*10**6 # uF\n",
+ "alfa=alfa/8.686 # nepers\n",
+ "f=fc*cosh(alfa/2)/1000 # kHz\n",
+ "print \"\\nat f = %.2f kHz, the above filter will have required attenuation.\"%(f)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 7 Page 347"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 54,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "equation for instant current:\n",
+ "i=2.13*sin(314*t+1.01)\n",
+ "Power consumed = 56.6 W\n",
+ "Voltage across capacitor = 73.3 V(+ve & -ve)\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,atan,sqrt,asin,sin\n",
+ "\n",
+ "# Given\n",
+ "#v=100*sin(314*t)\n",
+ "R=25 # ohm\n",
+ "C=80 # uF\n",
+ "omega=314 # radian\n",
+ "Vm=100 # V\n",
+ "\n",
+ "Xc=1/omega/(C*10**-6) # ohm\n",
+ "Z=sqrt(R**2+Xc**2) # ohm\n",
+ "Im=Vm/Z # A\n",
+ "theta=atan(Xc/R) # radian\n",
+ "print \"equation for instant current:\"\n",
+ "print \"i=%.2f*sin(%d*t+%.2f)\"%(Im,omega,theta)\n",
+ "P=(Im/sqrt(2))**2*R # W\n",
+ "print \"Power consumed = %.1f W\"%(P)\n",
+ "Vcm=Im*Xc # V \n",
+ "#(when i=Im/2)\n",
+ "i=0.5*Im # A\n",
+ "#vc=Vcm*sin(314*t+theta-pi/2)\n",
+ "#i=Im*sin(314*t+theta)\n",
+ "tt=asin(i/Im) # radian tt=314*t+theta\n",
+ "vcm=Vcm*sin(tt-pi/2)\n",
+ "print \"Voltage across capacitor = %.1f V(+ve & -ve)\"%(abs(vcm))"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 8 Page 348"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 55,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Capacitance of XC = 318 uF\n",
+ "Circuit current = 10 A and power = 1 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import pi,roots\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "Z1=(6.25+1J*1.25) # ohm\n",
+ "Z2=(5+1J*0) # ohm\n",
+ "#Z3=(5-1J*XC) # ohm\n",
+ "V=100 # V\n",
+ "f=50 # Hz\n",
+ "#Z23=(250+5*Xc**2)/(100+Xc**2)-1J*(25*Xc)/(100+Xc**2)\n",
+ "#for in phase condition imag part must be zero\n",
+ "#5*Xc**2-100*Xc+5*100=0\n",
+ "A=[5 ,-100, 500] # polynomal \n",
+ "XC=roots(A)#\n",
+ "XC=XC[0] # ohm\n",
+ "C=1/(2*pi*f*XC)*10**6 # uF\n",
+ "print \"Capacitance of XC = %.f uF\"%(C)\n",
+ "Z=XC # ohm\n",
+ "I=V/Z # A\n",
+ "P=I**2*Z/1000 # kW\n",
+ "print \"Circuit current = %.f A and power = %.f kW\"%(I,P)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 9 Page 349"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 56,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "L = 10.4 mH\n",
+ " C=267 uF\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "omega_o=600 # rad/s\n",
+ "omega=400 # rad/s\n",
+ "R=3 # ohm\n",
+ "IBYIo=1/2 # ratio\n",
+ "\n",
+ "\n",
+ "fo=omega_o/2/pi # Hz\n",
+ "f=omega/2/pi # Hz\n",
+ "#I/Io=1/(sqrt(1+Q**2*(f/fo-fo/f)**2))\n",
+ "Q=sqrt(1/IBYIo**2-1)/(fo/f-f/fo)\n",
+ "#Q=1/omega_0/R/C\n",
+ "C=1/omega_o/R/Q*10**6 # uF\n",
+ "#Q=omega_0*L/R\n",
+ "L=Q*R/omega_o*1000 # mH\n",
+ "print \"L = %.1f mH\\n C=%.f uF\"%(L,C)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 10 Page 350"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 57,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Star Connection : P=1.6 kW\n",
+ "Delta Connection : P=4.8 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt\n",
+ "\n",
+ "# Given\n",
+ "\n",
+ "V=400 # V\n",
+ "f=50 # Hz\n",
+ "n=3 # no of phase\n",
+ "R=100 # ohm\n",
+ "\n",
+ "#Star connection\n",
+ "Vph=V/sqrt(n) # V\n",
+ "Iph=Vph/R # A\n",
+ "IL=Iph # A\n",
+ "cos_fi=1 # for only resitor load\n",
+ "P=sqrt(3)*V*IL*cos_fi/1000 # kW\n",
+ "print \"Star Connection : P=%.1f kW\"%(P)\n",
+ "#Delta Connection\n",
+ "\n",
+ "Vph=V # V\n",
+ "Iph=Vph/R # A\n",
+ "IL=sqrt(3)*Iph # A\n",
+ "VL=Vph # V\n",
+ "P=sqrt(3)*VL*IL*cos_fi/1000 # kW\n",
+ "print \"Delta Connection : P=%.1f kW\"%(P)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 11 Page 351"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 58,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Phase Current:\n",
+ "Iab=10 angle=-53.13 degree \n",
+ "Ibc=10 angle=-156.87 degree \n",
+ "Ica=20 angle=156.87 degree \n",
+ "\n",
+ "\n",
+ " Line Current:\n",
+ "Iaa=29 angle=-33.03 degree \n",
+ "Ibb=10 angle=165.00 degree \n",
+ "Icc=15 angle=127.97 degree \n",
+ "\n",
+ "\n",
+ " Total Power, W=3 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import exp,pi\n",
+ "import cmath as cm\n",
+ "# Given\n",
+ "Rab=6;Rbc=8;Rca=4 # ohm\n",
+ "Vab=100*exp(1J*0) # V\n",
+ "Vbc=100*exp(1J*-120*pi/180) # V\n",
+ "Vca=100*exp(1J*120*pi/180) # V\n",
+ "Zab=6+1J*8 # ohm\n",
+ "Zbc=8+1J*6 # ohm\n",
+ "Zca=4-1J*3 # ohm\n",
+ "\n",
+ "#Phase current\n",
+ "Iab=Vab/Zab # A\n",
+ "Ibc=Vbc/Zbc # A\n",
+ "Ica=Vca/Zca # A\n",
+ "print \"Phase Current:\"\n",
+ "print \"Iab=%.f angle=%.2f degree \"%(abs(Iab),cm.phase(Iab)*180/pi)\n",
+ "print \"Ibc=%.f angle=%.2f degree \"%(abs(Ibc),cm.phase(Ibc)*180/pi)\n",
+ "print \"Ica=%.f angle=%.2f degree \"%(abs(Ica),cm.phase(Ica)*180/pi)\n",
+ "#Line current\n",
+ "Iaa=Iab-Ica # A\n",
+ "Ibb=Ibc-Iab # A\n",
+ "Icc=Ica-Ibc # A\n",
+ "print \"\\n\\n Line Current:\"\n",
+ "print \"Iaa=%.f angle=%.2f degree \"%(abs(Iaa),cm.phase(Iaa)*180/pi)\n",
+ "print \"Ibb=%.f angle=%.2f degree \"%(abs(Iab),cm.phase(Ibb)*180/pi)\n",
+ "print \"Icc=%.f angle=%.2f degree \"%(abs(Icc),cm.phase(Icc)*180/pi)\n",
+ "#Power Consumed\n",
+ "Wab=abs(Iab)**2*Rab # W\n",
+ "Wbc=abs(Ibc)**2*Rbc # W\n",
+ "Wca=abs(Ica)**2*Rca # W\n",
+ "W=Wab+Wbc+Wca # W\n",
+ "W=W/1000 # kW\n",
+ "print \"\\n\\n Total Power, W=%.f kW\"%(W)\n",
+ "#Answer wrong for line current in the textbook."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 12 Page 353"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 59,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Wattmeter W1 reading=0 W\n",
+ "Wattmeter W2 reading=8000 W or 8 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import exp,pi\n",
+ "import cmath as cm\n",
+ "\n",
+ "# Given\n",
+ "VRY=200*exp(1J*0) # V\n",
+ "VYB=200*exp(1J*-120*pi/180) # V\n",
+ "VBR=200*exp(1J*120*pi/180) # V\n",
+ "\n",
+ "\n",
+ "ZA=10*exp(1J*60*pi/180) # ohm\n",
+ "ZB=10*exp(1J*0*pi/180) # ohm\n",
+ "ZC=10*exp(1J*60*pi/180) # ohm\n",
+ "\n",
+ "#Phase current\n",
+ "IRY=VRY/ZA # A\n",
+ "IYB=VYB/ZB # A\n",
+ "IBR=VBR/ZC # A\n",
+ "\n",
+ "IR=IRY-IBR # A\n",
+ "PVA=(VRY).conjugate()*IR # W\n",
+ "print \"Wattmeter W1 reading=%.f W\"%((PVA.real))\n",
+ "IB=IBR-IYB # A\n",
+ "PVB=(-VYB).conjugate()*IB # W\n",
+ "print \"Wattmeter W2 reading=%.f W or %.f kW\"%((PVB.real),(PVB.real)/1000)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 13 Page 354"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 60,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "expression for current:\n",
+ "i = 9.83*sin(omega*t--38.1)+1.0*sin(3*omega*t-7.0)+0.25*sin(5*omega*t-74.3)\n",
+ "Irms=7 A\n",
+ " Vrms=181 V\n",
+ "Total Power, P=977 W\n",
+ "Power factor = 0.77\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import exp,pi,sqrt\n",
+ "import cmath as cm\n",
+ "# Given\n",
+ "#v=250*sin(omega*t)+50*sin(3*omega*t+pi/3)+20*sin(5*omega*t+5*pi/6)\n",
+ "V1=250;V3=50;V5=20 # V\n",
+ "fi1=0;fi3=60;fi5=150 # degree\n",
+ "R=20 # omh\n",
+ "L=0.05 # H\n",
+ "omega=314 # rad/s\n",
+ "\n",
+ "X1=omega*L # ohm\n",
+ "Z1=R+1J*X1 # ohm\n",
+ "X3=3*omega*L # ohm\n",
+ "Z3=R+1J*X3 # ohm\n",
+ "X5=5*omega*L # ohm\n",
+ "Z5=R+1J*X5 # ohm\n",
+ "r1=abs(Z1);t1=cm.phase(Z1)\n",
+ "r3=abs(Z3);t3=cm.phase(Z3)\n",
+ "r5=abs(Z5);t5=cm.phase(Z5)\n",
+ "print \"expression for current:\"\n",
+ "print \"i = %.2f*sin(omega*t-%.1f)+%.1f*sin(3*omega*t%.1f)+%.2f*sin(5*omega*t-%.1f)\"%(V1/r1,fi1-t1*180/pi,V3/r3,fi3-t3*180/pi,V5/r5,fi5-t5*180/pi)\n",
+ "\n",
+ "I1m=V1/r1 # A\n",
+ "I3m=V3/r3 # A\n",
+ "I5m=V5/r5 # A\n",
+ "Irms=sqrt(I1m**2/2+I3m**2/2+I5m**2/2) # A\n",
+ "Vrms=sqrt(V1**2/2+V3**2/2+V5**2/2) # A\n",
+ "print \"Irms=%.f A\\n Vrms=%.f V\"%(Irms,Vrms)\n",
+ "P=Irms**2*R # W\n",
+ "print \"Total Power, P=%.f W\"%(P)\n",
+ "cosfi=P/Vrms/Irms # Power factor\n",
+ "print \"Power factor = %.2f\"%(cosfi)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 14 Page 355"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 61,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "expression for current:\n",
+ "i = 12.1*sin(314*t-1.263)+0.95*e**(-100*t)\n",
+ "current after 0.02 sec is : -11.4 A\n",
+ "transient component is : 1.56 A\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,exp,sin,atan\n",
+ "\n",
+ "# Given\n",
+ "f=50 # Hz\n",
+ "Vm=400 # V\n",
+ "R=10 # ohm\n",
+ "L=0.1 # H\n",
+ "t=0.02 # sec\n",
+ "XL=2*pi*f*L # ohm\n",
+ "Z=R+1J*XL # ohm\n",
+ "Im=Vm/abs(Z) # A\n",
+ "fi=atan(XL/R) # degree\n",
+ "lamda=L/R # sec\n",
+ "print \"expression for current:\"\n",
+ "print \"i = %.1f*sin(314*t-%.3f)+0.95*e**(-100*t)\"%(Im,fi)\n",
+ "i = Im*sin(314*t-fi)+0.95*exp(-100*t) # A\n",
+ "print \"current after 0.02 sec is : %0.1f A\"%(i)\n",
+ "i2=Im*(0.95*exp(-100*t)) # A\n",
+ "print \"transient component is : %0.2f A\"%(i2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 15 Page 356"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 62,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Since R<2sqrt(L/C), the circuit is originally oscillatory.\n",
+ "Expression for current :\n",
+ " i = 0.000*exp(-50t)*sin(312.2t)\n",
+ "\n",
+ "\n",
+ " Additional resistance required = 1064 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt,asin,exp,sin\n",
+ "from sympy import Symbol,solve\n",
+ "from scipy.misc import derivative\n",
+ "\n",
+ "# Given\n",
+ "C=5*10**-6 # F\n",
+ "L=2 # H\n",
+ "R=200 # ohm\n",
+ "\n",
+ "if R<2*sqrt(L/C):\n",
+ " print \"Since R<2sqrt(L/C), the circuit is originally oscillatory.\"\n",
+ "\n",
+ "\n",
+ "a=R/2/L\n",
+ "omega = sqrt(1/L/C-R**2/4/L**2) # rad/s\n",
+ "#i=Im*exp(-a*t)*sin(omega*t+fi)\n",
+ "#at t=0 sec\n",
+ "i0=0 # A\n",
+ "vc=10 # V\n",
+ "fi=asin(i0) # degree\n",
+ "#L*di/dt=vc at t=0\n",
+ "Im=Symbol('Im')\n",
+ "def current(t):\n",
+ " i=Im*exp(-a*t)*sin(omega*t+fi)\n",
+ " return i\n",
+ "#i=Im*expm(-a*t)*sin(omega*t+fi)\n",
+ "\n",
+ "\n",
+ "LdiBYdt=L*derivative(current,0)\n",
+ "#temp = coeff(LdiBYdt)\n",
+ "Im=solve(LdiBYdt,Im)[0]\n",
+ "#vc/temp(2)\n",
+ "print \"Expression for current :\\n i = %.3f*exp(-%dt)*sin(%.1ft)\"%(Im,a,omega)\n",
+ "Rn=2*sqrt(L/C) # ohm\n",
+ "Rad=Rn-R # ohm\n",
+ "print \"\\n\\n Additional resistance required = %d ohm\"%(Rad)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 16 Page 357"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 63,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Reading of hot wire instrument = 0.548 A\n",
+ "Reading of electrostatic voltmeter acroos 1000 ohm = 547 V\n",
+ "Reading of electrostatic voltmeter acroos 1 mH inductor = 353 V\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt\n",
+ "\n",
+ "# Given\n",
+ "#i=0.5+0.3*sin(omega*t)-0.2*sin(2*omega*t)\n",
+ "I0=0.5;I1m=0.3;I2m=-0.2 # from above expression\n",
+ "Iav=I0 # A\n",
+ "R=1000 # ohm\n",
+ "L=1/1000 # H\n",
+ "\n",
+ "Irms=sqrt(I0**2+(I1m/sqrt(2)**2+(I2m/sqrt(2)**2))) # A\n",
+ "print \"Reading of hot wire instrument = %.3f A\"%(Irms)\n",
+ "VR=Irms*R # V\n",
+ "print \"Reading of electrostatic voltmeter acroos 1000 ohm = %d V\"%(VR)\n",
+ "#vl_dash=L*di/dt=300*cos(w*t)-400*cos(2*w*t)\n",
+ "vl1=300;vl2=4 # V\n",
+ "vl=sqrt((300/sqrt(2))**2+(400/sqrt(2))**2)\n",
+ "print \"Reading of electrostatic voltmeter acroos 1 mH inductor = %d V\"%(vl)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 17 Page 358"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 64,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "The limit of error = 48.6 uV\n",
+ "Deflection = 8.2 mm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "R=80 # ohm\n",
+ "V=2 # V\n",
+ "l=50 # cm\n",
+ "vd=.1 # V\n",
+ "emf=1.43 # V\n",
+ "Rc=850 # ohm\n",
+ "sg=17.5 # mm/uA\n",
+ "df=1 # mm\n",
+ "\n",
+ "\n",
+ "I=R/V # A\n",
+ "Rw=vd/I # ohm (Resistance of side wire)\n",
+ "Id=df/sg*10**-6 # A (current for 1mm deflection)\n",
+ "el=1/sg*Rc # uV\n",
+ "print \"The limit of error = %.1f uV\"%(el)\n",
+ "Rw1=0.2/l*Rw # ohm (for 2cm slide wire)\n",
+ "dV=I*Rw1*1000 # mV (Change in voltage from null point)\n",
+ "r1=emf/I # ohm (tapped portion) \n",
+ "r2=r1*22.8/R # ohm\n",
+ "Ig=dV/1000/(Rc+r2) # A\n",
+ "d=dV/1000/(Rc+r2)/Id # mm\n",
+ "print \"Deflection = %.1f mm\"%(d)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 18 Page 359"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 65,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "reading of hot wire ammeter = 0.56 A\n",
+ "reading of moving coil ammeter = 0.30 A\n",
+ "\n",
+ "\n",
+ " Power taken from the mains = 83.3 W\n",
+ "Power dissipated in rectifying device = 67 W\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt\n",
+ "from sympy.mpmath import quad\n",
+ "\n",
+ "# Given\n",
+ "R=50 # ohm\n",
+ "Vrms=100 # V\n",
+ "Rd1=50 # ohm\n",
+ "Rd2=100 # ohm \n",
+ "\n",
+ "Vm=Vrms/sqrt(2) # V\n",
+ "#v=Vm*sin(theta)\n",
+ "Rf=R+Rd1 # ohm\n",
+ "Rb=R+Rd2 # ohm\n",
+ "#i_f=v/Rf # A\n",
+ "#i_b=v/Rb # A\n",
+ "Irms=1/2/pi*(quad(lambda theta:(sqrt(2)*sin(theta))**2,[0,pi])+quad(lambda theta:(sqrt(2)/3*sin(theta))**2,[pi,2*pi]))\n",
+ "Iav=1/2/pi*(quad(lambda theta:sqrt(2)*sin(theta),[0,pi])+quad(lambda theta:sqrt(2)/3*sin(theta),[pi,2*pi]))\n",
+ "print \"reading of hot wire ammeter = %.2f A\"%(Irms)\n",
+ "print \"reading of moving coil ammeter = %.2f A\"%(Iav)\n",
+ "P=1/2*(Vrms**2/Rf+Vrms**2/Rb) # W\n",
+ "print \"\\n\\n Power taken from the mains = %.1f W\"%(P)\n",
+ "Pc=Irms**2*R # W\n",
+ "Pd=P-Pc # W\n",
+ "print \"Power dissipated in rectifying device = %d W\"%(Pd)\n",
+ "#Answer wrong in the textbook."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 19 Page 361"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 66,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Required potential difference = 500 V\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt,sin\n",
+ "\n",
+ "# Given\n",
+ "d=1/100 # m\n",
+ "S=-1/100 # m\n",
+ "Ve=2 # kV\n",
+ "theta=30 # degree\n",
+ "e=1.6*10**-19 # C\n",
+ "m=9.67*10**-31 # kg\n",
+ "\n",
+ "u=sqrt(2*e*Ve*1000/m) # m/s\n",
+ "uy=u*sin(pi/180*theta) # m/s\n",
+ "vy=0 # since final velocity =0\n",
+ "#vy**2-uy**2=2*ay*S\n",
+ "ay=(vy**2-uy**2)/2/S # m**2/s\n",
+ "#ay=e/m*V/d\n",
+ "V=ay*m*d/e # V\n",
+ "print \"Required potential difference = %.f V\"%(V)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 20 Page 361"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 67,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Amplification factor, mu = -40\n",
+ "Mutual conductance, gm = 2.74 S\n",
+ "Plate resistance, ra = 14.6 kohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "#Ia=0.0004*(Va+40*Vg)**(3/2) # mA --eqn(1)\n",
+ "Va=250 # V\n",
+ "Vg=-3 # V\n",
+ "#mu=delVa/delVg\n",
+ "#differenciation wrt Vg eqn(1)\n",
+ "#(4*10**-6*3/2*(Va+40*Vg))**(1/2)*(mu+40)=0\n",
+ "mu=-40 # constant\n",
+ "print \"Amplification factor, mu = %.f\"%(mu)\n",
+ "#differenciation wrt Va eqn(1)\n",
+ "#delIa/delVa=(4*10**-6*3/2*(Va+40*Vg))**(1/2)*(0+40)\n",
+ "gm=(4*10**-6*3/2)*(Va+40*Vg)**(1/2)*(0+40)*1000 # mA/V or S\n",
+ "print \"Mutual conductance, gm = %.2f S\"%(gm)\n",
+ "#differenciation wrt Ia eqn(1) keeping Vg constant\n",
+ "#1=(4*10**-6)*3/2*(Va+40*Vg)**(1/2)*(delVa/delIa+0)\n",
+ "#ra=delVa/delIa\n",
+ "ra=1/((4*10**-6)*3/2*(Va+40*Vg)**(1/2))\n",
+ "print \"Plate resistance, ra = %.1f kohm\"%(ra/1000)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 21 Page 363"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 68,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "General equation of FM wave is:\n",
+ "v=4*sin(1.57e+08*t+25*sin(2513*t)\n",
+ "\n",
+ "\n",
+ " General equation of PM wave is:\n",
+ "v=4*sin(1.57e+08*t+25*sin(2513*t)\n",
+ "\n",
+ "\n",
+ " Now equation of FM wave is:\n",
+ "v=4*sin(1.57e+08*t+25*sin(12566*t)\n",
+ "\n",
+ "\n",
+ " Now equation of PM wave is:\n",
+ "v=4*sin(1.57e+08*t+25*sin(12566*t)\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "fc=25*10**6 # Hz\n",
+ "fm=400 # Hz\n",
+ "Vm=4 # V\n",
+ "Del=10*10**3 # Hz\n",
+ "wc=2*pi*fc # rad/s\n",
+ "wm=2*pi*fm # rad/s\n",
+ "m=Del/fm # modulation index\n",
+ "mf=m;mp=m # modulation index\n",
+ "print \"General equation of FM wave is:\"\n",
+ "print \"v=%d*sin(%.2e*t+%d*sin(%d*t)\"%(Vm,wc,mf,wm)\n",
+ "print \"\\n\\n General equation of PM wave is:\"\n",
+ "print \"v=%d*sin(%.2e*t+%d*sin(%d*t)\"%(Vm,wc,mp,wm)\n",
+ "# Changing modulating frequency\n",
+ "fm_new=2*10**3 # Hz\n",
+ "a=fm_new/fm # increase in angular frequency\n",
+ "print \"\\n\\n Now equation of FM wave is:\"\n",
+ "print \"v=%d*sin(%.2e*t+%d*sin(%d*t)\"%(Vm,wc,mf,a*wm)\n",
+ "print \"\\n\\n Now equation of PM wave is:\"\n",
+ "print \"v=%d*sin(%.2e*t+%d*sin(%d*t)\"%(Vm,wc,mp,a*wm)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 22 Page 363"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 69,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "modulation index = 0.5\n",
+ "carrier power under modulated condition = 5.06 kW\n",
+ "plate circuit efficiency = 75 percent\n",
+ "plate dissipation under unmodulated condition = 1.5 kW\n",
+ "plate dissipation under modulated condition = 1.69 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "Ebb=300 # V\n",
+ "Ibb=20 # A\n",
+ "Emm=150 # V\n",
+ "Po=4.5*10**3 # W\n",
+ "\n",
+ "m=Emm/Ebb # modulation index\n",
+ "Pbb=Ebb*Ibb\n",
+ "eta=Po/Pbb*100 # %\n",
+ "P=Po*(1+m**2/2) # W\n",
+ "Pdo=Pbb-Po # W\n",
+ "Pd=Pdo*(1+m**2/2) # W\n",
+ "print \"modulation index = %.1f\"%(m)\n",
+ "print \"carrier power under modulated condition = %0.2f kW\"%(P/1000)\n",
+ "print \"plate circuit efficiency = %.f percent\"%(eta)\n",
+ "print \"plate dissipation under unmodulated condition = %.1f kW\"%(Pdo/1000)\n",
+ "print \"plate dissipation under modulated condition = %.2f kW\"%(Pd/1000)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 23 Page 364"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 70,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Series equivalent circuit:\n",
+ "Rs = 77.7 ohm\n",
+ "Xs = 34.3 ohm\n",
+ "\n",
+ "\n",
+ " Parallel equivalent circuit:\n",
+ "Rp = 92.8 ohm\n",
+ "Xp = 211 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import cos,pi,sin\n",
+ "# Given\n",
+ "Zo=50 # ohm\n",
+ "VSWR=2 # ratio\n",
+ "#lm=0.2*lamda\n",
+ "lmBYlamda=0.2\n",
+ "betaINTOlamda=2*pi\n",
+ "rho=(VSWR-1)/(VSWR+1) # reflection coefficient\n",
+ "theta=2*betaINTOlamda*lmBYlamda # radian\n",
+ "#exp(j*theta)=cos(theta)+1J*sin(theta)\n",
+ "ZL=Zo*(1-rho*(cos(theta)+1J*sin(theta)))/(1+rho*(cos(theta)+1J*sin(theta))) # ohm\n",
+ "Rs=(ZL.real) # ohm\n",
+ "Xs=abs((ZL.imag)) # ohm(capacitive)\n",
+ "print \"Series equivalent circuit:\"\n",
+ "print \"Rs = %0.1f ohm\"%(Rs)\n",
+ "print \"Xs = %0.1f ohm\"%(Xs)\n",
+ "YL=(1/ZL)*1000 # mS\n",
+ "Rp=1000/(YL.real) # ohm\n",
+ "Xp=1000/(YL.imag) # ohm\n",
+ "print \"\\n\\n Parallel equivalent circuit:\"\n",
+ "print \"Rp = %0.1f ohm\"%(Rp)\n",
+ "print \"Xp = %0.f ohm\"%(Xp)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 24 Page 366"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 71,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "For TE10 mode:\n",
+ "cutoff wavelength = 9 cm\n",
+ "guide wavelength = 3.59 cm\n",
+ "Group velocity = 2.8e+08 m/s\n",
+ "Phase velocity = 3.2e+08 m/s\n",
+ "Characteristic wave impedence = 406 ohm\n",
+ "\n",
+ "\n",
+ " For TM11 mode:\n",
+ "cutoff wavelength = 5 cm\n",
+ "guide wavelength = 4.48 cm\n",
+ "Group velocity = 2.2e+08 m/s\n",
+ "Phase velocity = 4.0e+08 m/s\n",
+ "Characteristic wave impedence = 281 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt\n",
+ "\n",
+ "# Given\n",
+ "b=3 # cm\n",
+ "a=4.5 # cm\n",
+ "f=9*10**9 # Hz\n",
+ "v=3*10**10 # cm/s\n",
+ "lamda=v/f # cm\n",
+ "\n",
+ "print \"For TE10 mode:\"\n",
+ "m=1 # for TE10 mode\n",
+ "lamda_c = 2*a/m # cm\n",
+ "rho=sqrt(1-(lamda/lamda_c)**2)\n",
+ "lamda_g=lamda/rho # cm\n",
+ "vg=rho*v # cm/s\n",
+ "vp=v/rho # cm/s\n",
+ "ZTE=120*pi/rho # ohm\n",
+ "\n",
+ "print \"cutoff wavelength = %.f cm\"%(lamda_c)\n",
+ "print \"guide wavelength = %.2f cm\"%(lamda_g)\n",
+ "print \"Group velocity = %.1e m/s\"%(vg/100)\n",
+ "print \"Phase velocity = %.1e m/s\"%(vp/100)\n",
+ "print \"Characteristic wave impedence = %.f ohm\"%(ZTE)\n",
+ "\n",
+ "print \"\\n\\n For TM11 mode:\"\n",
+ "m=1;n=1# for TE10 mode\n",
+ "lamda_c = 2/sqrt((m/a)**2+(n/b)**2) # cm\n",
+ "rho=sqrt(1-(lamda/lamda_c)**2)\n",
+ "lamda_g=lamda/rho # cm\n",
+ "vg=rho*v # cm/s\n",
+ "vp=v/rho # cm/s\n",
+ "ZTM=120*pi*rho # ohm\n",
+ "print \"cutoff wavelength = %.f cm\"%(lamda_c)\n",
+ "print \"guide wavelength = %.2f cm\"%(lamda_g)\n",
+ "print \"Group velocity = %.1e m/s\"%(vg/100)\n",
+ "print \"Phase velocity = %.1e m/s\"%(vp/100)\n",
+ "print \"Characteristic wave impedence = %.f ohm\"%(ZTM)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 25 Page 367"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 72,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "part(a):\n",
+ "For fo>fs, the range of fo : 965 to 2065 kHz\n",
+ "frequency ratio = 2.14\n",
+ "capacitance ratio = 4.58\n",
+ "\n",
+ "\n",
+ " part(b):\n",
+ "For fo>fs, the range of fo : 35 to 1135 kHz\n",
+ "frequency ratio = 32.4\n",
+ "capacitance ratio = 1051.6\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "fs_max=1600 # kHz\n",
+ "fs_min=500 # kHz\n",
+ "IF=465 # kHz\n",
+ "\n",
+ "fr=fs_max/fs_min # ratio\n",
+ "C_ratio = fr**2 # Cs_max/Cs_min\n",
+ "#Part (a)\n",
+ "fo_min=IF+fs_min # kHz\n",
+ "fo_max=IF+fs_max # kHz\n",
+ "fr_o=fo_max/fo_min # frequency ratio for oscillator\n",
+ "C_ratio_o = fr_o**2 # Cs_max/Cs_min\n",
+ "print \"part(a):\"\n",
+ "print \"For fo>fs, the range of fo : %.f to %.f kHz\"%(fo_min,fo_max)\n",
+ "print \"frequency ratio = %.2f\"%(fr_o)\n",
+ "print \"capacitance ratio = %.2f\"%(C_ratio_o)\n",
+ "\n",
+ "#Part (b)\n",
+ "fo_min=-IF+fs_min # kHz\n",
+ "fo_max=-IF+fs_max # kHz\n",
+ "fr_o=fo_max/fo_min # frequency ratio for oscillator\n",
+ "C_ratio_o = fr_o**2 # Cs_max/Cs_min\n",
+ "print \"\\n\\n part(b):\"\n",
+ "print \"For fo>fs, the range of fo : %.f to %.f kHz\"%(fo_min,fo_max)\n",
+ "print \"frequency ratio = %.1f\"%(fr_o)\n",
+ "print \"capacitance ratio = %.1f\"%(C_ratio_o)\n",
+ "#ans wrong for part b in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 26 Page 368"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 73,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Resistor values are : \n",
+ "RL=1.60 kohm\n",
+ "Re=0.40 kohm\n",
+ "R1=55.60 kohm\n",
+ "R2=9.34 kohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "Ic=3 # mA\n",
+ "hfe=45 # unitless\n",
+ "Vcc=12 # V\n",
+ "VBE=0.5 # V\n",
+ "S=0.05 # stability factor\n",
+ "Beta=45 # unitless\n",
+ "\n",
+ "RR=Vcc/2/(Ic*10**-3) # ohm (let RL+Re=RR)\n",
+ "#Re=20% of (Re+Rl)\n",
+ "Re=RR*20/100 # ohm\n",
+ "RL=RR-Re # ohm\n",
+ "Ve=(Ic+Ic/Beta)*10**-3*Re # V\n",
+ "Vb=Ve+VBE # V\n",
+ "#S=Re/Rb=0.5 => Rb=Re/S\n",
+ "R1=Vcc*Re/S/Vb/1000 # kohm\n",
+ "# Vb/Vcc = R2/(R2+R1)\n",
+ "R2=Vb*R1/(Vcc-Vb) # kohm\n",
+ "print \"Resistor values are : \"\n",
+ "print \"RL=%.2f kohm\"%(RL/1000)\n",
+ "print \"Re=%.2f kohm\"%(Re/1000)\n",
+ "print \"R1=%.2f kohm\"%(R1)\n",
+ "print \"R2=%.2f kohm\"%(R2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 27 Page 369"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 74,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "load presented by transformer = 11.8 ohm\n",
+ "load power output = 67.6 W\n",
+ "conversion efficiency = 62.8 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "Vcc=50 # V\n",
+ "Vmin=10 # V\n",
+ "Pd=40 # W\n",
+ "\n",
+ "\n",
+ "Vo=Vcc-Vmin # V\n",
+ "K=Vo/Vcc # constant\n",
+ "Rdash=2*Vcc**2/pi/Pd*(K-pi*K**2/4) # ohm\n",
+ "Po=K**2*Vcc**2/2/Rdash # W\n",
+ "eta=pi*K/4*100 # %\n",
+ "\n",
+ "print \"load presented by transformer = %.1f ohm\"%(Rdash)\n",
+ "print \"load power output = %.1f W\"%(Po)\n",
+ "print \"conversion efficiency = %.1f percent\"%(eta)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 28 Page 370"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 75,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "for 2nd stage(CC stage)\n",
+ "current gain = 48.57\n",
+ "Input impedence = 97.14 kohm\n",
+ "Voltage gain = 1.00\n",
+ "\n",
+ "\n",
+ " for 1st stage(CE stage)\n",
+ "current gain = -47.66\n",
+ "Input impedence = 1.08 kohm\n",
+ "Voltage gain = -86.76\n",
+ "Output impedence = 68.57 kohm\n",
+ "Output impedence taking Rc1 into account = 1.94 kohm\n",
+ "\n",
+ "\n",
+ " for overall amplifier\n",
+ "Output impedence = 34.81 ohm\n",
+ "Output impedence taking Re2 into account = 33.65 ohm\n",
+ "current gain = -46.70\n",
+ "Voltage gain = -86.76\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "Rs=1000 # ohm\n",
+ "Rc1=2*1000 # ohm\n",
+ "Re2=2*1000 # ohm\n",
+ "#CE configuration\n",
+ "hie=1100 # ohm\n",
+ "hre=2.5*10**-4#\n",
+ "hfe=50#\n",
+ "hoe=25*10**-6 # s\n",
+ "#CC configuration\n",
+ "hic=1.1 # kohm\n",
+ "hrc=1#\n",
+ "hfc=-51#\n",
+ "hoc=25*10**-6 # s\n",
+ "\n",
+ "print \"for 2nd stage(CC stage)\"\n",
+ "AI2=-hfc/(1+hoe*Re2) # current gain\n",
+ "Ri2=hic+hrc*AI2*Re2 # kohm\n",
+ "Av2=AI2*Re2/Ri2 # Voltage Gain\n",
+ "print \"current gain = %0.2f\"%(AI2)\n",
+ "print \"Input impedence = %0.2f kohm\"%(Ri2/1000)\n",
+ "print \"Voltage gain = %0.2f\"%(Av2)\n",
+ "\n",
+ "print \"\\n\\n for 1st stage(CE stage)\"\n",
+ "RL1=Rc1*Ri2/(Rc1+Ri2) # kohm\n",
+ "AI1=-hfe/(1+hoe*RL1) # current gain\n",
+ "print \"current gain = %.2f\"%(AI1)\n",
+ "Ri1=hie+hre*AI1*RL1 # kohm\n",
+ "print \"Input impedence = %0.2f kohm\"%(Ri1/1000)\n",
+ "Av1=AI1*RL1/Ri1 # Voltage gain\n",
+ "print \"Voltage gain = %0.2f\"%(Av1)\n",
+ "Ro1=1/(hoe-hfe*hre/(hie+100)) # ohm\n",
+ "print \"Output impedence = %.2f kohm\"%(Ro1/1000)\n",
+ "Ro1dash=Ro1*Rc1/(Ro1+Rc1) # /ohm\n",
+ "print \"Output impedence taking Rc1 into account = %.2f kohm\"%(Ro1dash/1000)\n",
+ "\n",
+ "print \"\\n\\n for overall amplifier\"\n",
+ "Ro=1/(hoc*100-hfc*hrc/(hic+Ro1dash)) # ohm\n",
+ "print \"Output impedence = %.2f ohm\"%(Ro)\n",
+ "Rodash=Ro*Re2*1000/(Ro1+Re2*1000) # /ohm\n",
+ "print \"Output impedence taking Re2 into account = %.2f ohm\"%(Rodash)\n",
+ "AI=AI1*AI2*Rc1/(Ri2+Rc1) # current gain\n",
+ "print \"current gain = %.2f\"%(AI)\n",
+ "Av=Av1*Av2 # voltage gain\n",
+ "print \"Voltage gain = %.2f\"%(Av)\n",
+ "#answer is wrong for overall amplifier in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 29 Page 372"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 76,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Voltage gain upper BW frequency = 0.37 MHz\n",
+ "Current gain = -13.51\n",
+ "Voltage gain = -27.03\n",
+ "Voltage gain BW product = 9.90 MHz\n",
+ "Current gain BW product = 4.95 MHz\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "\n",
+ "# Given\n",
+ "fT=6*10**6 # Hz\n",
+ "hfe=50#\n",
+ "Rs=500 # ohm\n",
+ "gm=0.04 # S\n",
+ "rbb_dash=100 # ohm\n",
+ "Cc=10*10**-12 # F\n",
+ "RL=1 # kohm\n",
+ "\n",
+ "rbe=hfe/gm # ohm\n",
+ "Ce=gm/2/pi/fT # F\n",
+ "C=Ce+Cc*(1+gm*RL) # F\n",
+ "hie=rbb_dash+rbe # ohm\n",
+ "R=(Rs+rbb_dash)*rbe/((Rs+rbb_dash)+rbe) # ohm\n",
+ "f2=1/2/pi/R/C # Hz\n",
+ "print \"Voltage gain upper BW frequency = %.2f MHz\"%(f2/10**6)\n",
+ "AIS=-hfe*Rs/(Rs+hie) # current gain\n",
+ "print \"Current gain = %.2f\"%(AIS)\n",
+ "AVS=-hfe*RL*1000/(Rs+hie) # voltage gain\n",
+ "print \"Voltage gain = %.2f\"%(AVS)\n",
+ "AVSf2=AVS*f2 # Hz\n",
+ "print \"Voltage gain BW product = %.2f MHz\"%(abs(AVSf2/10**6))\n",
+ "AISf2=AIS*f2 # Hz\n",
+ "print \"Current gain BW product = %.2f MHz\"%(abs(AISf2/10**6))\n",
+ "\n",
+ "#answer in the textbook are wrong."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 30 Page 373"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 77,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "VGS=0.05 V\n",
+ "gm = -13.23 mS\n",
+ "Rs = -49 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi,sqrt\n",
+ "\n",
+ "# Given\n",
+ "VP=-2 # V\n",
+ "IDSS=1.75/1000 # A\n",
+ "VDD=24 # V\n",
+ "ID=1/1000 # A\n",
+ "VP=0.2 # V (pinch off voltage)\n",
+ "\n",
+ "VGS=(1-sqrt(ID/IDSS))*VP # V\n",
+ "gmo=-2*IDSS/VP # S\n",
+ "gm=gmo*(1-VGS/VP) # S\n",
+ "Rs=-VGS/ID # ohm\n",
+ "\n",
+ "print \"VGS=%.2f V\"%(VGS)\n",
+ "print \"gm = %.2f mS\"%(gm*1000)\n",
+ "print \"Rs = %.f ohm\"%(Rs)\n",
+ "#Ans are wrong in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 31 Page 374"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 78,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Bandwidth of redesigned aplifier, BW=101 kHz\n"
+ ]
+ }
+ ],
+ "source": [
+ "from math import sqrt\n",
+ "from __future__ import division\n",
+ "# Given\n",
+ "G=37 # dB\n",
+ "f1=50 # Hz\n",
+ "f2=18.7*1000 # Hz\n",
+ "BW1=f2 # Hz (f2-f1~=f2)\n",
+ "\n",
+ "\n",
+ "A1=10**(G/20) # Gain\n",
+ "A3=sqrt(A1) # Gain\n",
+ "RL1BYRL2=A1/A3 # ratio\n",
+ "RL2BYRL1=A3/A1 # ratio\n",
+ "#BW=2*pi*Cd*RL\n",
+ "BW1BYBW2=RL2BYRL1#\n",
+ "BW2BYBW1=RL1BYRL2#\n",
+ "f2dash=f2*sqrt(sqrt(2)-1)#\n",
+ "BW2=BW2BYBW1*f2dash # Hz\n",
+ "print \"Bandwidth of redesigned aplifier, BW=%.f kHz\"%(BW2/1000)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 32 Page 375"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 79,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "ripple factor = 0.4 percent\n",
+ "Critical inductance, Lc=8.5 H\n"
+ ]
+ }
+ ],
+ "source": [
+ "from math import sqrt\n",
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "L=30 # H\n",
+ "C=10*10**-6 # F\n",
+ "RL=8*10**3 # ohm\n",
+ "f=50 # Hz\n",
+ "\n",
+ "r=sqrt(2)/12/(2*pi*f)**2/L/C*100 # %\n",
+ "Lc=2*RL/6/(2*pi*f) # H\n",
+ "print \"ripple factor = %.1f percent\"%(r)\n",
+ "print \"Critical inductance, Lc=%.1f H\"%(Lc)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 33 Page 376"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 80,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Current supplied by the main generator = 7000 A\n",
+ "Current supplied on +ve side = 6000 A\n",
+ "Current supplied on -ve side = 8000 A\n",
+ "out-off balance Current = 2000 A\n",
+ "Current in each armature = 1000 A\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "# Given\n",
+ "V=500 # V\n",
+ "Pp=1500*10**3 # W (+ve side)\n",
+ "Pn=2000*10**3 # W (-ve side)\n",
+ "\n",
+ "P=Pp+Pn # W\n",
+ "I=P/V # A\n",
+ "Ip=Pp/(V/2) # A\n",
+ "In=Pn/(V/2) # A\n",
+ "Iob=In-Ip # A\n",
+ "Ia=Iob/2 # A\n",
+ "print \"Current supplied by the main generator = %.f A\"%(I)\n",
+ "print \"Current supplied on +ve side = %.f A\"%(Ip)\n",
+ "print \"Current supplied on -ve side = %.f A\"%(In)\n",
+ "print \"out-off balance Current = %.f A\"%(Iob)\n",
+ "print \"Current in each armature = %.f A\"%(Ia)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 34 Page 377"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 81,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "regulation = 17 percent\n",
+ "Efficiency = 94 percent\n",
+ "\n",
+ "\n",
+ " regulation = 13.4 percent\n",
+ "Efficiency = 96 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "l=20 # km\n",
+ "P=10000 # kW\n",
+ "V=11 # kV\n",
+ "pf=0.707 # lagging\n",
+ "R=0.02 # ohm/km/phase\n",
+ "X=0.07 # ohm/km/phase\n",
+ "\n",
+ "#for pf = 0.707\n",
+ "\n",
+ "IL=P*10**3/sqrt(3)/(V*1000)/pf # A\n",
+ "VRphase=V*1000/sqrt(3) # V\n",
+ "R_phase=l*R # ohm\n",
+ "X_phase=l*X # ohm\n",
+ "Z_phase=R_phase+1J*X_phase # ohm\n",
+ "Vd_phase=IL*(pf-1J*pf)*Z_phase # V\n",
+ "VS=(Vd_phase+VRphase) # V\n",
+ "regulation=(VS-VRphase)/VRphase*100 # %\n",
+ "print \"regulation = %.f percent\"%abs(regulation)\n",
+ "PL=3*IL**2*R_phase/1000 # kW\n",
+ "Po=P+PL # kW\n",
+ "eta=P/Po*100 # %\n",
+ "print \"Efficiency = %.f percent\"%(eta)\n",
+ "\n",
+ "#for pf2=0.9 # lagging\n",
+ "pf=0.9 # lagging\n",
+ "IL=P*10**3/sqrt(3)/(V*1000)/pf # A\n",
+ "VRphase=V*1000/sqrt(3) # V\n",
+ "R_phase=l*R # ohm\n",
+ "X_phase=l*X # ohm\n",
+ "Z_phase=R_phase+1J*X_phase # ohm\n",
+ "Vd_phase=IL*(pf-1J*.435)*Z_phase # V\n",
+ "VS=(Vd_phase+VRphase) # V\n",
+ "regulation=(VS-VRphase)/VRphase*100 # %\n",
+ "print \"\\n\\n regulation = %.1f percent\"%abs(regulation)\n",
+ "PL=3*IL**2*R_phase/1000 # kW\n",
+ "Po=P+PL # kW\n",
+ "eta=P/Po*100 # %\n",
+ "print \"Efficiency = %.f percent\"%(eta)\n",
+ "#ans wrong for 2nd part in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 35 Page 378"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 82,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "lamp1 : Total cost/hour = 0.488 paise\n",
+ "lamp2 : Total cost/hour = 0.61 paise\n",
+ "on comparing cost it is clear lamp1 will be more economical. \n",
+ "\n",
+ "\n",
+ " load factor = 28 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "C1=1.2 # Rs\n",
+ "C2=5 # Rs\n",
+ "P1=100 # W\n",
+ "P2=30 # W\n",
+ "t=1000 # hours\n",
+ "Ce=60 # Rs/kW/annum for max demand\n",
+ "Cee=3 # paise/unit for extra\n",
+ "\n",
+ "#first lamp\n",
+ "Cl1=C1*100/t # paise / hour\n",
+ "dmax1=P1/1000 # kW/hour\n",
+ "Cmax1=Ce*100*dmax1/(24*365) # paise/hour\n",
+ "CE1=Cee*dmax1 # /paise / hour\n",
+ "CT1=Cl1+Cmax1+CE1 # paise (total cost per hour)\n",
+ "print \"lamp1 : Total cost/hour = %.3f paise\"%(CT1)\n",
+ "#second lamp\n",
+ "Cl2=C2*100/t # paise / hour\n",
+ "dmax2=P2/1000 # kW/hour\n",
+ "Cmax2=Ce*100*dmax2/(24*365) # paise/hour\n",
+ "CE2=Cee*dmax2 # /paise / hour\n",
+ "CT2=Cl2+Cmax2+CE2 # paise (total cost per hour)\n",
+ "print \"lamp2 : Total cost/hour = %.2f paise\"%(CT2)\n",
+ "print \"on comparing cost it is clear lamp1 will be more economical. \"\n",
+ "#let load factor = x\n",
+ "#Cl1+Cmax1/x+CE1=Cl2+Cmax2/x+CE2\n",
+ "x=(Cmax1-Cmax2)/(Cl2+CE2-Cl1-CE1)*100 # % load factor\n",
+ "print \"\\n\\n load factor = %.f percent\"%(x)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 36 Page 379"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 83,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "(a) extra shunt field turns required = 104\n",
+ "(b) extra shunt field turns required = 52\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "p=4 # pole\n",
+ "I1=143 # A\n",
+ "Z=492 # armature conductors\n",
+ "theta=10 # degree\n",
+ "I2=10 # A\n",
+ "\n",
+ "Ia=I1+I2 # A\n",
+ "Iw=Ia/2 # A for wave sound\n",
+ "Il=Ia/4 # for lap sound\n",
+ "#part(a)\n",
+ "ATw=Z*Iw*theta/360 # AT\n",
+ "nw=ATw/theta # turns \n",
+ "print \"(a) extra shunt field turns required = %d\"%(nw)\n",
+ "\n",
+ "#part(b)\n",
+ "ATl=Z*Il*theta/360 # AT\n",
+ "nl=ATl/theta # turns \n",
+ "print \"(b) extra shunt field turns required = %d\"%(nl)\n",
+ "#answer wrong for part(a) in the boko."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 37 Page 380"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 84,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "New speed will be 570 rpm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import roots\n",
+ "# Given\n",
+ "Wh=250 # W\n",
+ "We=100 # W\n",
+ "N=1000/60 # rps\n",
+ "\n",
+ "A=Wh/N # constant\n",
+ "B=We/N**2 # constant\n",
+ "Wnew=1/2*(Wh+We) # W\n",
+ "#Wnew=A*N1+B*N1**2\n",
+ "p=[B,A,-Wnew] # polynomial for N1\n",
+ "N1=roots(p) # rps\n",
+ "N1=N1[1]*60 # rpm#discarding -ve vealue\n",
+ "print \"New speed will be %.f rpm\"%(N1)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 38 Page 381"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 85,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Speed of the machine running as shunt motor = 381 rpm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "P=50 # kW\n",
+ "V=250#V\n",
+ "N1=400 # rpm\n",
+ "Ra=0.02 # ohm\n",
+ "Rf=50 # ohm\n",
+ "Pi=50 # kW\n",
+ "Vin=250 # V\n",
+ "Vd=1 # V per Brush\n",
+ "\n",
+ "I=P*10**3/V#A\n",
+ "Ish=V/Rf # A\n",
+ "Ia=I+Ish # A\n",
+ "Va=Ia*Ra # V\n",
+ "Vbd=2*Vd # V\n",
+ "Eb1=V+Va+Vbd # V\n",
+ "\n",
+ "\n",
+ "#as motor\n",
+ "I=P*10**3/V#A\n",
+ "Ish=V/Rf # A\n",
+ "Ia=I-Ish # A\n",
+ "\n",
+ "Va=Ia*Ra # V\n",
+ "Vbd=2*Vd # V\n",
+ "Eb2=V-Va-Vbd # V\n",
+ "N2=(Eb2/Eb1)*N1 # rpm\n",
+ "print \"Speed of the machine running as shunt motor = %.f rpm\"%(N2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 39 Page 383"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 86,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Motor efficiency = 92 percent\n",
+ "Generator efficiency = 92 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "VL=250 # V\n",
+ "Is=50 # A\n",
+ "Ia=380 # A\n",
+ "If1=5 # A\n",
+ "If2=4.2 # A\n",
+ "ra=0.02 # ohm\n",
+ "\n",
+ "#Machine Losses:\n",
+ "ma_cu_loss=Ia**2*ra # W (motor armature cu loss)\n",
+ "ga_cu_loss=(Ia-Is)**2*ra # W (generator armature cu loss)\n",
+ "P=VL*Is # W\n",
+ "stray_loss=P-ma_cu_loss-ga_cu_loss # W\n",
+ "stray_loss_per_machine=stray_loss/2 # W\n",
+ "\n",
+ "#Motor efficiency\n",
+ "field_cu_loss=VL*If2 # W\n",
+ "total_loss=ma_cu_loss+field_cu_loss+stray_loss_per_machine # W\n",
+ "Pin_motor=(VL*Ia)+(VL*ra) # W\n",
+ "Pout_motor=Pin_motor-total_loss # W\n",
+ "Eff=Pout_motor/Pin_motor*100 # %\n",
+ "print \"Motor efficiency = %.f percent\"%(Eff)\n",
+ "\n",
+ "\n",
+ "#Generator efficiency\n",
+ "field_cu_loss=VL*If1 # W\n",
+ "total_loss=ga_cu_loss+field_cu_loss+stray_loss_per_machine # W\n",
+ "Pout_generator=VL*(Ia-Is) # W\n",
+ "Pin_generator=Pout_generator+total_loss # W\n",
+ "Eff=Pout_motor/Pin_motor*100 # %\n",
+ "print \"Generator efficiency = %.f percent\"%(Eff)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 40 Page 384"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 87,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Full load efficiency : \n",
+ "at unity power factor = 96.8 percent\n",
+ "at 0.8 power factor = 96.0 percent\n",
+ "\n",
+ "\n",
+ " Voltage drop at unity pf = 393.8 V\n",
+ "Voltage drop at 0.8 pf lagging = 384.0 V\n",
+ "Voltage drop at 0.8 pf leading = 406 V\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "KVA=4 # kVA\n",
+ "V1=200#V\n",
+ "V2=400#V\n",
+ "f=50 # Hz\n",
+ "Io1=0.8 # A\n",
+ "P1=70 # W\n",
+ "Vs2=17.5 # V\n",
+ "Is2=9 # A\n",
+ "P2=50 # W\n",
+ "\n",
+ "#full load\n",
+ "I_loss=P1 # W\n",
+ "I2=KVA*1000/V2 # A\n",
+ "Cu_loss=(I2/Is2)**2*P2 # W\n",
+ "Zo2=Vs2/Is2 # ohm\n",
+ "Ro2=P2/Is2**2 # ohm\n",
+ "Xo2=sqrt(Zo2**2-Ro2**2) # ohm\n",
+ "\n",
+ "#(a) \n",
+ "print \"Full load efficiency : \"\n",
+ "#unity pf\n",
+ "pf=1 # power factor\n",
+ "Output=KVA*pf # kW\n",
+ "Losses=Cu_loss+I_loss # W\n",
+ "eta=Output*1000/(Output*1000+Losses)*100 # %\n",
+ "print \"at unity power factor = %.1f percent\"%(eta)\n",
+ "#0.8 pf\n",
+ "pf=0.8 # power factor\n",
+ "Output=KVA*pf # kW\n",
+ "eta=Output*1000/(Output*1000+Losses)*100 # %\n",
+ "print \"at 0.8 power factor = %.1f percent\"%(eta)\n",
+ "\n",
+ "#(b)\n",
+ "#(i) unity pf\n",
+ "Vd=I2*Ro2 # V\n",
+ "V22=V2-Vd # V\n",
+ "print \"\\n\\n Voltage drop at unity pf = %.1f V\"%(V22)\n",
+ "#(i) 0.8 pf lagging\n",
+ "pf=0.8 # power factor\n",
+ "Vd=I2*(Ro2*pf+Xo2*sqrt(1-pf**2)) # V\n",
+ "V22=V2-Vd # V\n",
+ "print \"Voltage drop at 0.8 pf lagging = %.1f V\"%(V22)\n",
+ "#(i) 0.8 pf leading\n",
+ "pf=0.8 # power factor\n",
+ "Vd=I2*(Ro2*pf-Xo2*sqrt(1-pf**2)) # V\n",
+ "V22=V2-Vd # V\n",
+ "print \"Voltage drop at 0.8 pf leading = %.f V\"%(V22)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 41 Page 385"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 88,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "All day efficiency = 97 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "KVA=15 # kVA\n",
+ "pf=1#\n",
+ "eff=98/100 # efficiency\n",
+ "\n",
+ "L1=2 # kW\n",
+ "pf1=0.5 # lagging\n",
+ "t1=12 # hours\n",
+ "L2=12 # kW\n",
+ "pf2=0.8 # lagging\n",
+ "t2=6 # hours\n",
+ "L3=18 # kW\n",
+ "pf3=0.9 # lagging\n",
+ "t3=6 # hours\n",
+ "\n",
+ "Po=KVA*pf # kW\n",
+ "Pin=Po/eff # kW\n",
+ "Losses=Pin-Po # kW\n",
+ "Cu_loss=Losses/2 # kW\n",
+ "I_loss=Losses/2 # kW\n",
+ "\n",
+ "KVA1=L1/pf1 # kVA\n",
+ "KVA2=L2/pf2 # kVA\n",
+ "KVA3=L3/pf3 # kVA\n",
+ "Cu_loss1=Cu_loss*(KVA1/KVA2)**2 # kW\n",
+ "Cu_loss2=Cu_loss*(KVA2/KVA2)**2 # kW\n",
+ "Cu_loss3=Cu_loss*(KVA3/KVA2)**2 # kW\n",
+ "\n",
+ "Cu_loss_t1=Cu_loss1*t1 # kW\n",
+ "Cu_loss_t2=Cu_loss2*t2 # kW\n",
+ "Cu_loss_t3=Cu_loss3*t3 # kW\n",
+ "Cu_loss_total=Cu_loss_t1+Cu_loss_t2+Cu_loss_t3 # kW\n",
+ "I_loss24=I_loss*24 # Wh\n",
+ "\n",
+ "Po24=L1*t1+L2*t2+L3*t3 # kWh\n",
+ "Pi24=Po24+Cu_loss_total+I_loss24 # kWh\n",
+ "eff_allday=Po24/Pi24*100 # %\n",
+ "print \"All day efficiency = %.f percent\"%(eff_allday)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 42 Page 386"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 89,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Current drawn by the transformer=42.67 A\n",
+ "power factor = 0.9 lagging\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "V1=250 # V\n",
+ "V2=150 # V\n",
+ "Vs1=200 # V\n",
+ "Load1=5 # kW\n",
+ "pf1=0.8 # lagging\n",
+ "Load2=2 # kW\n",
+ "pf2=1 # unity\n",
+ "Vs2=100 # V\n",
+ "\n",
+ "I1=Load1*1000/V1/pf1 # A\n",
+ "t1_ratio=V1/Vs1 # \n",
+ "Ip1=I1*t1_ratio # A at 0.8 pf (current drawn by primary)\n",
+ "\n",
+ "I2=Load2*1000/Vs2/pf2 # A\n",
+ "t2_ratio=Vs2/V2 # \n",
+ "Ip2=I2*t2_ratio # A at 0.8 pf (current drawn by primary)\n",
+ "\n",
+ "Ipx=Ip1*pf1+Ip2 # A\n",
+ "Ipy=Ip1*sqrt(1-pf1**2) # A\n",
+ "I3=sqrt(Ipx**2+Ipy**2) # A\n",
+ "print \"Current drawn by the transformer=%.2f A\"%(I3)\n",
+ "pf=Ipx/I3 # power factor\n",
+ "print \"power factor = %.1f lagging\"%(pf)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 43 Page 387"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 90,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Percentage reduction in stator voltage = 23 percent\n",
+ "power factor = 0.3\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt,atan,cos\n",
+ "# Given\n",
+ "R2=0.03 # ohm\n",
+ "X2=0.18 # ohm\n",
+ "Ns=100 # rpm\n",
+ "s1=3 # %\n",
+ "\n",
+ "\n",
+ "Nfl=(100-s1) # rpm (full load speed)\n",
+ "N2=Nfl/2 # rpm\n",
+ "s2=(Ns-N2)/Ns*100 # %\n",
+ "V1BYV2=sqrt(s2/s1*(R2**2+(s1/100*X2)**2)/(R2**2+(s2/100*X2)**2)) # from torque equation\n",
+ "#let V1=V12BYV1 V2=1\n",
+ "V1=V1BYV2 # V\n",
+ "V2=1 # V\n",
+ "V12BYV1=(V1-1)/V1*100 # % reduction in the stator (V12=V1-V2)\n",
+ "print \"Percentage reduction in stator voltage = %.f percent\"%(V12BYV1)\n",
+ "fi=atan(s2/100*X2/R2) # radian\n",
+ "pf=cos(fi) # power factor\n",
+ "print \"power factor = %.1f\"%(pf)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 44 Page 388"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 91,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "(a) at standstill, To:Ti = 40:1\n",
+ "(b) at s=0.05, To:Ti = 0.4:1\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "\n",
+ "# Given\n",
+ "zo=1+1J*1 # ohm\n",
+ "zi=0.2+1J*4 # ohm\n",
+ "Ri=zi.real # ohm\n",
+ "Ro=(zo).real # ohm\n",
+ "\n",
+ "#at standstill\n",
+ "s=1 # % at standstill\n",
+ "Zo=sqrt((zo).real**2+(zo).imag**2) # ohm\n",
+ "Zi=sqrt((zi).real**2+(zi).imag**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"(a) at standstill, To:Ti = %d:1\"%(ToBYTi)\n",
+ "\n",
+ "#at s=0.5\n",
+ "s=0.05 # %\n",
+ "Zo=sqrt((zo).real**2/s**2+(zo).imag**2) # ohm\n",
+ "Zi=sqrt((zi).real**2/s**2+(zi).imag**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"(b) at s=0.05, To:Ti = %.1f:1\"%(ToBYTi)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 45 Page 389"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 92,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "no. of turns in primary = 582\n",
+ "no. of turns in secondary = 18\n",
+ "\n",
+ "cross section of primary winding=5.24e-04 m**2\n",
+ "cross section of secondary winding=1.7e-05 m**2\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "Edc=500 # V\n",
+ "fim=.085 # Wb\n",
+ "f=50 # Hz\n",
+ "E1=11000 # V\n",
+ "P=1500 # kW\n",
+ "p=8 # pole\n",
+ "pf=0.9\n",
+ "V=500 # V\n",
+ "J=3 # A/mm**2\n",
+ "\n",
+ "E2=Edc/sqrt(2)#V\n",
+ "N2=E2/4.44/f/fim # no. of turns\n",
+ "N1=E1/E2*N2 # no. of turns\n",
+ "print \"no. of turns in primary = %d\"%(N1)\n",
+ "print \"no. of turns in secondary = %d\"%(N2)\n",
+ "Idc=P*10**3/V # A\n",
+ "eta=1 # because of no loss\n",
+ "ISR=0.472*Idc/(eta*pf)\n",
+ "A1=ISR/J*10**-6 # m**2 (cross section area)\n",
+ "I1=N2/N1*ISR # A\n",
+ "A2=I1/J*10**-6 # m**2 (cross section area of primary winding)\n",
+ "print \"\\ncross section of primary winding=%.2e m**2\"%(A1)\n",
+ "print \"cross section of secondary winding=%.1e m**2\"%(A2)\n",
+ "#ans in the book are not accurate."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 46 Page 391"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 93,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Suitable auto transformation ratio = 77.5\n",
+ "Starting torque Tst = 15 percent of full-load torque\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "\n",
+ "# Given\n",
+ "IscBYIfl=5 # as Isc=5*Ifl\n",
+ "ILByIfl=3 # as IL <= 3*Ifl\n",
+ "sf=5 # %\n",
+ "\n",
+ "#IL=K**2*ISC\n",
+ "#dividing by Ifl\n",
+ "K=sqrt(ILByIfl/IscBYIfl)*100 # %\n",
+ "TstBYTf=(K/100)**2*IscBYIfl*sf/100*100 # % #ratio of torque\n",
+ "print \"Suitable auto transformation ratio = %.1f\"%(K)\n",
+ "print \"Starting torque Tst = %.f percent of full-load torque\"%(TstBYTf)\n",
+ "#ans wrong in the textbook."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 47 Page 391"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 94,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "no of studs = 5 and no. of section = 4\n",
+ "\n",
+ "Resistance of 1st section = 2.24 ohm\n",
+ "Resistance of 2nd section = 1.49 ohm\n",
+ "Resistance of 3rd section = 0.99 ohm\n",
+ "Resistance of 4th section = 0.68 ohm\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import log\n",
+ "\n",
+ "# Given\n",
+ "V=500 # V\n",
+ "ns=60 # slots\n",
+ "nc=20 # conductor/slot\n",
+ "ra=1.31 # ohm\n",
+ "Tmax=218 # N-m\n",
+ "fi=23*10**-3 # Wb\n",
+ "\n",
+ "Tmin=Tmax/1.5#N-m\n",
+ "Z=ns*nc # no of conductors\n",
+ "Ia=Tmax/(.159*fi*Z) # A\n",
+ "Imax=1.5*Ia # A\n",
+ "I1=Imax # A\n",
+ "I2=Ia # A\n",
+ "R1=V/I1 # ohm\n",
+ "n= log(R1/ra)/log(I1/I2)+1 # no of studs\n",
+ "N=n-1 # no of section\n",
+ "print \"no of studs = %d and no. of section = %d\"%(n,N)\n",
+ "R2=R1*(I2/I1) # ohm\n",
+ "R3=R2*(I2/I1) # ohm\n",
+ "R4=R3*(I2/I1) # ohm\n",
+ "R1s=R1-R2 # ohm\n",
+ "R2s=R2-R3 # ohm\n",
+ "R3s=R3-R4 # ohm\n",
+ "R4s=R4-ra # ohm\n",
+ "print \"\\nResistance of 1st section = %.2f ohm\"%(R1s)\n",
+ "print \"Resistance of 2nd section = %.2f ohm\"%(R2s)\n",
+ "print \"Resistance of 3rd section = %.2f ohm\"%(R3s)\n",
+ "print \"Resistance of 4th section = %.2f ohm\"%(R4s)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 48 Page 393"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 95,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "temperature rise after 2 hours full load = 55 degree C\n",
+ "temperature rise of cold water after 1 hour = 28 degree C\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import log,exp\n",
+ "\n",
+ "# Given\n",
+ "theta1=20 # degree C\n",
+ "theta2=35 # degree C\n",
+ "t1=0.5 # hour\n",
+ "t2=1 # hour\n",
+ "theta_m_dashBYthetam=80/100 # temperature rise\n",
+ "\n",
+ "#theta=theta_m*(1-e**(-t/alfa))\n",
+ "#theta1/theta2=(1-exp(-t1/alfa))/(1-exp(-t2/alfa))\n",
+ "ee1=theta2/theta1-1 # let ee1=exp(-1/2/alfa)\n",
+ "theta_m=theta1/(1-ee1) # degree C\n",
+ "theta_2=theta_m*(1-ee1**4) # degree C (after 2 hours)\n",
+ "print \"temperature rise after 2 hours full load = %.f degree C\"%(theta_2)\n",
+ "alfa=-1/2/log(ee1) # hour\n",
+ "alfa_dash=theta_m_dashBYthetam*alfa # hour\n",
+ "theta_m_dash=theta_m_dashBYthetam*theta_m\n",
+ "theta_dash=theta_m_dash*(1-exp(-t2/alfa))\n",
+ "print \"temperature rise of cold water after 1 hour = %.f degree C\"%(theta_dash)\n",
+ "#ans of 2nd part is wrong in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 49 Page 394"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 96,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Regulation at no load voltage = 6.7 percent\n",
+ "Regulation at full load voltage = 7.2 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt,cos,pi,sin\n",
+ "\n",
+ "# Given\n",
+ "u=30 # degree \n",
+ "m=3 # no of phases\n",
+ "\n",
+ "#Id=sqrt(2)*Vs*X*(1-cosd(u))*sin(pi/m)\n",
+ "IdBYVs_dash=m/2/pi*(1-cos(pi/180*u))*sin(pi/m)*sqrt(2) # load current/Vs\n",
+ "#where IdBYVs_dash = m/pi*IdX/2\n",
+ "EdoBYVs=sqrt(2)*m/pi*sin(pi/m) # dc output voltage/Vs with no overlap\n",
+ "EduBYVs=EdoBYVs-IdBYVs_dash # dc output voltage/Vs with overlap\n",
+ "#part (a)\n",
+ "Reg1=(EdoBYVs-EduBYVs)/EdoBYVs*100 # % (regulation)\n",
+ "print \"Regulation at no load voltage = %.1f percent\"%(Reg1)\n",
+ "#part (b)\n",
+ "Reg2=(EdoBYVs-EduBYVs)/EduBYVs*100 # % (regulation)\n",
+ "print \"Regulation at full load voltage = %.1f percent\"%(Reg2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 50 Page 395"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 97,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Current for each machine = 370 A & 1630 A \n",
+ "Power output for each machine = 162.3 kW & 716.3 kW\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from numpy import array\n",
+ "# Given\n",
+ "I12=2000 # A (I12=I1+I2)\n",
+ "R1=0.04 # ohm\n",
+ "R2=0.025 # ohm\n",
+ "rf1=25 # ohm\n",
+ "rf2=20 # ohm\n",
+ "E1=440 # V\n",
+ "E2=420 # V\n",
+ "\n",
+ "#E-Vad=V where Vad=I1+V/rf1\n",
+ "#V*(1+R1/rf1)+R1*I1=E1#eqn(1)\n",
+ "#V*(1+R2/rf2)-I1*R2=E2-I12*R2# eqn(2)\n",
+ "A=array([[(1+R1/rf1),R1],[(1+R2/rf2),-R2]])# # matrix for solution\n",
+ "B=array([[E1],[E2-I12*R2]]) # matrix for solution\n",
+ "X=A**-1*B # solution\n",
+ "V=X[0,0] # V\n",
+ "I1=X[1,0] # A\n",
+ "I2=I12-I1 # A\n",
+ "print \"Current for each machine = %.f A & %.f A \"%(I1,I2)\n",
+ "Po1=V*I1 # W\n",
+ "Po2=V*I2 # W\n",
+ "print \"Power output for each machine = %.1f kW & %.1f kW\"%(Po1/1000,Po2/1000)\n",
+ "#ans in the book are wrong."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 51 Page 396"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 98,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "pf transformer A = 0.82 lag\n",
+ "pf transformer B = 0.78 lag\n",
+ "power output transformer A = 6535 W\n",
+ "power output transformer B = 4925 W\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import atan,pi,cos,degrees\n",
+ "# Given\n",
+ "ZA=0.15+0.5*1J # ohm\n",
+ "ZB=0.1+0.6*1J # ohm\n",
+ "EA=207 # V\n",
+ "EB=205 # V\n",
+ "ZL=2+1.5*1J # ohm\n",
+ "\n",
+ "IA=(EA*ZB+(EA-EB)*ZL)/(ZA*ZB+ZL*(ZA+ZB)) # A\n",
+ "IB=(EB*ZA-(EA-EB)*ZL)/(ZA*ZB+ZL*(ZA+ZB)) # A\n",
+ "V2=(IA+IB)*ZL # V\n",
+ "fi_A=degrees(atan((V2).imag/(V2).real)-(atan((IA.imag)/(IA.real))))\n",
+ "pf_A=cos(pi/180*fi_A) # lag\n",
+ "print \"pf transformer A = %.2f lag\"%(pf_A)\n",
+ "fi_B=degrees(atan((V2.imag)/(V2.real))-(atan((IB.imag)/(IB.real))))\n",
+ "pf_B=cos(pi/180*fi_B) # lag\n",
+ "print \"pf transformer B = %.2f lag\"%(pf_B)\n",
+ "PA=abs(V2*IA*pf_A) # W\n",
+ "print \"power output transformer A = %.f W\"%(PA)\n",
+ "PB=abs(V2*IB*pf_B) # W\n",
+ "print \"power output transformer B = %.f W\"%(PB)\n",
+ "#Power output ans are wrong in the book."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 52 Page 397"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 99,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "filament length = 1.26 m\n",
+ "filament diameter = 20 um\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "# Given\n",
+ "d1=0.05*10**-3 # mm\n",
+ "l1=100*10**-2 # m\n",
+ "i2BYi1=1/4 # current ratio\n",
+ "#(d2/d1)**(3/2)=i2BYi1\n",
+ "d2=(i2BYi1)**(2/3)*d1*10**6 # um\n",
+ "l2=1/2*l1*d1/d2*10**6 # m\n",
+ "print \"filament length = %.2f m\"%(l2)\n",
+ "print \"filament diameter = %.f um\"%(d2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 53 Page 398"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 100,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "filament length = 1.6 m\n",
+ "filament diameter = 48 um\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "# Given\n",
+ "d1=0.10*10**-3 # mm\n",
+ "l1=150*10**-2 # m\n",
+ "i2BYi1=1/3 # current ratio\n",
+ "#(d2/d1)**(3/2)=i2BYi1\n",
+ "d2=(i2BYi1)**(2/3)*d1*10**6 # um\n",
+ "l2=1/2*l1*d1/d2*10**6 # m\n",
+ "print \"filament length = %.1f m\"%(l2)\n",
+ "print \"filament diameter = %.f um\"%(d2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 54 Page 398"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 101,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "(a) at standstill, To:Ti = 8:1\n",
+ "(b) at s=0.05, To:Ti = 3:10\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "zo=2+1J*2 # ohm\n",
+ "zi=0.5+1J*4 # ohm\n",
+ "Ri=(zi).real # ohm\n",
+ "Ro=(zo).real # ohm\n",
+ "\n",
+ "#at standstill\n",
+ "s=1 # % at standstill\n",
+ "Zo=sqrt((zo.real)**2+(zo.imag)**2) # ohm\n",
+ "Zi=sqrt((zi.real)**2+(zi.imag)**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"(a) at standstill, To:Ti = %d:1\"%(ToBYTi)\n",
+ "\n",
+ "#at s=0.5\n",
+ "s=0.05 # %\n",
+ "Zo=sqrt((zo.real)**2/s**2+(zo.imag)**2) # ohm\n",
+ "Zi=sqrt((zi.real)**2/s**2+(zi.imag)**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"(b) at s=0.05, To:Ti = %.f:10\"%(ToBYTi*10)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 55 Page 400"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 102,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "no. of turns in primary = 415\n",
+ "no. of turns in secondary = 12\n",
+ "\n",
+ "cross section of primary winding=6.56e-04 m**2\n",
+ "cross section of secondary winding=1.9e-05 m**2\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "\n",
+ "# Given\n",
+ "Edc=250 # V\n",
+ "fim=.065 # Wb\n",
+ "f=50 # Hz\n",
+ "E1=6000 # V\n",
+ "P=1500 # kW\n",
+ "p=8 # pole\n",
+ "pf=0.9\n",
+ "V=400 # V\n",
+ "J=3 # A/mm**2\n",
+ "\n",
+ "E2=Edc/sqrt(2)#V\n",
+ "N2=E2/4.44/f/fim # no. of turns\n",
+ "N1=E1/E2*N2 # no. of turns\n",
+ "print \"no. of turns in primary = %d\"%(N1)\n",
+ "print \"no. of turns in secondary = %d\"%(N2)\n",
+ "Idc=P*10**3/V # A\n",
+ "eta=1 # because of no loss\n",
+ "ISR=0.472*Idc/(eta*pf)\n",
+ "A1=ISR/J*10**-6 # m**2 (cross section area)\n",
+ "I1=N2/N1*ISR # A\n",
+ "A2=I1/J*10**-6 # m**2 (cross section area of primary winding)\n",
+ "print \"\\ncross section of primary winding=%.2e m**2\"%(A1)\n",
+ "print \"cross section of secondary winding=%.1e m**2\"%(A2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 56 Page 400"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 103,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Suitable auto transformation ratio = 86.6\n",
+ "Starting torque Tst = 12 percent of full-load torque\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "IscBYIfl=4 # as Isc=5*Ifl\n",
+ "ILByIfl=3 # as IL <= 3*Ifl\n",
+ "sf=4 # %\n",
+ "\n",
+ "#IL=K**2*ISC\n",
+ "#dividing by Ifl\n",
+ "K=sqrt(ILByIfl/IscBYIfl)*100 # %\n",
+ "TstBYTf=(K/100)**2*IscBYIfl*sf/100*100 # % #ratio of torque\n",
+ "print \"Suitable auto transformation ratio = %.1f\"%(K)\n",
+ "print \"Starting torque Tst = %.f percent of full-load torque\"%(TstBYTf)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 57 Page 401"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 104,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "temperature rise after 2 hours full load = 56 degree C\n",
+ "temperature rise of cold water after 1 hour = 27 degree C\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import log,exp\n",
+ "# Given\n",
+ "theta1=30 # degree C\n",
+ "theta2=45 # degree C\n",
+ "t1=0.5 # hour\n",
+ "t2=1 # hour\n",
+ "theta_m_dashBYthetam=60/100 # temperature rise\n",
+ "\n",
+ "#theta=theta_m*(1-e**(-t/alfa))\n",
+ "#theta1/theta2=(1-exp(-t1/alfa))/(1-exp(-t2/alfa))\n",
+ "ee1=theta2/theta1-1 # let ee1=exp(-1/2/alfa)\n",
+ "theta_m=theta1/(1-ee1) # degree C\n",
+ "theta_2=theta_m*(1-ee1**4) # degree C (after 2 hours)\n",
+ "print \"temperature rise after 2 hours full load = %.f degree C\"%(theta_2)\n",
+ "alfa=-1/2/log(ee1) # hour\n",
+ "alfa_dash=theta_m_dashBYthetam*alfa # hour\n",
+ "theta_m_dash=theta_m_dashBYthetam*theta_m\n",
+ "theta_dash=theta_m_dash*(1-exp(-t2/alfa))\n",
+ "print \"temperature rise of cold water after 1 hour = %.f degree C\"%(theta_dash)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 58 Page 401"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 105,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "at slip=0, To:Ti = 7:1\n",
+ "at s=0.05, To:Ti = 3:10\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt\n",
+ "# Given\n",
+ "zo=2+1J*3 # ohm\n",
+ "zi=0.5+1J*5 # ohm\n",
+ "Ri=(zi.real) # ohm\n",
+ "Ro=(zo.real) # ohm\n",
+ "\n",
+ "#at standstill\n",
+ "s=1 # % at standstill\n",
+ "Zo=sqrt((zo.real)**2+(zo.imag)**2) # ohm\n",
+ "Zi=sqrt((zi.real)**2+(zi.imag)**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"at slip=0, To:Ti = %d:1\"%(ToBYTi)\n",
+ "\n",
+ "#at s=0.5\n",
+ "s=0.05 # %\n",
+ "Zo=sqrt((zo.real)**2/s**2+(zo.imag)**2) # ohm\n",
+ "Zi=sqrt((zi.real)**2/s**2+(zi.imag)**2) # ohm\n",
+ "ToBYTi=Ro/Ri*(Zi/Zo)**2 # torque ratio\n",
+ "print \"at s=0.05, To:Ti = %.f:10\"%(ToBYTi*10)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 59 Page 402"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 106,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "part(a) Regulation at no load voltage = 15 percent\n",
+ "part(b) Regulation at full load voltage = 17 percent\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt,pi,sin,cos\n",
+ "\n",
+ "# Given\n",
+ "u=45 # degree \n",
+ "m=3 # no of phases\n",
+ "\n",
+ "#Id=sqrt(2)*Vs*X*(1-cosd(u))*sin(pi/m)\n",
+ "IdBYVs_dash=m/2/pi*(1-cos(pi/180*u))*sin(pi/m)*sqrt(2) # load current/Vs\n",
+ "#where IdBYVs_dash = m/pi*IdX/2\n",
+ "EdoBYVs=sqrt(2)*m/pi*sin(pi/m) # dc output voltage/Vs with no overlap\n",
+ "EduBYVs=EdoBYVs-IdBYVs_dash # dc output voltage/Vs with overlap\n",
+ "#part (a)\n",
+ "Reg1=(EdoBYVs-EduBYVs)/EdoBYVs*100 # % (regulation)\n",
+ "print \"part(a) Regulation at no load voltage = %.f percent\"%(Reg1)\n",
+ "#part (b)\n",
+ "Reg2=(EdoBYVs-EduBYVs)/EduBYVs*100 # % (regulation)\n",
+ "print \"part(b) Regulation at full load voltage = %.f percent\"%(Reg2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 60 Page 402"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 107,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "length of filament = 1.89 m\n",
+ "diameter of filament = 60 um\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "\n",
+ "# Given\n",
+ "d1=0.15*10**-3 # mm\n",
+ "l1=150*10**-2 # m\n",
+ "i2BYi1=1/4 # current ratio\n",
+ "#(d2/d1)**(3/2)=i2BYi1\n",
+ "d2=(i2BYi1)**(2/3)*d1*10**6 # um\n",
+ "l2=1/2*l1*d1/d2*10**6 # m\n",
+ "print \"length of filament = %.2f m\"%(l2)\n",
+ "print \"diameter of filament = %.f um\"%(d2)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 61 Page 403"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 108,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "Potential difference = 1875 V\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import sqrt,sin,pi\n",
+ "# Given\n",
+ "d=5/100 # m\n",
+ "S=-4/100 # m\n",
+ "Ve=3 # kV\n",
+ "theta=45 # degree\n",
+ "e=1.6*10**-19 # C\n",
+ "m=9.67*10**-31 # kg\n",
+ "\n",
+ "u=sqrt(2*e*Ve*1000/m) # m/s\n",
+ "uy=u*sin(pi/180*theta) # m/s\n",
+ "vy=0 # since final velocity =0\n",
+ "#vy**2-uy**2=2*ay*S\n",
+ "ay=(vy**2-uy**2)/2/S # m**2/s\n",
+ "#ay=e/m*V/d\n",
+ "V=ay*m*d/e # V\n",
+ "print \"Potential difference = %.f V\"%(V)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## Ex 62 Page 403"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 109,
+ "metadata": {
+ "collapsed": false
+ },
+ "outputs": [
+ {
+ "name": "stdout",
+ "output_type": "stream",
+ "text": [
+ "reading of ammeter 1= 0.56 A\n",
+ "reading of ammeter 2 = 0.30 A\n",
+ "\n",
+ "\n",
+ "Power taken from the mains = 162.0 W\n",
+ "Power dissipated in rectifying device = 115 W\n"
+ ]
+ }
+ ],
+ "source": [
+ "from __future__ import division\n",
+ "from math import pi\n",
+ "from sympy.mpmath import quad\n",
+ "# Given\n",
+ "R=150 # ohm\n",
+ "Vrms=200 # V\n",
+ "Rd1=65 # ohm\n",
+ "Rd2=140 # ohm \n",
+ "\n",
+ "Vm=Vrms/sqrt(2) # V\n",
+ "#v=Vm*sin(theta)\n",
+ "Rf=R+Rd1 # ohm\n",
+ "Rb=R+Rd2 # ohm\n",
+ "#i_f=v/Rf # A\n",
+ "#i_b=v/Rb # A\n",
+ "Irms=1/2/pi*(quad(lambda theta:(sqrt(2)*sin(theta))**2,[0,pi])+quad(lambda theta:(sqrt(2)/3*sin(theta))**2,[pi,2*pi]))\n",
+ "Iav=1/2/pi*(quad(lambda theta:sqrt(2)*sin(theta),[0,pi])+quad(lambda theta:sqrt(2)/3*sin(theta),[pi,2*pi]))\n",
+ "print \"reading of ammeter 1= %.2f A\"%(Irms)\n",
+ "print \"reading of ammeter 2 = %.2f A\"%(Iav)\n",
+ "P=1/2*(Vrms**2/Rf+Vrms**2/Rb) # W\n",
+ "print \"\\n\\nPower taken from the mains = %.1f W\"%(P)\n",
+ "Pc=Irms**2*R # W\n",
+ "Pd=P-Pc # W\n",
+ "print \"Power dissipated in rectifying device = %d W\"%(Pd)\n",
+ "#Answer wrong in the textbook."
+ ]
+ }
+ ],
+ "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.9"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 0
+}
diff --git a/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/VgnES.png b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/VgnES.png
new file mode 100644
index 00000000..b3fe4a06
--- /dev/null
+++ b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/VgnES.png
Binary files differ
diff --git a/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/f4att.png b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/f4att.png
new file mode 100644
index 00000000..429bf068
--- /dev/null
+++ b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/f4att.png
Binary files differ
diff --git a/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/starNdelta.png b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/starNdelta.png
new file mode 100644
index 00000000..f39b0c05
--- /dev/null
+++ b/Problems_in_Electrical_Engineering_by_Parker_Smith/screenshots/starNdelta.png
Binary files differ