#### HEWLETT-PACKARD ### **HP-41C** ### CIRCUIT ANALYSIS PAC #### NOTICE Hewlett-Packard Company makes no express or implied warranty with regard to the keystroke procedures and program material offered or their merchantability or their fitness for any particular purpose. The keystroke procedures and program material are made available solely on an "as is" basis, and the entire risk as to their quality and performance is with the user. Should the keystroke procedures or program material prove defective, the user (and not Hewlett-Packard Company nor any other party) shall bear the entire cost of all necessary correction and all incidental or consequential damages. Hewlett-Packard Company shall not be liable for any incidental or consequential damages in connection with or arising out of the furnishing, use, or performance of the keystroke procedures or program material. #### INTRODUCTION The Circuit Analysis Pac consists of a general network analysis program, GNAP, and a ladder network analysis program, LNAP. This manual provides a description of each program, relevant equations, a set of instructions for using the programs, and several example problems, each of which includes a list of keystrokes required for its solution. Before plugging in your Application Module, turn the calculator off, and be sure you understand the section "Inserting and Removing Application Modules." Before using a particular program, take a few minutes to read "Format of User Instructions" and "A Word About Program Usage." You should first familiarize yourself with a program by running it once or twice following the user instructions in the manual. Thereafter, the program's prompting or the mnemonics on the overlays should provide the necessary instructions, including which variables are to be input, which keys are to be pressed, and which values will be output. We hope that the Circuit Analysis Pac will assist you in the solution of numerous problems. As you become familiar with your Pac, please feel free to send us your comments and suggestions about this Pac or about other solutions programs you would like to see. Send your comments and suggestions to: Hewlett-Packard Corvallis Division Customer Support 1000 N.E. Circle Blvd. Corvallis, OR 97330, U.S.A. If you have technical problems with this Pac or with the HP-41, consult your owner's handbook. #### Note: Application modules are designed to be used in both HP-41C and HP-41CV model calculators. The HP-41C and HP-41CV differ only in their initial Continuous Memory capacities. The term "HP-41C" is used throughout the rest of this manual, unless otherwise specified, to refer to both calculators. #### **CONTENTS** | Introduction | 1 | |--------------------------------------------|----| | Contents | 2 | | Inserting and Removing Application Modules | 3 | | Format of User Instructions | 5 | | A Word About Program Usage | 6 | | General Network Analysis Program | 8 | | Ladder Network Analysis Program | 20 | | Appendix A Register Usage | 29 | | Appendix B Subroutines | 33 | | Appendix C Program Labels | 34 | #### INSERTING AND REMOVING APPLICATION MODULES Before you insert an Application Module for the first time, familiarize yourself with the following information. Up to four Application Modules can be plugged into the ports on the HP-41C. While plugged in, the names of all programs contained in the Module can be displayed by pressing 2. #### **CAUTION** Always turn the HP-41C off before inserting or removing any plug-in extension or accessories. Failure to turn the HP-41C off could damage both the calculator and the accessory. #### To insert Application Modules: - Turn the HP-41C off! Failure to turn the calculator off could damage both the Module and the calculator. - Remove the port covers. Remember to save the port covers; they should be inserted into the empty ports when no extensions are inserted. 3. Insert the Application Module with the label facing downward as shown, into any port after the last Memory Module. For example, if you have a Memory Module inserted in port 1, you can insert an Application Module in any of ports 2, 3, or 4. (The port numbers are shown on the back of the calculator.) Never insert an Application Module into a lower numbered port than a Memory Module. - 4 Inserting and Removing Application Modules - If you have additional Application Modules to insert, plug them into any port after the last Memory Module. Be sure to place port covers over unused ports. - 5. Turn the calculator on and follow the instructions given in this book for the desired application functions. #### To remove Application Modules: - Turn the HP-41C off! Failure to do so could damage both the calculator and the Module. - 2. Grasp the desired Module handle and pull it out as shown. 3. Place a port cap into the empty ports. #### Mixing Memory Modules and Application Modules Any optional accessories (such as the HP-82104A Card Reader, or the HP-82143A Printer) should be treated in the same manner as Application Modules. That is, they can be plugged into any port after the last Memory Module. Also, the HP-41C should be turned off prior to insertion or removal of these extensions. The HP-41C allows you to leave gaps in the port sequence when mixing Memory and Application Modules. For example, you can plug a Memory Module into port 1 and an Application Module into port 4, leaving ports 2 and 3 empty. #### FORMAT OF USER INSTRUCTIONS The completed User Instruction Form- which accompanies each program is your guide to operating the programs in this Pac. The form is composed of five labeled columns. Reading from left to right, the first column, labeled STEP, gives the instruction step number. The INSTRUCTIONS column gives instructions and comments concerning the operations to be performed. The INPUT column specifies the input data, the units of data if applicable, or the appropriate alpha response to a prompted question. Data input keys consist of 0 to 9 and the decimal point (the numeric keys), **EEX** (enter exponent), and **CHS** (change sign). The FUNCTION column specifies the keys to be pressed after keying in the corresponding input data. The DISPLAY column specifies prompts, intermediate and final answers, and their units, where applicable. Above the DISPLAY column is a box which specifies the minimum number of data storage registers necessary to execute the program. Refer to the Owner's Handbook for information on how the SIZE function affects storage configuration. The following illustrates the User Instruction Form for the GNAP program. | | | | | SIZE>40 | |------|-----------------------------------------------------|--------|--------------------------------|---------------------------------------------------| | STEP | INSTRUCTIONS | INPUT | FUNCTION | DISPLAY | | 1 | Initialize the GNAP program | | XEO GNAP | GNAP<br>NODES=? | | 2 | Key in:<br>number of nodes<br>number of branches | N<br>B | R/S<br>R/S<br>R/S <sup>2</sup> | BRANCHES=?<br>N=(N)B=(B) <sup>1</sup><br>BRANCH 1 | | 3 | Key in each branch element:<br>a) Resistance (Ohms) | R | A | NODES:<br>Fr. TO=? | | | or b) Capacitance (Farads) | С | 8 | NODES:<br>FR. TO=? | | | or c) Inductance (Henrys) | L | C | NODES:<br>FR. TO=? | | | and enter branch nodes<br>or d) Transconductance | FR. TO | R/S | BRANCH(n+1) | | , | (Śiemens) | gm | O | INPUT:<br>V+.V-=? | | | | | <u> </u> | | #### A WORD ABOUT PROGRAM USAGE #### Catalog When an Application Module is plugged into a port of the HP-41C, the contents of the Module can be reviewed by pressing ATALOG 2 (the Extension Catalog). Executing the ATALOG function lists the name of each program or function in the Module, as well as functions of any other extensions which might be plugged in. #### **Overlays** Overlays have been included for some of the programs in this Pac. To run the program, choose the appropriate overlay, and place it on the calculator. The mnemonics on the overlay are provided to help you run the program. The program's name is given vertically on the left side. When the calculator is in USER mode, a blue mnemonic identifies the key directly above it. Gold mnemonics are similar to blue mnemonics, except that they are above the appropriate key and the shift (gold) key must be pressed before the re-defined key. Once again, USER mode must be set. #### **ALPHA and USER Mode Notation** This manual uses a special notation to signify ALPHA mode. Whenever a statement on the User Instruction Form is printed in gold, the ALPHA key must be pressed before the statement can be keyed in. After the statement is input, press ALPHA again to return the calculator to its normal operating mode, or to begin program execution. For example, XEO GNAP means press the following keys: XEO ALPHA GNAP ALPHA. When the calculator is in USER mode, this manual will use the symbols A - J and E to refer to the reassigned keys in the top two rows. These key designations will appear on the User Instruction Form and in the keystroke solutions to sample problems. #### **Optional HP-82143A Printer** When the optional printer is plugged into the HP-41C along with the Circuit Analysis Application Module, all results will be printed automatically. You may also want to keep a permanent record of the values input to a certain program. A convenient way to do this is to set the Print Mode switch to NORMAL before running the program. In this mode, all input values and the corresponding keystrokes will be listed on the printer, thus providing a record of the entire operation of the program. #### Using Programs as Subroutines The programs in this Pac may be called as subroutines for user programs in the HP-41C's program memory. Refer to Appendix B for information on special subroutine calling points. #### **Downloading Module Programs** If you wish to trace execution, to modify, or to record on magnetic cards a program in this Application Module, it must first be copied into the HP-41C's program memory. For information concerning the HP-41C's COPY function, see the Owner's Handbook. It is not necessary to copy a program in order to run it. #### **Program Interruption** These programs have been designed to operate properly when run from beginning to end, without turning the calculator off (remember, the calculator may turn itself off). If the HP-41C is turned off, it may be necessary to set flag 21 (SF 21) to continue proper execution. #### Use of Labels You should generally avoid writing programs into the calculator memory that use program labels identical to those in your Application Module. In case of a label conflict, the label within program memory has priority over the label within the Application Pac program. Several labels used in the Circuit Analysis Module are also used in other modules. If you have this module and another plugged into your calculator, you should make sure that the module containing the programs you want to use is in the lower numbered port. You will find a list of all the global labels used in this Application Module at the back of the manual in appendix C, Program Labels. The names of modules or accessories where duplicate labels occur are also listed. Before plugging in two or more modules, check that listing for duplicate label conflicts. #### **Assigning Program Names** Key assignments to keys A - J and A - E take priority over the automatic assignments of local labels in the Application Module. Be sure to clear previously assigned functions before executing a Module program. #### **GENERAL NETWORK ANALYSIS PROGRAM** This program analyzes electrical networks, computing amplitude and phase of the transfer function $V_2$ (s)/ $V_1$ (s). If the optional HP-82143A printer is used, the results may be either printed or plotted. The network elements allowed are resistors, capacitors, inductors, and voltage-controlled current sources. The size of the circuit that can be handled by the program depends on the number of memory registers available. The following table indicates the number of nodes, N, and branches, B, that can be analyzed with three memory modules. The number of registers needed for a circuit is $2N^2 + 3B + 29$ . #### POSSIBLE CIRCUIT CONFIGURATIONS #### **Number of Memory Modules** | 0 | 1 | 2 | 3 | |----------|------|------|------| | N B | N B | N B | N B | | 2 8 | 2 30 | 2 51 | 2 72 | | 3 5 | 3 26 | 3 48 | 3 69 | | <u> </u> | 4 22 | 4 43 | 4 64 | | | 5 16 | 5 37 | 5 58 | | | 6 8 | 6 30 | 6 51 | | | | 7 21 | 7 42 | | İ | | 8 11 | 8 32 | | | | | 9 21 | Assuming you have set the minimum size of 28, the GNAP program begins by asking you for the size of your circuit and then tests to determine if there is enough storage before it begins. If there is insufficient storage, the message "SET SIZE NNN" warns you that the number of data registers must be increased. When numbering the nodes in your circuit, be sure that node 0 is ground, node 1 is the input node, and node 2 is the node whose voltage you wish to determine. #### **Analysis Algorithm** For any network, a matrix called the "nodal admittance matrix" can be written." This matrix gives the relationship between the node voltages and the branch currents: $$\mathbf{Y}_{\mathbf{n}} \; \mathbf{V}_{\mathbf{n}} = \mathbf{A} \; \mathbf{I} \tag{1}$$ where: A is the incidence matrix $V_n$ is the node-voltage vector I is the source-current vector $\mathbf{Y}_{n}$ is the nodal admittance matrix The algorithm assumes that our network is driven only by a current source of 1 ampere flowing from the ground node, node 0, into the input node, node 1. Equation (1) can then be written as $$\mathbf{Y}_{\mathbf{n}} \ \mathbf{V}_{\mathbf{n}} = \begin{bmatrix} 1 \\ 0 \\ 0 \\ \vdots \\ \vdots \end{bmatrix}$$ (2) This equation could be solved explicitly for each node voltage by multiplying both sides on the left by $\mathbf{Y}_n^{-1}$ . $$\mathbf{V}_{n} = \mathbf{Y}_{n}^{-1} \begin{bmatrix} 1 \\ 0 \\ 0 \\ \vdots \\ \vdots \end{bmatrix}$$ (3) But since we only need the ratio $V_2/V_1$ , it is not necessary to invert $\mathbf{Y}_n$ . Instead, we can use Gaussian elimination to transform $\mathbf{Y}_n$ into a lower triangular matrix. $$\begin{bmatrix} a_{11} & 0 & 0 & 0 & \dots & \dots & \vdots \\ a_{21} & a_{22} & 0 & 0 & \dots & \dots & \vdots \\ a_{31} & a_{32} & a_{33} & 0 & \dots & \dots & \vdots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ a_{n1} & a_{n2} & a_{n3} & \dots & \dots & a_{nn} \end{bmatrix} \begin{bmatrix} V_1 \\ V_2 \\ V_3 \\ \vdots \\ V_n \end{bmatrix} = \begin{bmatrix} 1 \\ 0 \\ 0 \\ \vdots \\ 0 \end{bmatrix}$$ $$(4)$$ <sup>\*</sup>See Balabanian & Bickart, Electrical Network Theory, Wiley, New York, 1969 or equivalent. Then we compute the desired ratio by solving the second equation, obtained from (4). $$\frac{V_2}{V_1} = -\frac{a_{21}}{a_{22}} \tag{5}$$ To illustrate this procedure, consider this circuit: By using the techniques of Sec. 2.4 of Balabanian, we can write the Y<sub>n</sub> matrix $$Y_{n} = \begin{bmatrix} 4 & 0 & -4 \\ 0 & 3 & -2 \\ -4 & -2 & 9 \end{bmatrix}$$ Multiplying the third row by $\frac{2}{9}$ and adding it to the second, we get $$Y_{n} = \begin{bmatrix} 4 & 0 & -4 \\ -\frac{8}{9} & \frac{23}{9} & 0 \\ -4 & -2 & 9 \end{bmatrix}$$ Since we don't need to triangularize past the second row, we have $$\frac{V_2}{V_1} = \frac{8}{23} = -9.17 \text{ dB}$$ For circuits containing reactive components, the above procedure is carried out in the same way except that all operations are done with complex numbers. The GNAP program works with a real conductance matrix, G, and an imaginary susceptance matrix, B. You might get the message DATA ERROR if there is a resonant subnetwork in your circuit and the frequency being used is the exact resonant frequency. If this condition occurs, it will be necessary to alter your input frequency slightly. | | | | | SIZE>40 | |------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------|---------------------------------------------------| | STEP | INSTRUCTIONS | INPUT | FUNCTION | DISPLAY | | 1 | Initialize the GNAP program | | XEQ GNAP | GNAP<br>NODES=? | | 2 | Key in:<br>number of nodes<br>number of branches | N<br>B | R/S<br>R/S<br>R/S <sup>2</sup> | BRANCHES=?<br>N=(N)B=(B) <sup>1</sup><br>BRANCH 1 | | 3 | Key in each branch element:<br>a) Resistance (Ohms) | R | A | NODES:<br>FR. TO=? | | | or b) Capacitance (Farads) | С | В | NODES:<br>FR. TO=? | | | or c) Inductance (Henrys) | L | C | NODES:<br>FR. TO=? | | | and enter branch nodes <sup>3</sup><br>or d) Transconductance | FR. TO | R/S | BRANCH(n+1) | | | (Siemens) | gm | D | INPUT:<br>V+.V-=? | | | and enter voltage control | V+ .V- | R/S | OUTPUT: | | | and current nodes (current<br>leaves . current enters)<br>Repeat step 3 for all branches.<br>When done with all. | IL.IE | R/S | BRANCH (n+1) | | 4 | (OPTIONAL) To review the circuit: | | <b>■</b> E<br>R/S <sup>2</sup><br>: | BRANCH 1<br>(List of Input) | | 5 | Specify the frequency sweep:<br>Key in: Lowest Frequency<br>Highest Frequency<br>frequency increment <sup>4</sup> | f <sub>min</sub><br>f <sub>max</sub><br>Δf | F<br>R/S<br>R/S | FMIN=?<br>FMAX=?<br>F INCR=?<br>READY | | 6 | To compute and list results: Press R/S until results have been obtained for all frequencies. | | J<br>R/S <sup>2</sup><br>R/S <sup>2</sup> | frequency<br>magnitude<br>magnitude,dB | | | <sup>1</sup> If SET SIZE NNN appears,<br>you need more data registers.<br>Set SIZE as indicated and<br>continue by pressing R/S). | | R/\$ <sup>2</sup><br>: | phase<br>: | | | <sup>2</sup> If you are using the printer<br>these Run/Stops are not<br>required. | | | | | | <sup>3</sup> The grounded NODE of a passive branch must be the TO node. | | | | | | $^4$ If $\Delta f$ is entered as a negative value, the program uses $\Delta$ as a multiplicative increment. | | | | #### 12 General Network Analysis Program | STEP | INSTRUCTIONS | INPUT | FUNCTION | DISPLAY | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------|----------------------------| | 7 | To plot the results (assuming you have an HP-82143A printer attached), select desired plot: a) magnitude or b) magnitude in dB or c) Phase | | G<br>H | YMIN=?<br>YMIN=?<br>YMIN=? | | 8 | Specify plot parameters: Key in a) Y <sub>MIN</sub> b) Y <sub>MAX</sub> c) x-axis (y-intercept) | Y <sub>MIN</sub><br>Y <sub>MAX</sub><br>x-axis <sup>5</sup> | R/S<br>R/S<br>R/S | YMAX=?<br>AXIS=? | | | <sup>5</sup> You may suppress printing of the x-axis by placing any alpha character in the alpha display, e.g.; ALPHA NO AXIS R/S causes "NO AXIS" to be stored as the y-intercept and no axis will be plotted. | | | | #### Example 1: Compute the magnitude and phase response for this active filter. It was designed to be a high-pass filter with a 10-Hz cutoff frequency, passband gain of 20 dB, and $\alpha$ -peaking factor of 1. #### Keystrokes XEO ALPHA SIZE ALPHA 082 XEO ALPHA GNAP ALPHA R/S 4 R/S 7 **R/S** R/S 1 EEX CHS 6B 1.03 R/S 7579 A 3 **R/S** 1 EEX CHS 6B 3.04 R/S 100 EEX CHS 9B 3.02 R/S 334200 4.02 [R/S] 10000 .04 R/S .02 **R/S** 10**A** 2 R/S F 1 (R/S) 100 R/S 10 USER TE USER CHS R/S #### Display **GNAP** These keystrokes assume the printer is not being used. NODES? BRANCHES? N=4 B=7 BRANCH 1 NODES: FR.TO=? BRANCH 2 NODES: FR.TO=? **BRANCH 3** NODES: FR.TO=? **BRANCH 4** NODES: FR.TO=? BRANCH 5 NODES: FR.TO=? **BRANCH 6** INPUT: V+.V-=? OUTPUT: IL.IE=? **BRANCH 7** NODES: FR.TO=? DONE FMIN=? FMAX=? FINCR=? READY #### 14 General Network Analysis Program | • | J | |------------|-------------------| | Keystrokes | Display | | J | F= 1.00 | | R/S | H=0.10 | | R/S | H=-19.96dB | | R/S | <b>∠=-5.77</b> | | R/S | F=3.16 | | R/S | H=1.05 | | R/S | H=0.41dB | | R/S | ∠=- <b>19.36</b> | | R/S | F=10.00 | | R/S | H=10.00 | | R/S | H=20.00dB | | R/S | ∠=- <b>90.00</b> | | R/S | F=31.62 | | R/S | H=10.48 | | R/S | H=20.41dB | | R/S | ∠=− <b>160.64</b> | | R/S | F=100.00 | | R/S | H=10.05 | | R/S | H=20.04dB | | R/S | ∠=− <b>174.23</b> | | | | #### Example 2: Create a Bode plot for this transistor amplifier. First transform the circuit using an h-parameter model. Then replace the current-controlled current source with a voltage-controlled current source. #### Keystrokes XEQ ALPHA SIZE ALPHA 062 XEQ ALPHA GNAP ALPHA 3 R/S 5 **R/S** .638 EEX CHS 6 B 1.03 R/S 2494🗚 3 **R/S** .04🖸 3 R/S 2 **R/S** 5000**A** 2 **R/S** 3183 EEX CHS 12 B 2 R/S E #### Display GNAP NODES? BRANCHES? N=3 B=5 BRANCH 1 NODES: FR.TO=? BRANCH 2 BRANCH Z NODES: FR.TO=? **BRANCH 3** *INPUT:* V+.V-=? OUTPUT:IL.IE=? **BRANCH 4** NODES: FR.TO=? **BRANCH 5** NODES: FR.TO=? DONE B 1. C=638.0E-9 NODES: 1.0300 . . B 2. R=2.494E3 NODES: 3.0000 These keystrokes assume a printer is being used. Review the circuit description #### Example 3: Analyze this circuit from 100 Hz to 100 kHz. Make Bode plots using a multiplicative frequency increment of $10^{1/8}$ . #### Keystrokes **Display** XEQ ALPHA SIZE ALPHA 059 XEQ ALPHA GNAP ALPHA 3 [R/S] 4 [R/S] 200 EEX CHS 6C 1.02 R/S .33 🗚 2.03 R/S 220 EEX CHS 6 B 3 (R/S) 20**A** 2[R/S] F > 100 R/S 1 EEX 5 R/S 10 USER TO TO USER CHS R/S **H** (**J** if you have no printer) 50 CHS R/S 10 R/S 0 R/S **GNAP** NODES? **BRANCHES?** N=3 B=4**BRANCH 1** NODES: FR.TO=? **BRANCH 2** NODES: FR.TO=? **BRANCH 3** NODES: FR.TO=? **BRANCH 4** NODES: FR.TO=? **DONE** FMIN=? FMAX=?F INCR =? READY YMIN=? YMAX=? AXIS=? If SIZE > 59, ignore this line. These keystrokes assume a printer is being used. # 18 General Network Analysis Program Keystrokes Display I YMIN=? 188 CHS R/S YMAX=? 188 R/S AXIS=? 0 R/S #### Example 4: You can use programs of your own to put any desired label on a plot. Store Ymin, Ymax, Axis, and the Label. Then execute PRPLOTP. This example shows how to use a Voltage-Controlled Current Source to determine the input impedance of a circuit and how to plot it with the label "Z IN." First build the circuit. | Keystrokes | Display | | |--------------------------|-----------------------|----------------| | XEQ ALPHA SIZE ALPHA 076 | | These key- | | XEQ ALPHA GNAP ALPHA | GNAP | strokes assume | | | NODES? | the printer is | | 4 R/S | BRANCHES? | being used. | | 5 <b>R/S</b> | N=4 B=5 | | | | BRANCH 1 | | | 1 <b>D</b> | <i>INPUT:</i> V+.V-=? | | | | | | #### Display Keystrokes OUTPUT:IL.IE=? 1 R/S .02 R/S **BRANCH 2** NODES: FR.TO=? 4.85 **EEX CHS** 12 B **BRANCH 3** 2 R/S 138.5 [EEX] CHS 18 B NODES: FR.TO=? **BRANCH 4** 2.03 R/S 500 EEX CHS 3 C NODES: FR.TO=? 3.04 R/S **BRANCH 5** NODES: FR.TO=? 10**A** 4 R/S DONE FMIN=? F 19125300 R/S FMAX=? FINCR=? 19125800 R/S READY 50 R/S Then write this short program. Keystrokes Display GTO (-) PACKING PRGM LBL ALPHA Z IN ALPHA 01 LBL Z IN GTO ALPHA H<F> ALPHA 02 GTO H<F> PRGM 0(STO) 00 Ymin\* 50000 STO 01 Ymax ALPHA Z IN STO 04 No Axis STO 11 ALPHA Name XEQ ALPHA PRPLOTP ALPHA <sup>\*</sup>For a description of the function PRPLOTP and the registers used to store its plot parameters, see your **Printer Owner's Handbook**. #### LADDER NETWORK ANALYSIS PROGRAM This program analyzes ladder networks of up to 107 branches providing amplitude and phase of various transfer functions, either printed or plotted. Network elements allowed are resistors, capacitors, inductors, series and parallel inductor-capacitor combinations, voltage-controlled current sources, current-controlled current sources, transformers, gyrators, transmission lines, open stub lines, and shorted stub lines. Transfer functions computed are $V_2/V_1$ , $I_2/I_1$ , $P_2/P_1$ and $Z_{\rm in}$ . Network size is determined by the number of memory modules present. The maximum number of branches possible is 107. | Memory Modules | Branches | (maximum) | |----------------|----------|-----------| | _ | | | | 0 | 11 | |---|-----| | 1 | 43 | | 2 | 75 | | 3 | 107 | If SIZE is not large enough, the display will show "NONEXISTENT." You may execute SIZE with a larger argument and then press $\mathbb{R}/\mathbb{S}$ to resume execution of the program. You need at least $40 + 2 \times$ (number of elements) data registers to run this program. Some elements require three storage registers. #### Theoretical Basis of Ladder Network Analysis Program The operation of this program is based on the fact that the chain-parameter matrix of two cascaded circuits is equal to the product of their individual chain-parameter matrices. Circuit elements are stored as they are input from left to right. Then at each frequency the individual chain-parameter matrices are formed and multiplied to gradually compute the overall matrix. Finally, the desired transfer function is computed. The chain-parameter matrix is defined by the following sketch and matrix equation. 4 is the Cyrillic letter "cha". $$\begin{bmatrix} I_1 & & & & \\ V_1 & & & & \\ \end{bmatrix} \underbrace{\begin{bmatrix} \mathbf{q} \end{bmatrix}}_{V_2} \underbrace{\begin{bmatrix} V_1 \\ I_1 \end{bmatrix}}_{I_1} = \begin{bmatrix} \mathbf{q}_{11} & & \mathbf{q}_{12} \\ \mathbf{q}_{21} & & \mathbf{q}_{22} \end{bmatrix} \begin{bmatrix} V_2 \\ -I_2 \end{bmatrix}$$ The circuit elements allowed by this program are shown below with their 4-matrices. | Name | Circuit | Cha | ain-Parameter Matrix | |-----------------------|---------|---------------------------|----------------------------------------------------------------------------------------------------------| | RS Series Resistor | •——• | <b>y</b> = | 1∠0 R ∠0<br>0 1∠0 | | RP Parallel Resistor | R<br>R | <b>y</b> = | $ \begin{array}{ccc} 1 \angle 0 & & & 0 \\ \frac{1}{R} \angle 0 & & & 1 \angle 0 \end{array} $ | | CS Series Capacitor | ° | <b>y</b> = [ | $ \begin{array}{ccc} 1 \angle 0 & \frac{1}{\omega C} \angle -90 \\ 0 & 1 \angle 0 \end{array} $ | | CP Parallel Capacitor | c | _ | 1Δ0 0<br>ωCΔ90 1Δ0 | | LS Series Inductor | oo | $\mathbf{q} = \mathbf{c}$ | 1∠0 ωL∠90<br>0 1∠0 | | LP Parallel Inductor | | <b>y</b> = [ | $ \begin{array}{ccc} 1 \angle 0 & 0 \\ \frac{1}{\omega L} \angle -90 & 1 \angle 0 \end{array} $ | | LCS Series L-C | c • | <b>y</b> = | $ \begin{array}{ccc} 1\angle 0 & \frac{\omega L}{1-\omega^2 LC} \angle 90 \\ 0 & 1\angle 0 \end{array} $ | | LCP Parallel L-C | | <b>y</b> = | $ \begin{array}{ccc} 1 \angle 0 & 0 \\ $ | | TF Transformer | | <b>y</b> = [ | _ | $$\mathbf{q} = \begin{bmatrix} 0 & \alpha \angle 0 \\ \frac{1}{\alpha} \angle 0 & 0 \end{bmatrix}$$ $$\mathbf{H} = \begin{bmatrix} 0 & -\frac{1}{g_{\rm m}} L0 \\ 0 & -\frac{1}{r_{\rm b}g_{\rm m}} L0 \end{bmatrix}$$ $$\mathbf{q} = \begin{bmatrix} 0 & -\frac{\mathbf{r}_b}{\beta} L0 \\ 0 & -\frac{1}{\beta} L0 \end{bmatrix}$$ $$\mathbf{q} = \begin{bmatrix} \cos\theta \angle 0 & Z_0 \sin\theta \angle 90 \\ \frac{\sin\theta}{Z_0} \angle 90 & \cos\theta \angle 0 \end{bmatrix}$$ $$\mathbf{q} = \begin{bmatrix} \frac{1\angle 0}{\tan \theta} & 0 \\ \frac{\tan \theta}{Z_0} & \angle 90 \end{bmatrix}$$ $$\mathbf{q} = \begin{bmatrix} 1\angle 0 & 0 \\ \frac{\cot \theta}{Z_0} \angle -90 & 1\angle 0 \end{bmatrix}$$ Any of the following transfer functions may be computed from the overall chain-parameter matrix. #### Input impedance $$\left| Z_{\text{in}} \right| = \frac{\Psi_{11} Z_{L} + \Psi_{12}}{\Psi_{21} Z_{L} + \Psi_{22}}$$ #### Power Gain $$\left| \begin{array}{c} \frac{P_{out}}{P_{in}} \right| \hspace{0.2cm} = \hspace{0.2cm} \left| \begin{array}{c} I_2 \\ \hline I_1 \end{array} \right|^2 \frac{\text{Re}\{Z_L\}}{\text{Re}\{Z_{in}\}}$$ #### | 1 in | | 11 | 1 Voltage transfer ratio $$\left| \begin{array}{c} V_2 \\ \hline V_1 \end{array} \right| = \frac{Z_L}{\psi_{11} \, Z_L + \psi_{12}}$$ #### Forward transfer admittance $$\left| \begin{array}{c} I_2 \\ \hline V_1 \end{array} \right| = \frac{-1}{q_{11} Z_1 + q_{12}}$$ #### Current transfer ratio $$\left| \frac{I_2}{I_1} \right| = \frac{-1}{\Psi_{21} Z_L + \Psi_{22}}$$ #### Forward transfer impedance $$\left| \begin{array}{c} V_2 \\ \hline I_1 \end{array} \right| = \frac{Z_L}{\Psi_{21} Z_L + \Psi_{22}}$$ | | | | | SIZE >50 | |------|------------------------------------------------------------------------|----------------------------|---------------------|----------------------------------| | STEP | INSTRUCTIONS | INPUT | FUNCTION | DISPLAY | | 1 | Initialize the Ladder Net-<br>work Analysis Program | | XEQ LNAP | LNAP<br>BEGIN INPUT | | 2 | Input circuit elements one<br>at a time starting at the<br>left. | | | | | | Series Resistor | R | <b>A</b> | RS=(R) | | | Parallel Resistor | R | | RP= (R) | | | Series Capacitor | С | B | CS= (C) | | | Parallel Capcitor | С | ■B | CP= (C) | | | Series Inductor | Ł | C | LS= (L) | | | Parallel Inductor | L | <b>■</b> C | LP=(L) | | | Voltage-Controlled Current<br>Source | r<br>g <sub>m</sub> | ENTER+ | VCIS=<br>(r), (gm) | | | Current-Controlled Current<br>Source | r<br>β | ENTER+ | ICIS= (r), (β) | | | Series L-C | L<br>C | ENTER+) | LCS= (L),<br>(C) | | | Parallel L-C | L<br>C | ENTER+) | LCP= (L),<br>(C) | | | Transformer | n | (XEO) TF | TF= (n) | | | Gyrator | α | (XEQ) GY | $GY = (\alpha)$ | | | Transmission Line $\{\theta = \frac{\text{electrical length}}{f_0}\}$ | <i>θ</i><br>Ζ <sub>o</sub> | ENTER+<br>XEQ LINE | $LINE = (\theta), \\ (Z_{o})$ | | | Open Stub | <i>θ</i><br>Ζ <sub>o</sub> | ENTER*) (XEQ) STUBO | STUB0= (θ),<br>(Z <sub>o</sub> ) | | | Shorted Stub | θ<br>Ζ <sub>o</sub> | ENTER+) (XEO) STUBS | STUBS= $(\theta)$ , $(Z_o)$ | | 3 | Input load impedance: | R∟<br>X∟ | ENTER+ | | | 4 | (Optional) Review the circuit. Press (R/S) to see successive branches. | | E E | | | | *This R/S is not needed if you are using a printer. | , | | | | STEP | INSTRUCTIONS | INPUT | FUNCTION | DISPLAY | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------| | 5 | Select frequency sweep Minimum frequency Maximum frequency Frequency increment (negative value indicates multiplicative increment) | fmin<br>fmax<br>Af | F<br>R/S<br>R/S | FMIN=? FMAX=? FINCR=? FUNCTION? | | 6 | To output results, key in a list-function name. (The calculator is already in ALPHA mode.) Transfer voltage ratio Transfer current ratio Power ratio Input Impedance All of the above | V2/V1<br>I2/I1<br>P2/P1*<br>ZIN<br>ALL | R/S<br>R/S<br>R/S<br>R/S<br>R/S | FUNCTION: | | 7 | To plot results, key in the desired plot-function name. (The calculator is already in ALPHA mode.) Plot Magnitude of V2/V1 Plot Magnitude of V2/V1 Plot Magnitude of I2/I1 Plot Magnitude of I2/I1 Plot Magnitude of I2/I1 in dB Plot Angle of I2/I1 Plot Magnitude of I2/I1 Plot Magnitude of I2/I1 | | PV<br>PVdB<br>P∠V<br>PI<br>PIdB<br>P∠I<br>PZIN<br>P∠ZIN | YMIN=?<br>YMIN=?<br>YMIN=?<br>YMIN=?<br>YMIN=?<br>YMIN=?<br>YMIN=? | | 8 | Specify plotting infor-<br>mation<br>(Any alpha-data input | Y <sub>MIN</sub><br>Y <sub>MAX</sub> | R/S<br>R/S | YMAX=?<br>AXIS=? | | 9 | yields no axis) When the plot is complete, you may return to step 1, step 3, or step 5. If you wish to return to step 6, press | axis | R/S | FUNCTION? | | | *This is the <b>real</b> power ratio as only the real portions of $\mathbf{Z}_{\text{L}}$ and $\mathbf{Z}_{\text{m}}$ are considered. | | | - | #### Example 1: Make Bode plots (magnitude and phase) of $V_2/V_1$ for this transistor amplifier. Transform the circuit using an h-parameter model. | PVdB R/S | YMI | |----------|-----| | 20 R/S | YMA | | 50 R/S | AXI | | 50 R/S | | If you have no printer, V2/V1 R/S will cause individual values to be output. #### Example 2: If the stub lengths, d1 and d2, are 54° and 49.68° respectively, what is the input impedance of this double-stub tuner? ( $Z_0$ is $100\Omega$ ) | Keystrokes | Display | | |---------------------------|--------------------|-------------------| | FIX 2 | | | | XEQ ALPHA SIZE ALPHA 053 | | | | XEQ ALPHA LNAP ALPHA | LNAP | | | R/S | BEGIN INPUT | | | 54 ENTER+ | | | | 100 XEQ ALPHA STUBS ALPHA | STUBS=54.00,100.00 | You might like to | | 45 ENTER+ | | assign STUBS to | | 100 XEQ ALPHA LINE ALPHA | LINE=45.00,100.00 | a key, say | | 49.68 ENTER+ | | XXY . | | Keystrokes | Display | |---------------------------|--------------------| | 100 XEQ ALPHA STUBS ALPHA | STUBS=49.68,100.00 | | 90 ENTER+ | | | 100 XEQ ALPHA LINE ALPHA | LINE=90.00,100.00 | | 50 ENTER+ 100 E | ZL=50.00+J100.00 | | F | FMIN = ? | | 1 <b>R/S</b> | FMAX = ? | | R/S | FINCR = ? | | R/S | <b>FUNCTION?</b> | | ZIN R/S | F=1.00 | | R/S | ZIN=97.00 | | R/S | L-1.27 | | R/S | ZIN = 96.97 | | R/S | +J-2.15 | #### Example 3: What is the input impedance of the circuit shown at 1 MHz and 10 MHz? | _ | | _ | | |---|---|---|--| | • | ł | о | | | _ | 1 | ٠ | | #### Keystrokes F 1 EEX 6 R/S 10 EEX 6 R/S 9 EEX 6 R/S ZIN R/S R/S R/S R/S R/S R/S R/S Display FMIN = ? FMAX = ? FINCR = ? FUNCTION? F= 1,000,000. ZIN=122. L**31.** ZIN=104. + **J63**. F=10,000,000. ZIN=221. **∠−75.** ZIN=56. +J-213. ## Appendix A PROGRAM DATA | Flags | 05 S:Δf is multiplicative | C: $\Delta f$ is additive | | 07 S: Plot dB | | 09 S: Plot magnitude | | | | | | | | | | | | | | | | | | | | |--------------------|---------------------------|---------------------------|----------------|--------------------|------|----------------------|----------|--------------------|------|------|----|-----------|----|-----------------|----|----------|----------|--------|-------------|----------|-------|-------|---------------|------------------------|-------------------------| | Data Registers | Ymin | Ymax | PRPLOT scratch | Plotting Character | Axis | PRPLOT scratch | <b>-</b> | scaling multiplier | fmin | fmax | Δf | Plot Name | | number of freqs | ¥ | MJ V+ JK | UC -V MM | ו ר צי | M<br>M<br>X | <b>つ</b> | M.002 | 28+3b | maximum V2/V1 | component-type pointer | component-value pointer | | # Regs.<br>to Copy | 195 00 | 10 | 05 | 03 | 90 | 05 | 90 | 07 | 80 | 60 | 5 | - | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | | Program | GNAP | | | | | | | | | | | | | | | | | | | | | | | | | | 8 S: Plot phase 9 S: Plot magnitude 0 S: Don't increment f 0 S: Always execute * AN | C: Execute * AN only once | | | | | | | | | | | | | | | | | | | |-------------------------------------------------------------------------------------|---------------------------|----------------|----------|-----------------------|----------------------------|--------------------------|------------------------|------------------------------------------|-----------------------------------|----|--------|--------|--------|--------|--------|----|----|----------------------------------------|----------------| | PRPlot scratch 8<br>f<br>Scaling multiplier 10<br>fmin 20 | fmax | f<br>Dict Name | Re {Y,1} | Im {Y <sub>12</sub> } | $Re\left\{Y_{1 2}\right\}$ | $Im\left\{Y_{tz} ight\}$ | Re { Y <sub>21</sub> } | $\operatorname{Im}\left\{Y_{21}\right\}$ | $Re\left\{Y_{\mathbf{z}}\right\}$ | ҳ | Re {A} | lm {A} | Re {B} | Im {B} | Re {C⟩ | | ~ | ــــــــــــــــــــــــــــــــــــــ | Re {temporary} | | 05<br>06<br>07<br>08 | 60 | 1 0 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | Im $\{\text{temporary}\}$ Pointer to next element Number of elements, n RL XL Re $\{Y_{11}Z_{L} + Y_{12}\}$ Im $\{Y_{11}Z_{L} + Y_{12}\}$ Im $\{Y_{21}Z_{L} + Y_{22}\}$ Im $\{Y_{21}Z_{L} + Y_{22}\}$ not used not used List 29 30 31 33 33 33 34 35 36 36 36 40 network elements and values ## Appendix B SUBROUTINES This table provides information necessary to use various portions of the Circuit Analysis Application Module as subroutines. | REMARKS | | | This label is provided so that a user-level program can initiate a GNAP analysis after the user has initially set up the circuit. | |------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | FINAL REGISTERS | y: Im $\{(U_1 + iV_1) (U_2 + iV_2)\}$<br>x: Re $\{(U_1 + iV_1) (U_2 + iV_2)\}$ | y: V <sub>1</sub> + V <sub>2</sub><br>x: U <sub>1</sub> + U <sub>2</sub> | egarding | | INITIAL REGISTERS FLAGSTATUS | | 7:V <sub>2</sub><br>7:U <sub>2</sub><br>7:V <sub>1</sub> | See Appendix A for detailed information regarding register contents and flag settings. | | LABEL | *<br>* | +<br>*C+ | ·* | | SUBROUTINE | Complex Multiply | Complex Add | GNAP PRINT | | | | 22 | | #### APPENDIX C PROGRAM LABELS | | Label | *** | Dublicate Label In | |--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------| | *J | | | Home Management Pac | | PV | | _ | Home Management Pac<br>Real Estate Pac | | RS | | | Petroleum Fluids Pac | | *AN *C* *C+ *MAT* ALL CP CP= CS CS= C= GM= GNAP GY GY= H <f>dB ICIS ICIS= I2/I1 I2/1dB</f> | LINE LINE= LCP LCP= LCS LCS= LNAP LP LP= LS LS= L= PHASE PI PIdB PP2/P1 PVdB PZ/P1 PZ/P1 PZ/I | STUBS=<br>STUBO<br>STUBO=<br>TF<br>TF=<br>VCIS<br>VCIS=<br>V2/V1<br>V2/1dB | No Label Conflicts | The labels in this list are not in the same order as they appear in the catalog listing for the module. Corvallis Division 1000 N.E. Circle Blvd., Corvallis, OR 97330, U.S.A. 00041-90118 Rev. D Printed in U.S.A. 5/82