## Linear algebraic nodal analysis (LANA) algorithm variable guide

Jeffrey A. Anderson
Choosing names and notation for mathematical variables is an art. Good notation begets lucid thinking. Bad notation causes unnecessary confusion. This document provides more information and insights about the variables and equations that make up linear algebraic nodal analysis. In some cases, we explore possible noun phrases to refer to relevant equations in written or spoken format. The hope is to improve your capacity to use the LANA algorithm to describe the behavior of electric circuits and set a foundation for you to use linear algebra in engineering contexts.

## Input: Ideal circuit diagrams labels

The LANA algorithm is designed to provide an authentic modeling experience for anyone interested in learning how to apply linear algebra in engineering contexts. The input to this algorithm is a complete description of an electric circuit that includes resistors along with dc voltage and current sources. At the introductory level, this input usually comes in the form of an ideal circuit schematic. Below are two resources that suggest best practices to draw and label these types of circuit diagrams:
$\square$ Rules and guidelines for drawing good schematics from the Electronics Stack ExchangeGuidelines for Drawing Schematics by Tim J. Sobering
When drawing an ideal circuit diagram, we define and label each element using a letter and number combination (eg. R1, V3, I2). We use uppercase English letters to indicate the type of component while the corresponding number enumerates each individual element of this type in the circuit. This convention follows from a similar practice of stamping each ideal element in Computer-Aided Design (CAD) programs. We use the standard letter codes for resistors, voltage sources, and current sources, seen in Table 1 below.

| Letter Code | Element Type |
| :---: | :--- |
| R | Resistor |
| V | Voltage Source |
| I | Current Source |
| Table 1: Letters for component labels |  |

To ensure readability and ease of reference, each component designator appears next to the associated component. We dedicate the use of both the lower- and upper-case English letters R, V, and I to represent quantities related to resistance, voltage, and current, respectively. Table 2 below provides examples of the element labels used in the input to the LANA algorithm.

| Element label | Description and notes |
| :---: | :--- |
| R 3 | Element label or element name for resistor 3 in an ideal circuit schematic. |
| V 1 | Element label or element name for dc voltage source 1 in an ideal circuit schematic. |
| I2 | Element label or element name for dc current source 2 in an ideal circuit schematic. |

Table 2: Example element labels for an ideal schematic

## Step 1: Identify and label the entire set of nodes of our circuit

There are two main goals for labeling each node. First we want a unique identifier for each node and second we want to count the total number of nodes. In other words, we want to create a bijection between the circuit nodes and a set of natural numbers. In LANA, we do this by labeling the nodes with natural numbers $1,2, \ldots, n_{g}$, where $n_{g}$ is the total number of nodes in the circuit. This avoids the need to use lowercase letters to refer to the nodes and gets right to the point. Each node label is identical to its corresponding index.

There is one possible downside to this approach. If we're not careful, we can cause confusion when referring to other integers. The sentence
"Edge $e_{1}$ goes out of node 2 and into node 1."
does a much better job of referring to the nodes in context than the less-clear statement
"Edge $e_{1}$ goes out of 2 and into 1."
The nonnegative integers play many roles throughout this work so we must be extra careful to refer to each node in the proper context. Assuming we so, labeling the nodes with natural numbers is simple and effective.

## Step 2A: Track the dimensions of key features in our circuit

The digraph model of the electric circuit consists of two sets: the set of nodes $\mathcal{N}$ and the set of edges $\mathcal{E}$. We use math calligraphy typeface to represent all sets that describe directed graphs, as shown in Table 3 below.

| Variable | Description and notes |
| :---: | :--- |
| $\mathcal{G}$ | Our digraph model of the electric circuit with $\mathcal{G}=(\mathcal{N}, \mathcal{E})$. |
| $\mathcal{N}$ | The set of nodes $\mathcal{N}=\left\{1,2, \ldots, n_{g}\right\} \subset \mathbb{N}$. We might say these are the set of nodes that define <br> the digraph $\mathcal{G}$ or the set of circuit nodes. |
| $\mathcal{E}$ | The set of edges $\mathcal{E} \subset \mathcal{N} \times \mathcal{N}$. Each edge is an ordered pair of nodes. We call the first coordinate <br> of an edge the initial node and the second coordinate the terminal node. Each directed edge <br> points out of the initial node into the terminal node. For circuit applications, we say that no <br> self-loops are allowed meaning that the initial and terminal nodes cannot be the same. |

Table 3: The sets that describe our directed graph model of the circuit.
Throughout this work, we dedicate the lower case letter $n$ to count the cardinality of special subsets of nodes. Table 4 below highlights variables that rely on the lower case letter $n$.

| Variable | Element Type |
| :---: | :--- |
| $n_{g}$ | Total number of nodes (including the ground node). |
| $n_{f}$ | Number of free variables in the voltage-source linear-systems problem. |
| $n$ | Minimal number of independent nodes needed to analyze circuits. |

Table 4: Letters for cardinality for sets of nodes
Notice the special use of subscripts to differentiate between each variable in Table 4. These subscripts are designed as memory tools to call into mind the role of each specific counter, as highlighted in Table 5 below.

| Subscript | Significance |
| :---: | :--- |
| $g$ | Tracks when the ground node is included (g means ground is included). |
| $f$ | Refers to free variables from the voltage-source linear-systems problem. |
|  | No subscript Indicates that all constraints have been eliminated. |

Table 5: Letters for cardinality for sets of nodes

We use the lower case letter $m$ counts the cardinality (as a nonnegative integer) of special subsets of edges. Since we establish a bijection between edges of our digraph model and circuit elements, the letter $m$ also counts subsets of circuit components.

The central reason why we choose letters $m$ and $n$ to count edges and nodes comes from conventions in applied linear algebra. Linear algebraists love to write matrix dimensions in the form $m \times n$ where $m, n \in \mathbb{N}$. Lloyd Trefethen and David Bau have a brief description of this convention on page 9 of their famous Numerical Linear Algebra textbook in their section titled "A note on $m$ and $n$." With this convention in mind, Table 5 below highlights all of the dimensions used to describe the entire incidence matrix.

| Variable | Description and notes |
| :---: | :--- |
| $n_{g}$ | This positive integer counts the total number of nodes in the circuit, including the ground <br> node. In electrical engineering, it is sometimes ambiguous if a node count includes the ground <br> node or not. The subscript $g$ makes it abundantly clear that the ground node is included in <br> this count. When the subscript $g$ is present on the integer $n$, we are counting all nodes in the <br> circuit, including the ground node |
| $m_{r}$ | This positive integer represents the number of resistors in the circuit. |
| $m_{v}$ | This nonnegative integer represents the number of dc voltage sources in the circuit. |
| $m$ | This positive integer represents the total number of circuit elements with <br> This integer represents the number of dc current sources in the circuit. |
| We might also say that this counter represents the total number of edges in the digraph model <br> of our circuit or the cardinality of the edge set $\mathcal{E}$. |  |

Table 5: Dimensions for node and edge sets for the entire incidence matrix

## Step 2B: Orient and enumerate the edges of the digraph

Replace each circuit element with an edge of our digraph. For edges associated with current sources, we orient this edge in the same direction as the flow of current in that source. For edges of our graph corresponding to voltage sources, we orient these edges from the positive "+" lead to the negative "-" lead of the associated sources. Finally, we assign arbitrary directions to all edges corresponding to the resistors in our circuit. In addition to orienting each edge according to the rules outlined above, we also choose a very special enumeration scheme for the edges of our circuit. First we count and label all edges corresponding to resistors as edges $e_{1}, e_{2}, \ldots, e_{m_{r}}$. Next, we continue our count by labeling the edges corresponding to voltage sources, yielding edges $e_{m_{r}+1}, \ldots, e_{m_{r}+m_{v}}$. Finally, we enumerate our edges corresponding to current sources as $e_{m_{r}+m_{v}+1}, \ldots, e_{m}$.

## Step 3: Create all circuit matrices

For all circuit equations described below, we follow the well-established convention that boldface, lowercase English letters represent vectors while italicized lowercase letters represent scalar-valued entries within these vectors. Uppercase English letters represent matrices.

## Step 3A: Create the entire incidence matrix

We define the entire incidence matrix with the rows corresponding to edges and the columns corresponding to the nodes. The reason we choose this orientation is to describe nodal analysis using a larger equilibrium equation framework espoused by Gilbert Strang in Chapter 2 of his Introduction to Applied Mathematics textbook. This framework suggests the structure $A^{T} C A$ as the output to our nodal analysis algorithm. If we chose to map rows to nodes and columns to edges, we end up with a matrix structure in the form $A C A^{T}$. Of course, this alternative approach is completely valid but LANA focuses on illustrating the power in the structure $A^{T} C A$. Thus we associate edges with rows and nodes with columns. Below are all incidence matrices used to describe the directed graph model from step 2.

| Variable name | Description and notes |
| :---: | :--- |
| $A_{g}$ | This entire incidence matrix has $m$ rows and $n_{g}$ columns. I might also call this the <br> incidence matrix encoding the circuit's digraph prior to eliminating the ground node. |
| $A_{r_{g}}$ | The resistor subblock of the entire incidence matrix or the entire resistor subblock, with <br> $A_{r_{g}} \in \mathbb{R}^{m_{r} \times n_{g}}$. |
| $A_{v_{g}}$ | The entire voltage source subblock or the voltage-source subblock of the entire incidence <br> matrix with $A_{v_{g}} \in \mathbb{R}^{m_{v} \times n_{g}}$. <br> are attached to our circuit. In this case, this subblock is empty. |
| $A_{i_{g}}$ | The entire current source subblock or the current-source subblock of the entire incidence <br> matrix, with $A_{i_{g}} \in \mathbb{R}^{m_{i} \times n_{g}}$. Since $m_{i}$ might be equal to zero if no current sources are <br> attached, this subblock may not exist. |

Table 6: The entire incidence matrix and it's subblocks

## Notes on index variables for the incidence matrices

When referring to specific rows and columns of these incidence matrices, we use index variables. We dedicate the symbol $j \in \mathbb{N}$ to refer rows and letter $k$ to specify nodes. We do not use the letter $i$ as an index. In electrical engineering, the letter $i$ refers to current. There is a valid argument that the letter $j$ may also cause some confusion since many electrical engineers set $j=\sqrt{-1}$. However, since LANA focuses on DC analysis of circuits containing only resistors and dc power sources, we need not dip into complex analysis. Moreover, even if we do decide to use complex numbers, we can specifically reference the use of the letter $j$ as an index variable wherever it appears.

## Step 3B: Create the node voltage potential vector

Table 7 below presents the variables used to describe the entire set of node voltage potentials in the circuit. In steps 5 and 6 of the LANA algorithm, we impose constrains on some of these variables and reduce this list to a minimal set of potential variables from which all other circuit values can be calculated.

| Variable name | Description and notes |
| :---: | :--- |
| $\mathbf{u}_{g}$ | The entire list of node voltage potentials of the circuit with $\mathbf{u}_{g} \in \mathbb{R}^{n_{g}}$. This list of voltage <br> potentials assumes we have not yet chosen the ground node. |
| $u_{k}$ | The voltage potential of the $k$ th node, where $u_{k}=$ Entry $_{k}\left(\mathbf{u}_{g}\right)$ for $k \in\left\{1,2, \ldots, n_{g}\right\}$. |

Table 7: The node voltage potential variables for the circuit

## Step 3C: Create the voltage drop vector

| Variable name | Description and notes |
| :---: | :--- |
| $\mathbf{v}$ | The vector of voltage drops across each element with $\mathbf{v} \in \mathbb{R}^{m}$. We might also refer to <br> this as the voltage-drop vector. |
| $\mathbf{v}_{r}$ | The resistor voltage-drop vector or the resistor subblock of the vector of voltage drops, <br> with $\mathbf{v}_{r} \in \mathbb{R}^{m_{r}}$. |
| $\mathbf{v}_{v}$ | The voltage-source voltage-drop vector where $\mathbf{v}_{v} \in \mathbb{R}^{m_{v}}$. We might also name this vector <br> the voltage-source subblock of the vector of voltage drops. Assuming $m_{v}>0$, this vector <br> has scalar-valued entries given by $v_{v_{j}}=$ Entry $_{j}\left(\mathbf{v}_{v}\right)$ for $j=1, \ldots, m_{v}$. |
| $v_{v_{j}}$ | Assuming $m_{v} \geq 1$, we see $v_{v_{j}}=\operatorname{Entry}{ }_{j}\left(\mathbf{v}_{v}\right)$ for $j \in\left\{1, \ldots, m_{v}\right\}$. The value of $v_{v_{j}}$ is the <br> assigned value of the circuit element Vj which can be read from the dc voltage sources. <br> We should explicitly note that these values are KNOWN constants. |
| $\mathbf{v}_{i}$ | The current-source voltage-drop vector has the property that $\mathbf{v}_{i} \in \mathbb{R}^{m_{i}}$. Another way to <br> refer to this vector might be to use the phrase the current-source subblock of the vector <br> of voltage drops. |

Table 8: Voltage-drop variables for each element in the circuit.

## Step 3D: Create the current vector

| Variable | Variable name, description and notes |
| :---: | :--- |
| $\mathbf{i}$ | The current vector or the vector of currents through each element with $\mathbf{i} \in \mathbb{R}^{m}$. |
| $\mathbf{i}_{r}$ | We have $\mathbf{i}_{r} \in \mathbb{R}^{m_{r}}$ and we might say this is the resistor current vector, the resistor subblock of <br> the vector of currents through each element, or the current vector for the resistors. |
| $\mathbf{i}_{v}$ | The voltage-source current vector, where $\mathbf{i}_{v} \in \mathbb{R}^{m_{v}}$, also referred to as the voltage-source <br> subblock of the current vector. |
| $\mathbf{i}_{i}$ | The current-source current vector has the property that $\mathbf{i}_{i} \in \mathbb{R}^{m_{i}}$. Another way to refer to <br> this vector might be to use the phrase the current-source subblock of the vector of currents <br> through each element. |
| $i_{i_{j}}$ | Assuming $m_{i} \geq 1$, we see $i_{i_{j}}=$ Entry ${ }_{j}\left(\mathbf{i}_{i}\right)$ for $j \in\left\{1, \ldots, m_{i}\right\}$. The value of $i_{i_{j}}$ is the assigned <br> value of the circuit element Ij which can be read from the dc current sources. We should <br> explicitly note that these values are KNOWN constants. |

Table 9: Current variables for each element in the circuit.

## Step 4A: State the entire set of Kirchhoff's current laws (KCLs)

| Equation | Equation name, description, and notes |
| :---: | :--- |
| $A_{g}^{T} \mathbf{i}=\mathbf{0}$ | The entire set of Kirchhoff's current law equations in matrix <br> form with zero right-hand side. We might also refer to this <br> equation as the complete list of KCLs with right-hand side <br> equal to zero. |
| $A_{r_{g}}^{T} \mathbf{i}_{r}+A_{v_{g}}^{T} \mathbf{i}_{v}=-A_{i_{g}}^{T} \cdot \mathbf{i}_{i}$. | The subblock form of the entire set of KCLs with nonzero <br> current-source forcing term on right-hand side. |
|  |  |

Table 10: Matrix equations to express KCL equations.

## Step 4B: State the brach constitutive relations (BCRs)

Branch constitutive relations (BCRs) are equations that relate the voltage drop across to the current running through a particular circuit element. For the types of circuit's we study in this work, the only type of BCRs are associated with the resistors in the circuit and are known as Ohm's law. We can track two different versions of Ohm's law, as seen in Table 11 below.

| Equation | Equation name, description, and notes |
| :--- | :--- |
| $\mathbf{v}_{r}=R \mathbf{i}_{r}$ | The resistance form of Ohm's law equations for all resistors <br> in circuit. Also known as the matrix version of Ohm's law <br> in resistance form. |
| $\mathbf{i}_{r}=G \mathbf{v}_{r}$ | The conductance form of Ohm's law equations for all resis- <br> tors in circuit. Also known as the matrix version of Ohm's <br> law in conductance form. |

Table 11: Matrix equations to express Ohm's law.
The individual entries of matrix $R$ come from the assigned values of the resistors, as seen in Table 12 below.

| Variable name | Description and notes |
| :---: | :---: |
| $r_{j}$ | The assigned resistance value associated with the $j$ th resistor Rj in the circuit for $j=1,2, \ldots, m_{r}$. This is also known as the resistance of the $j$ th resistor. |
| $R$ | This $m_{r} \times m_{r}$ diagonal matrix, known as the resistance matrix, stores the resistances of all resistors as the diagonal elements with $R=\left[\begin{array}{cccc} r_{1} & 0 & \cdots & 0 \\ 0 & r_{2} & \ddots & \vdots \\ \vdots & \ddots & \ddots & 0 \\ 0 & \cdots & 0 & r_{m_{r}} \end{array}\right]$ |
| $G$ | The diagonal matrix $G \in \mathbb{R}^{m_{r} \times m_{r}}$ is defined as $G=R^{-1}$. The entry-by-entry definition is given as $G=\left[\begin{array}{cccc} g_{1} & 0 & \cdots & 0 \\ 0 & g_{2} & \ddots & \vdots \\ \vdots & \ddots & \ddots & 0 \\ 0 & \cdots & 0 & g_{m_{r}} \end{array}\right]$ <br> where $g_{j}=\frac{1}{r_{j}}$ for $j \in\left\{1,2, \ldots, m_{r}\right\}$. This is also called the conductance matrix. |

Table 12: Resistor and conductance variables in Ohm's law equations.

## Note about conductance variables

A natural thought for mathematicians not trained as electrical engineers is to assume we should name the conductance matrix $C$ instead of $G$. The word conductance starts with the letter "C" and the equilibrium equation framework suggested by Strang also includes matrix $C$. While this is a great thought, it doesn't stand up to the test of making our math as clear as possible for the end users. In electrical engineering, the letter "C" is used for capacitors. Following conventions in electrical engineering, we use the variable $g_{j}$ to describe the conductance of the $j$ th resistor.

## Step 4C: State the entire set of Kirchhoff's voltage laws (KVLs)

In stating Kirchhoff's voltage laws (KVLs), we choose a convention that is specialized to CAD programming for on circuit simulation. In contrast, most introductory physics and engineering course present KVL equations in two forms. The first form of KVLs is written below.

The path form of Kirchhoff's voltage law states that if two paths in a circuit have the same initial nodes and the same terminal nodes, then the sums of the voltage drops along the two paths must be the same.

The other way to write Kirchhoff voltage law focuses on loops instead of paths and reads as follows:
The loop form of Kirchhoff's voltage law states that the sum of all voltage drops around any loop in a circuit must be zero. Alternatively, we might also say that the sum of all voltage rises around any loop in a circuit must be zero.

In the LANA algorithm, we use a more general version of Kirchhoff's voltage laws given as follows:
The node-potential form of Kirchhoff's voltage law states that the voltage drop across any twoterminal element of a circuit is the difference in the node voltage potentials at each lead.

By combining this node-potential KVLs with circuit matrices from graph theory, we can produce the other two forms of KVLs as a consequent of this node-potential form. Table 13 below shows how we write the KVLs in node-potential form using the matrices we generated in step 3 of the LANA algorithm.

| Equation | Equation name, description, and notes |
| :--- | :--- |
| $A_{g} \mathbf{u}_{g}=\mathbf{v}$ | The entire set of Kirchhoff's voltage law equations in node- <br> potential form. We might also refer to this equation as the <br> the complete list of KVLs in node-potential form. |
| $A_{r_{g}} \mathbf{u}_{g}=\mathbf{v}_{r}$ | The entire set of resistor KVLs. We might also call the <br> equation as the resistor subblock of the entire set of KVLs. <br> We stay away from using the terse and less-accurate phrase <br> resistor KVLs since the LANA algorithm distinguishes be- <br> tween complete, grounded, and deflated KVL equations, as <br> discussed below. |
| $A_{v_{g}} \mathbf{u}_{g}=\mathbf{v}_{v}$ | The entire set of voltage-source KVL equations or the <br> voltage-source subblock of the entire set of KVLs. The <br> right-hand side of this equation contains known voltage val- <br> ues and this forms the entire voltage-source general linear- |
| systems problem. |  |

Table 13: Matrix equations to express KVLs in node-potential form.

## Step 5: Identify ordinary and generalized nodes

We define a generalized node to be any set of nodes connected by a path of voltage sources. For each generalized node, we have only one independent node voltage potential. Any node to which no voltage source is connected is called an ordinary node. We use the deactivated circuit heuristic to identify ordinary and generalized nodes.

In the deactivated circuit heuristic, we deactivate the voltage and current sources in the circuit by setting their values to zero. This is equivalent to drawing a new deactivated resistor network in which we replace each voltage source with a short circuit and each current source with an open circuit. When we deactivate the circuit in this way, the nodes in each generalized node meld together. The node potential variables for all nodes inside a generalized node are constrained by the placement of the voltage sources. Thus, the values of these variables are not independent from each other.

## Step 6: Create a minimal set of independent node potentials

The LANA algorithm uses linear algebra to reduce the vector $\mathbf{u}_{g}$ to a minimal set of independent node variables from which all other quantities in the circuit can be calculated. To achieve this reduction, we partition the entries of $\mathbf{u}_{g}$ into two lists. The first list of constrained variables includes one node potential variable for each voltage source and exactly one additional variable for our chosen ground node. The second list of independent variables are the chosen node voltage potentials that remain after eliminating the constrained quantities.

## Step 6A: Impose one constraint for each voltage source

To impose the $\left(m_{v}+1\right)$ constraints, we look at two features of our modeling problem. The first set of constraints is encoded in the element-specific KVLs from step 4C. Specifically, the voltage-source KVLs form a linear-systems problem

$$
A_{v_{g}} \mathbf{u}_{g}=\mathbf{v}_{v}
$$

since the vector $\mathbf{v}_{v}$ on the right-hand side has known entries. This voltage source general linear-systems problem encodes $m_{v}$ restrictions amongst the entries of $\mathbf{u}_{g}$. The second type of constraint relates to our choice of ground node. To ground our circuit, we pick a reference node and set one entry of the vector $\mathbf{u}_{g}$ to zero. By partitioning the entries of $\mathbf{u}_{g}$ in this way, we create a minimal list $\mathbf{u} \in \mathbb{R}^{n}$ of independent node variables, where $n=\left(n_{g}-m_{v}-1\right)$. To reduce $\mathbf{u}_{g}$ down to $\mathbf{u}$, we begin with the voltage-source constraints and then we ground the circuit.

| Equation | Equation name, description, and notes |
| :---: | :--- |
| $A_{v_{g}} \mathbf{u}_{g}=\mathbf{v}_{v}$ | In this voltage-source subblock of the entire set of $K V L s$, <br> we notice that the right-hand side of this equation contains |
| known voltage values. We recognize this as the voltage- |  |
| source general linear-systems problem. We can produce a |  |
| complete solution to this problem to impose $m_{v}$ constraints |  |
| amongst the entries of $\mathbf{u}_{g}$. |  |

Table 14: Matrix equations to express the voltage-source constraints.

Each variable in the complete solution to the voltage-source general linear-systems problem has special meaning, as show in Table 15 below.

| Variable | Variable name, description and notes |
| :---: | :--- |
| $\mathbf{p}_{g}$ | A particular solution to the voltage-source $K V L s$ where $A_{v_{g}} \mathbf{p}_{g}=\mathbf{v}_{v}$. |
| $Z_{v_{g}}$ | The voltage-source deactivation matrix of size $n_{g} \times n_{f}$. The columns of this matrix form a <br> basis for Nul $\left(A_{v_{g}}\right)$. |
| $n_{f}$ | The number of free variables from the voltage-source $K V L s$, where $n_{f}=n_{g}-m_{v}$. |
| $\mathbf{u}_{f}$ | The vector of free variables from the voltage-source KVL equations. |

Table 15: Variables to express the voltage-source constraints.

## Step 6B: Impose a single constraint for the ground node

To impose the final constraint, we choose a single ground node from the remaining ( $n_{g}-m_{v}$ ) free variables and shift the corresponding entry of the vector $\mathbf{u}_{f}$ from unknown to known. This permits a dimension reduction realized using multiplication with a matrix $D_{f_{0}} \in \mathbb{R}^{n_{f} \times n}$. The matrix $D_{f_{0}}$ is formed by taking the $n_{f} \times n_{f}$ identity matrix and deleting the column corresponding to the chosen ground node where

$$
n=n_{f}-1=\left(n_{g}-m_{v}\right)-1
$$

represents the minimum number of node voltage potentials needed to completely analyze the circuit. We use the deflation matrix $D_{f_{0}}$ to define

$$
\mathbf{u}=D_{f_{0}}^{T} \mathbf{u}_{f} \quad \text { and } \quad Z=Z_{v_{g}} D_{f_{0}}
$$

## Step 6C: Combine the constraints together

We then form the completely reduced solution to the voltage-source KVLs given by

$$
\mathbf{u}_{g}=\mathbf{p}_{g}+Z \mathbf{u}
$$

where the columns of $Z \in \mathbb{R}^{n_{g} \times n}$ are in $\operatorname{Nul}\left(A_{v_{g}}\right)$ and the vector $\mathbf{u} \in \mathbb{R}^{n}$ stores the minimal list of independent variables needed to fully analyze the circuit. We sum this up in Table 16 below.

| Equation | Equation name, description, and notes |
| :---: | :--- |
| $\mathbf{u}_{g}=\mathbf{p}_{g}+Z \mathbf{u}$ | Completely reduced solution to voltage-source KVLs. |
| $\mathbf{u}=D_{f_{0}}^{T} \mathbf{u}_{f}$ | The vector storing a minimal set of independent node volt- <br> age potentials needed to analyze the entire circuit. |
| $Z=Z_{v_{g}} D_{f_{0}}$ | Grounded voltage-source deactivation matrix imposes the <br> $\left(m_{v}+1\right)$ constraints and produce equations in terms of our <br> minimal list of independent node potential variables. |

Table 16: Variables to express the voltage-source constraints.

Step 7: State and solve the equilibrium equation for the circuit

| Variable name | Description and notes |
| :---: | :--- |
| $A$ | complete reduced incidence matrix of size $m \times n$. This describes a digraph model of the <br> deactivated resistor network. We form this grounded and deactivated incidence matrix <br> by multiplying $A_{g}$ on the right by the voltage-source deflation matrix $Z$ with $A=A_{g} Z$. |
| $A_{r}$ | This $m_{r} \times n$ matrix corresponds to the resistor subblock of the completely reducedincidence <br> matrix with $A_{r}=A_{r_{g}} Z$. We might also refer to this as the incidence matrix model of <br> the deactivated resistor network. |
| $A_{v}$ | This $m_{v} \times n$ matrix corresponds to the voltage-source subblock of the maximally deflated <br> incidence matrix with $A_{v}=A_{v_{g}} Z$. By construction, the columns of $Z$ are in the null <br> space of $A_{v_{g}}$ and we immediately conclude that |
| $\quad A_{v}=0 \in \mathbb{R}^{m_{v} \times n}$. |  |
| In transpose form, we have |  |
| In other words, this matrix has all zero entries. We are naming this matrix because it's |  |
| worth noting that the zero entries result from our construction of the matrix $Z$. |  |

Table 17: Deactivated incidence matrices

| Equation | Equation name, description, and notes |
| :---: | :--- |
| $K=A_{r}^{T} \cdot G \cdot A_{r}$ | The LANA coefficient matrix also referred to as a stiffness <br> matrix associated with our original circuit. |
| $K \cdot \mathbf{u}=A_{r}^{T} \cdot G \cdot \mathbf{b}-\mathbf{f}$ | The linear-algebraic nodal analysis equation. This is in the <br> exact form espoused by Strang on in box 2E on page 112 <br> of his Introduction to Applied Mathematics textbook. The <br> coefficient matrix $K$ is nonsingular and positive definite. |
| $\mathbf{f}=A_{i}^{T} \cdot \mathbf{i}_{i}$. | The current source forcing terms on the nodes of the cir- <br> cuit. In this case, we use same notation outlined in Strang's <br> Introduction to Applied Mathematics on page 112. |
| $\mathbf{b}=-A_{r_{g}} \mathbf{p}_{g}$ | The voltage-source forcing terms at the nodes of the cir- <br> cuit. The negative sign matches the notation as outlined in <br> Strang's Introduction to Applied Mathematics on page 112. |

Table 18: The Linear Algebraic Nodal Analysis Equation

