diff options
Diffstat (limited to 'Antennas_and_Wave_Propagation/chapter12.ipynb')
-rw-r--r-- | Antennas_and_Wave_Propagation/chapter12.ipynb | 195 |
1 files changed, 195 insertions, 0 deletions
diff --git a/Antennas_and_Wave_Propagation/chapter12.ipynb b/Antennas_and_Wave_Propagation/chapter12.ipynb new file mode 100644 index 00000000..5d140dce --- /dev/null +++ b/Antennas_and_Wave_Propagation/chapter12.ipynb @@ -0,0 +1,195 @@ +{ + "metadata": { + "name": "" + }, + "nbformat": 3, + "nbformat_minor": 0, + "worksheets": [ + { + "cells": [ + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "<h1>Chapter 12: The Cylindrical Antenna and the Moment Method (MM)<h1>" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "<h3>Example 12-12.1, Page number: 472<h3>" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "from math import pi\n", + "import numpy as np\n", + "\n", + "#Variable declaration\n", + "N = 3 #Piecewise sinusoidal dipole modes (unitless)\n", + "l = 1/10.0 #Dipole length (lambda)\n", + "z11_exact = 0.4935 - 3454j #Exact impedence vector(ohm)\n", + "z11_apprx = 0.4944 - 3426j #approximate impedence vector(ohm)\n", + "z12_exact = 0.4935 + 1753j #Exact impedence vector(ohm)\n", + "z12_apprx = 0.4945 + 1576j #approximate impedence vector(ohm)\n", + "z13_exact = 0.4935 + 129.9j #Exact impedence vector(ohm)\n", + "z13_apprx = 0.4885 + 132.2j #approximate impedence vector(ohm)\n", + "\n", + "#Calculations\n", + "N2 = N + 1 #Number of equal segments (unitless)\n", + "d = l/4 #Length of each segment (lambda)\n", + "Rmn = 20*(2*pi*d)**2 #Real part of elements of Z-matrix, Zmn (VA)\n", + "zmat_apprx = np.array([[(z11_apprx+z13_apprx), z12_apprx],\n", + " [2*z12_apprx, z11_apprx]])\n", + " #Z(impedence) matrix (unitless)\n", + "vmat = np.array([0,1]) #Voltage matrix (unitless)\n", + "i1,i2 = np.linalg.solve(zmat_apprx,vmat) #Current matrix (unitless)\n", + "i_ratio = i2/i1 #Current ratio (unitless)\n", + "zin = vmat[1]/i2 #Input impedence (ohm)\n", + "\n", + "\n", + "zmat_exact = np.array([[(z11_exact+z13_exact), z12_exact],\n", + " [2*z12_exact, z11_exact]])\n", + "i1_e,i2_e = np.linalg.solve(zmat_exact,vmat) #Current matrix (unitless)\n", + "i_ratio_exact = i2_e/i1_e #Current ratio (unitless)\n", + "zin_exact = vmat[1]/i2_e #Input impedence (ohm)\n", + "\n", + "\n", + "#Result\n", + "print \"The current ratio is \", np.around(i_ratio,4)\n", + "print \"This is nearly equal to 1.9,\" \\\n", + " \"indicating a nearly triangular current distribution\"\n", + "print \"The input impdence is \", np.around(zin,3), \"ohm using approximate values\"\n", + "print \"The input impedence is \", np.around(zin_exact,3), \"ohm using exact values\"" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "The current ratio is (2.09+0.0013j)\n", + "This is nearly equal to 1.9,indicating a nearly triangular current distribution\n", + "The input impdence is (1.891-1917.848j) ohm using approximate values\n", + "The input impedence is (2.083-1605.074j) ohm using exact values\n" + ] + } + ], + "prompt_number": 2 + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "<h3>Example 12-12.2, Page number: 473<h3>" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "from math import tan, pi\n", + "import numpy as np\n", + "\n", + "#Variable declaration\n", + "z_load = 2.083 + 1605j #conjugate matched load (ohm)\n", + "e0 = 1.0 #Electric field magnitude (unitless)\n", + "l = 1/10.0 #length of dipole (lambda)\n", + "imag = 0+1j #Imaginary number \n", + "\n", + "z11_exact = 0.4935 - 3454j #Exact impedence vector(ohm)\n", + "z11_apprx = 0.4944 - 3426j #approximate impedence vector(ohm)\n", + "z12_exact = 0.4935 + 1753j #Exact impedence vector(ohm)\n", + "z12_apprx = 0.4945 + 1576j #approximate impedence vector(ohm)\n", + "z13_exact = 0.4935 + 129.9j #Exact impedence vector(ohm)\n", + "z13_apprx = 0.4885 + 132.2j #approximate impedence vector(ohm)\n", + "\n", + "#Calculation\n", + "d = l/4 #Length of each segment (lambda)\n", + "vm = (2*e0/(2*pi))*tan(2*pi*d/2) #Voltage vector (VA)\n", + "z22 = z11_exact + z_load #Impedence matrix for loaded dipole (VA)\n", + "zmat_exact = np.array([[(z11_exact+z13_exact), z12_exact],\n", + " [2*z12_exact, z22]])\n", + " #Z(impedence) matrix (unitless)\n", + "vmat = np.array([vm,vm]) #Voltage matrix (unitless)\n", + "i1,i2 = np.linalg.solve(zmat_exact,vmat) #Current matrix (unitless)\n", + "i3 = i1 #Current vector (unitless)\n", + "\n", + "e_zn = (60*tan(2*pi*d/2))*imag #Free space electric field (V/m)\n", + "\n", + "e_s = i1*e_zn + i2*e_zn + i3*e_zn #Scattered field (V/m)\n", + "\n", + "sigma = 4*pi*(abs(e_s)**2)/(abs(e0)**2) #Radar Cross section (lambda**2)\n", + "\n", + "#Result\n", + "print \"The radar cross section using exact values of Z matrix is\", round(sigma,4),\\\n", + " \"lambda^2\"" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "The radar cross section using exact values of Z matrix is 0.1805 lambda^2\n" + ] + } + ], + "prompt_number": 3 + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "<h3>Example 12-12.3, Page number: 475<h3>" + ] + }, + { + "cell_type": "code", + "collapsed": false, + "input": [ + "import numpy as np\n", + "\n", + "#Variable declaration\n", + "z11_exact = 2-1921j #Exact impedence vector (ohm)\n", + "z12_exact = 1.9971-325.1j #Exact impedence vector (ohm)\n", + "\n", + "z11_apprx = 1.9739-1992j #Approximate impedence vector (ohm)\n", + "z12_apprx = 1.9739-232.8j #Approximate impedence vector (ohm)\n", + "\n", + "vmat = np.array([1,0])\n", + "\n", + "#Calculations\n", + "zmat_exact = np.array([[z11_apprx, z12_apprx],\n", + " [z12_apprx, z11_apprx]]) \n", + " #Impedence matrix (unitless)\n", + "i1,i2 = np.linalg.solve(zmat_exact,vmat)\n", + " #Current matrix (unitless)\n", + "zin = 1/i1\n", + "\n", + "#Result\n", + "print \"The input impedence for order N = 2 is\", np.around(zin,3), \"ohm\"" + ], + "language": "python", + "metadata": {}, + "outputs": [ + { + "output_type": "stream", + "stream": "stdout", + "text": [ + "The input impedence for order N = 2 is (1.539-1964.795j) ohm\n" + ] + } + ], + "prompt_number": 4 + } + ], + "metadata": {} + } + ] +}
\ No newline at end of file |