

# Symbolic Circuit Modelling and Simulation Using a Sparse Matrix: An Introduction

John Rugis

**Abstract**—The first part of this article introduces some basic concepts and briefly contrasts electronic circuit modelling with circuit analysis. Then a sparse matrix generalised circuit model is built from first principles by means of an example. Finally, examples of symbolic modelling and simulation for the purposes of theorem development and circuit design validity checking are presented. Note that in this article we will be considering linear circuit elements only.

## I. INTRODUCTION

We begin with the question: *What is an is an electronic circuit?* An electronic circuit is a collection of interconnected electronic components that has well-defined deterministic functionality when it is *running*. The functionality of a circuit when it is running is fully characterised by

- 1) the electric current through each component,
- 2) the voltage drop across each component,
- 3) and the voltage potential at each of the interconnections with respect to an arbitrary *ground* interconnection.

Each of the voltages has a polarity and each of the currents has a direction and can thus be either positive or negative.

A circuit is often thought of as a system having one or more *inputs* and one or more *outputs*. When we say that a circuit is *running* what we mean is that its inputs and outputs are (possibly constant) functions of time.

When a collection of interconnected circuit elements does not have well-defined deterministic functionality we say that the circuit design is not *valid*. In practice this could mean that the real-world circuit would burn-out!

### *What is circuit modelling?*

The modelling of electronic circuits consists of producing a mathematical representation of the circuit and all of its characteristics. Circuit models are an abstraction of their real-world counterpart and as such use *idealised* versions of real physical components and their interconnections. The modelling process is made easier by intentionally omitting any real-world considerations that are not of immediate interest e.g. temperature effects.

Any complete circuit model includes variables for each of the circuit's characteristic currents and voltages. *Inputs* are modelled using (possibly additional) circuit components and *outputs* are modelled as one or more of the characteristic currents or voltages. Circuit models are used by circuit designers to gain insight into the functioning of circuits and as an aid in the circuit design process.

We point out that circuit modelling is not the same thing as circuit analysis. Circuit analysis typically consists of applying a sequence of simplification methods one after the other until the answer to some specific question about the circuit's functionality has been reduced to the obvious. Circuit analysis can be characterised by saying that is done using a collection of tools and an *as needed* approach. This *analysis by simplification* has the limitation that we can ask only one question at a time about the circuit.

Modelling on the other hand can answer all questions about the functioning of any given circuit *simultaneously*. Modelling is best done with methods that seek comprehensive generalised representation.

Models are mostly used for simulation. Simulation means that we run the model, often but not necessarily on a computer, and that the model behaves like the actual physical circuit. It is reasonable to expect that a circuit model will give us some indication when a circuit design is not valid.

*Is it possible to model a linear circuit with a single equation?*

Yes! It is possible to model any given linear circuit, no matter how complex, with a single matrix algebraic equation [?], [?].

## II. A GENERALISED CIRCUIT MODEL

We will use an example and proceed step-by-step from first principles to construct a sparse matrix [?] generalised model.

### A. Schematic diagram

Figure ?? shows a schematic diagram of a simple circuit that contains three components (a constant independent voltage source and two resistors) plus ground. Schematics are the standard representation commonly used by circuit designers to specify electronic circuits. Note that some components, such as the resistors, can be connected in either direction without effecting the functionality of the circuit. Other components, such as the independent voltage source, have a polarity and reversal changes the functionality of the circuit.

A schematic diagram can be used as an unambiguous guide for building a real physical circuit and as such is a complete circuit specification. But the schematic diagram alone is not sufficient for circuit modelling.

### B. Digraph

Digraphs, taken from the mathematics subject area known as graph theory, can be used to represent circuits somewhat



Fig. 1. Schematic of a simple circuit.



Fig. 2. A circuit digraph.

more abstractly. Figure ?? shows a digraph representation of the same simple circuit.

This digraph has three *nodes* which are shown as labeled dots, and three *branches* shown as line segments with labeled circles on them. Additionally, each branch has a small arrowhead that indicates an associated reference direction pointing from it's *source node* to it's *destination node*. Note that each branch corresponds to a circuit component and that the nodes correspond to interconnections.

The labelling and reference directions provide the additional information required for modelling the circuit. The digraph highlights the circuit's interconnection topology and the reference directions but omits the component types, component values, and any possible component polarity.

#### C. Netlist

Another circuit representation, as used by the Spice [?] circuit simulation program, is a circuit netlist. The netlist is a non-graphical text-only representation. Here is one possible netlist for the same circuit:

```
V1 1 0 5
R1 1 2 10
R2 2 0 20
```

The format for each line in this netlist is:

- 1) Branch label with the first character indicating component type.
- 2) Source node label.
- 3) Destination node label.
- 4) Numeric component value.

There are a number of conventions that are followed both with netlists and circuit digraphs:

- 1) The ground node is always named 0.

- 2) All of the other node labels as well as all of the branch labels are arbitrary.
- 3) A positive numeric value for branch current indicates that (positive) current is flowing from the source node to the destination node, whereas a negative numeric value indicates that the current is in fact flowing in the opposite direction.
- 4) A positive numeric value for branch voltage indicates that voltage drops when moving from the source node to the destination node, whereas a negative numeric value indicates that voltage actually drops in the opposite direction.

The netlist is a complete circuit specification that can be used as a basis for modelling. The netlist is also conveniently computer readable.

#### D. Incidence matrix.

The first step in producing a mathematical circuit representation is to construct a node-branch incidence matrix for the circuit. The purpose of this matrix  $\mathbf{A}_a$  is to capture the circuit's interconnection topology.

For a circuit with  $n$  nodes and  $b$  branches we start with a zero matrix having  $n$  rows and  $b$  columns. Then for each branch column we put a '1' in the corresponding source node row and '-1' in the corresponding destination node row. The result for the sample circuit is given by:

$$\mathbf{A}_a = \begin{matrix} n_0 & \begin{bmatrix} -1 & 0 & -1 \end{bmatrix} \\ n_1 & \begin{bmatrix} 1 & 1 & 0 \end{bmatrix} \\ n_2 & \begin{bmatrix} 0 & -1 & 1 \end{bmatrix} \\ b_1 & b_2 & b_3 \end{matrix} \quad (1)$$

Because the voltage potential at the ground node is always zero, a reduced incidence matrix  $\mathbf{A}$ , in which the ground node row has been deleted, is ultimately no less informative. The reduced incidence matrix for the sample circuit is:

$$\mathbf{A} = \begin{bmatrix} 1 & 1 & 0 \\ 0 & -1 & 1 \end{bmatrix}$$

The dimensions of  $\mathbf{A}$  are  $(n - 1) \times b$  where  $n$  is the number of nodes and  $b$  is the number of branches.

#### E. Kirchhoff's Current Law

Kirchhoff's Current Law states that *the algebraic sum of currents leaving any node is zero*.

For the sample circuit, KCL involves all three branch currents  $i_1, i_2, i_3$  and applies to all three interconnection nodes  $n_0, n_1, n_2$  resulting in the following equations:

$$\begin{aligned} -i_1 - i_3 &= 0 \\ i_1 + i_2 &= 0 \\ -i_2 + i_3 &= 0 \end{aligned}$$

These equations can be rewritten in terms of the circuit's incidence matrix and a column vector of branch currents as follows:

$$\begin{bmatrix} -1 & 0 & -1 \\ 1 & 1 & 0 \\ 0 & -1 & 1 \end{bmatrix} \begin{bmatrix} i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ 0 \end{bmatrix}$$

In general, KCL can be expressed in matrix form as  $\mathbf{A}_a \mathbf{i} = \mathbf{0}$  and when using the reduced incidence matrix as

$$\mathbf{A}\mathbf{i} = \mathbf{0} \quad (2)$$

where  $\mathbf{i}$  is a column vector of branch currents and  $\mathbf{0}$  is a column vector of zeros.

#### F. Kirchhoff's Voltage Law

Kirchhoff's Voltage Law in one of its most general forms states that *the voltage drop between any two nodes is equal to the difference of the two node voltages*.

For the sample circuit, KVL involves three branch voltage drops  $v_1, v_2, v_3$  and three node voltages  $e_0, e_1, e_2$ . Remembering that  $e_0 = 0$  this results in the following equations:

$$v_1 = e_1 - 0$$

$$v_2 = e_1 - e_2$$

$$v_3 = e_2 - 0$$

These equations can be rewritten in matrix form using the transpose of the circuit's reduced incidence matrix as follows:

$$\begin{bmatrix} v_1 \\ v_2 \\ v_3 \end{bmatrix} = \begin{bmatrix} 1 & 0 \\ 1 & -1 \\ 0 & 1 \end{bmatrix} \begin{bmatrix} e_1 \\ e_2 \end{bmatrix}$$

In general, KVL can be expressed in matrix form as

$$\mathbf{v} = \mathbf{A}^T \mathbf{e} \quad (3)$$

where  $\mathbf{v}$  is a column vector of branch voltages and  $\mathbf{e}$  is a column vector of node voltages.

KCL (??) and KVL (??) can be combined into the single equation

$$\begin{bmatrix} \mathbf{0} & \mathbf{0} & \mathbf{A} \\ -\mathbf{A}^T & \mathbf{1} & \mathbf{0} \end{bmatrix} \begin{bmatrix} \mathbf{e} \\ \mathbf{v} \\ \mathbf{i} \end{bmatrix} = \begin{bmatrix} \mathbf{0} \\ \mathbf{0} \end{bmatrix} \quad (4)$$

where  $\mathbf{1}$  is an identity matrix and  $\mathbf{0}$  is a zero matrix having the requisite dimensions. Note that this single equation encodes all of the circuit's component interconnections, as well as both KCL and KVL, and holds true for all circuits. What's needed to finish off the model formulation is additional specific component type information.

#### G. Component Characteristics.

A component's type defines a characteristic  $vi$  relationship for each branch. The  $vi$  relationship for resistors is  $v_b = i_b R$  where  $R$  is the resistor's *resistance*. For an independent voltage source whose voltage is  $V$  the relationship is  $v_b = V$  no matter what  $i_b$  is. For the sample circuit:

$$v_1 = 5$$

$$v_2 = 10 i_2$$

$$v_3 = 20 i_3$$

These equations can each be rearranged to take the form:

$$av_b + bi_b = u_b$$

For the sample circuit we now have:

$$\begin{aligned} v_1 &= 5 \\ v_2 - 10 i_2 &= 0 \\ v_3 - 20 i_3 &= 0 \end{aligned}$$

These equations can be combined and rewritten in matrix form:

$$\begin{bmatrix} 1 & 0 & 0 \\ 0 & 1 & 0 \\ 0 & 0 & 1 \end{bmatrix} \begin{bmatrix} v_1 \\ v_2 \\ v_3 \end{bmatrix} + \begin{bmatrix} 0 & 0 & 0 \\ 0 & -10 & 0 \\ 0 & 0 & -20 \end{bmatrix} \begin{bmatrix} i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} 5 \\ 0 \\ 0 \end{bmatrix}$$

In general the characteristic equations for all *linear resistive components* can be combined and written in the form

$$\mathbf{M}\mathbf{v} + \mathbf{N}\mathbf{i} = \mathbf{u}_s \quad (5)$$

where  $\mathbf{M}$  is an array of voltage coefficients,  $\mathbf{N}$  is an array of current coefficients, and  $\mathbf{u}_s$  is a column vector of independent source magnitudes. The dimensions of both  $\mathbf{M}$  and  $\mathbf{N}$  are  $b \times b$  where  $b$  is the number of branches.

#### H. Sparse Matrix Model.

Now (??), (??), and (??) can all be combined giving:

$$\begin{bmatrix} \mathbf{0} & \mathbf{0} & \mathbf{A} \\ -\mathbf{A}^T & \mathbf{1} & \mathbf{0} \\ \mathbf{0} & \mathbf{M} & \mathbf{N} \end{bmatrix} \begin{bmatrix} \mathbf{e} \\ \mathbf{v} \\ \mathbf{i} \end{bmatrix} = \begin{bmatrix} \mathbf{0} \\ \mathbf{0} \\ \mathbf{u}_s \end{bmatrix} \quad (6)$$

Equation (??) is a *sparse matrix* generalised circuit model for linear resistive circuits. This sparse matrix equation is a complete model in that it encodes all of the circuit's component characteristics and interconnections as well as both KCL and KVL. Note that the sparse matrix equation has the form

$$\mathbf{T}\mathbf{w} = \mathbf{u} \quad (7)$$

where  $\mathbf{T}$  is a square matrix with dimensions  $(n - 1)2b$  where the circuit that it represents has  $n$  nodes and  $b$  branches.

In most circuit simulation applications one or more of the entries in  $\mathbf{u}$  are the circuit's *inputs*, one or more of the entries in  $\mathbf{w}$  are the circuit's *outputs*, and the entries in  $\mathbf{T}$  are constants. Running a simulation means that we find the solution  $\mathbf{w}$  to equation (??).

The complete sparse matrix equation for the sample circuit is:

$$\left[ \begin{array}{cc|cc|cc|ccc} 0 & 0 & 0 & 0 & 0 & 1 & 1 & 0 & \\ 0 & 0 & 0 & 0 & 0 & 0 & -1 & 1 & \\ \hline -1 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & \\ -1 & 1 & 0 & 1 & 0 & 0 & 0 & 0 & \\ 0 & -1 & 0 & 0 & 1 & 0 & 0 & 0 & \\ \hline 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & \\ 0 & 0 & 0 & 1 & 0 & 0 & -10 & 0 & \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & -20 & \end{array} \right] \begin{bmatrix} e_1 \\ e_2 \\ v_1 \\ v_2 \\ v_3 \\ i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 5 \\ 0 \\ 0 \end{bmatrix}$$

Gaussian elimination and exact arithmetic yields the solution

$$\begin{bmatrix} e_1 \\ e_2 \\ v_1 \\ v_2 \\ v_3 \\ i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} 5 \\ 10/3 \\ 5 \\ 5/3 \\ 10/3 \\ -1/6 \\ 1/6 \\ 1/6 \end{bmatrix}$$

which fully characterises the sample circuit when it is running.

### I. Symbolic Modelling and Simulation.

The sparse matrix circuit model equation can also be solved using symbolic rather than numerical component values. For the sample circuit we have:

$$\left[ \begin{array}{cc|ccc|ccc} 0 & 0 & 0 & 0 & 0 & 1 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & -1 & 1 \\ \hline -1 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ -1 & 1 & 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & -1 & 0 & 0 & 1 & 0 & 0 & 0 \\ \hline 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 & 0 & -R_1 & 0 \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & -R_2 \end{array} \right] \begin{bmatrix} e_1 \\ e_2 \\ v_1 \\ v_2 \\ v_3 \\ i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ V_1 \\ 0 \\ 0 \end{bmatrix}$$

Symbolic Gaussian elimination yields the solution:

$$\begin{bmatrix} e_1 \\ e_2 \\ v_1 \\ v_2 \\ v_3 \\ i_1 \\ i_2 \\ i_3 \end{bmatrix} = \begin{bmatrix} V_1 \\ V_1 R_2 / (R_1 + R_2) \\ V_1 \\ V_1 R_1 / (R_1 + R_2) \\ V_1 R_2 / (R_1 + R_2) \\ -V_1 / (R_1 + R_2) \\ V_1 / (R_1 + R_2) \\ V_1 / (R_1 + R_2) \end{bmatrix}$$

Note the richness of this solution in that it effectively includes both the series resistor formula and the voltage divider equation:

$$\begin{aligned} R_{total} &= -(v_1/i_1) = R_1 + R_2 \\ e_2 &= V_1 R_2 / (R_1 + R_2) \end{aligned}$$

### J. Circuit Design Validity Checking.

Recall that, by definition, a circuit has well-defined deterministic functionality. What we mean by a *valid circuit design* is that it in fact represents a circuit having the required well-defined functionality. In terms of the model what this means is that equation (??) has a well-defined unique solution. A fundamental result from linear algebra states that all equations of the form given by (??) have either

- 1) a single solution,
- 2) no solution,
- 3) or infinitely many solutions.

Thus, a circuit design is valid if and only if its model has a single solution. With this in mind, we are now in a position to explore a number of example circuit designs for validity.



Fig. 3. Schematic, digraph, and netlist.

1) *Circuit design example*: Is the single independent voltage source shown in Figure ?? a valid circuit design?

Working with the circuit model in the form of an augmented matrix and using symbolic Gaussian elimination gives the following result:

$$\left[ \begin{array}{ccc|c} 0 & 0 & 1 & 0 \\ -1 & 1 & 0 & 0 \\ 0 & 1 & 0 & V_1 \end{array} \right] = \left[ \begin{array}{ccc|c} 1 & 0 & 0 & V_1 \\ 0 & 1 & 0 & V_1 \\ 0 & 0 & 1 & 0 \end{array} \right]$$

Which means that the solution is:

$$\begin{bmatrix} e_1 \\ v_1 \\ i_1 \end{bmatrix} = \begin{bmatrix} V_1 \\ V_1 \\ 0 \end{bmatrix}$$

All of the circuit's characteristics are well-defined, therefore this circuit design is valid.

2) *Circuit design example*: Is the single independent current source shown in Figure ?? a valid circuit?



Fig. 4. Schematic, digraph, and netlist.

The augmented matrix and symbolic Gaussian elimination gives the result:

$$\left[ \begin{array}{ccc|c} 0 & 0 & -1 & 0 \\ 1 & 1 & 0 & 0 \\ 0 & 0 & 1 & I_1 \end{array} \right] = \left[ \begin{array}{ccc|c} 1 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 \end{array} \right]$$

This means that there are an infinite number of solutions as long as the following conditions are met:

$$\begin{bmatrix} e_1 + v_1 \\ i_1 \end{bmatrix} = \begin{bmatrix} 0 \\ 0 \end{bmatrix}$$

The circuit's characteristics are not uniquely determined, therefore this circuit design is not valid.

3) *Circuit design example*: Is the single resistor as shown in Figure ?? a valid circuit?



Fig. 5. Schematic, digraph, and netlist.

The augmented matrix and symbolic Gaussian elimination gives the result:

$$\left[ \begin{array}{ccc|c} 0 & 0 & 1 & 0 \\ -1 & 1 & 0 & 0 \\ 0 & 1 & -R_1 & 0 \end{array} \right] = \left[ \begin{array}{ccc|c} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \end{array} \right]$$

Which means that the solution is:

$$\left[ \begin{array}{c} e_1 \\ v_1 \\ i_1 \end{array} \right] = \left[ \begin{array}{c} 0 \\ 0 \\ 0 \end{array} \right]$$

All of the circuit's characteristics are well-defined, therefore this circuit design is valid.

4) *Circuit design example:* Do the two resistors as shown in Figure ?? form a valid circuit?



Fig. 6. Schematic, digraph, and netlist.

We start with the augmented matrix:

$$\left[ \begin{array}{cccccc|c} 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & -1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ -1 & 1 & 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & 0 & -1 & 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 & -R_1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 1 & 0 & -R_2 & 0 \end{array} \right]$$

Symbolic Gaussian elimination gives the result:

$$\left[ \begin{array}{cccccc|c} 1 & -1 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \end{array} \right]$$

Which means that the solution is:

$$\left[ \begin{array}{c} e_1 - e_2 \\ e_3 \\ v_1 \\ v_2 \\ i_1 \\ i_2 \end{array} \right] = \left[ \begin{array}{c} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array} \right]$$

The circuit's characteristics are not uniquely determined as either  $e_1$  or  $e_2$  could be a free variable, taking any value as long as the condition  $e_1 - e_2 = 0$  is met. Therefore this circuit design is not valid.



Fig. 7. Schematic, digraph, and netlist.

5) *Circuit design example:* Is the circuit design shown in Figure ?? valid?

We start with the augmented matrix

$$\left[ \begin{array}{cccccc|c} 0 & 0 & 0 & 0 & 0 & -1 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & -1 & 1 \\ 1 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ -1 & 1 & 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & -1 & 0 & 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & -R_1 \end{array} \right] \quad \left| \begin{array}{c} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ I_1 \\ I_2 \\ 0 \end{array} \right.$$

but after a number of elementary row operations the augmented matrix contains the row

$$\left[ \begin{array}{cccccc|c} 0 & 0 & 0 & 0 & 0 & 0 & 0 & I_1 - I_2 \end{array} \right]$$

which indicates that when  $I_1 \neq I_2$  there are no solutions and the circuit is thus not valid. But what happens when the currents are equal?

Setting  $I_2 = I_1$  and continuing with Gaussian elimination leads to the result:

$$\left[ \begin{array}{cccccc|c} 1 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 & 0 & 0 & 0 & R_1 I_1 \\ 0 & 0 & 1 & 1 & 0 & 0 & 0 & -R_1 I_1 \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & R_1 I_1 \\ 0 & 0 & 0 & 0 & 0 & 1 & 0 & I_1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & I_1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & I_1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \end{array} \right]$$

The circuit's characteristics are still not uniquely determined as any one of  $e_1$ ,  $v_1$ , or  $v_2$  could be a free variable, the other two then being determined by:

$$\left[ \begin{array}{c} e_1 + v_1 \\ v_1 + v_2 \end{array} \right] = \left[ \begin{array}{c} 0 \\ -R_1 I_1 \end{array} \right]$$

Therefore there are no conditions under which this circuit design is valid.

### III. CONCLUSION.

A sparse matrix circuit model can be easily constructed from first principles and used with both numerical as well as symbolic component values. The utility of the model has been demonstrated in a number of ways. Carefully selected circuit simulations can yield fundamental circuit theorems. Symbolic Gaussian elimination applied to the model can be used to check circuits for design validity.

## REFERENCES

- [1] L. O. Chua, C. A. Desoer, and E. S. Kuh, *Linear and Nonlinear Circuits*. New York: McGraw-Hill, 1987.
- [2] J. Vlach and K. Singhal, *Computer Methods for Circuit Analysis and Design*. New York: Van Nostrand Reinhold, 1983.
- [3] G. Hachtel, R. Braytoni, and F. Gustavson, "The sparse tableau approach to network analysis and design," *IEEE Transactions on Circuits Theory*, vol. CT-18, pp. 101–113, January 1971.
- [4] U. of California, *spice3f5.tar.gz*, July 1993, spice program source code and documentation.