# Step-by-step guide to the linear-algebraic nodal analysis (LANA) algorithm Jeffrey A. Anderson 

## INPUT:

Suppose we are given a complete description of an electric circuit containing only resistors, dc voltage sources, and dc current sources. The LANA algorithm proceeds with the steps provided below.

1. Identify and label the entire set of nodes in our circuit.

We begin our work by identifying the nodes in our circuit. To do so, we use the node identification heuristic in which we erase the element bodies of each ideal circuit element. The contiguous segments of conductor that remain are known as the nodes of the circuit. We label the nodes of our circuit using positive integers.
2. Model the circuit as a directed graph.

2A. Track the dimensions of key features in our circuit.
Construct a digraph model $\mathcal{G}$ for our circuit by specifically the dimensions of key features. To do so, we define the following nonnegative integers:

$$
\begin{aligned}
n_{g} & =\text { the total number of nodes in the set } \mathcal{N} \text { (including the ground node) } \\
m_{r} & =\text { the number of resistors in the circuit } \\
m_{v} & =\text { the number of dc voltage sources in the circuit } \\
m_{i} & =\text { the number of dc current sources in the circuit } \\
m & =\text { the total number of elements in our circuit. }
\end{aligned}
$$

Each individual circuit element corresponds to a unique edge in our digraph and the set of edges $\mathcal{E}$ contains exactly $m$ elements, with

$$
m=m_{r}+m_{v}+m_{i}
$$

2B. Orient and enumerate the edges of the digraph.
Replace each circuit element with an edge in our digraph. If an edge models a current source, we orient this edge in the same direction as the flow of current in that source. We orient an edge that corresponds to a voltage source from the positive " + " lead to the negative "-" lead of the associated source. Finally, we assign arbitrary directions to all edges corresponding to the resistors in our circuit.

We choose a special enumeration scheme for the edges of our digraph. 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}$. Each time we increment our edge index, we follow the same order determine by the enumeration scheme within each element type given in the original description of our circuit. For example, edge $e_{i}$ encodes the reference current direction assigned to resistor $i$ for $i=1,2, \ldots, m_{r}$.

2C. Draw a directed graph model of the circuit.
3. Create all circuit matrices.

3A. Create the entire incidence matrix
Form the entire incidence matrix $A_{g} \in \mathbb{R}^{m \times n_{g}}$ using the entry-by-entry definition

$$
a_{j k}=\left\{\begin{aligned}
1 & \text { if edge } e_{j} \text { leaves node } k \\
-1 & \text { if edge } e_{j} \text { enters node } k \\
0 & \text { otherwise }
\end{aligned}\right.
$$

for $j=1,2, \ldots, m$ and $k=1,2, \ldots, n_{g}$. The rows and columns of this matrix correspond to the edges and nodes of our digraph, respectively. We create a block-partition description of our entire incidence matrix $A_{g}$ using our enumeration scheme for our digraph's edges, with

$$
A_{g}=\left[\begin{array}{c}
A_{r_{g}} \\
\hdashline A_{v_{g}} \\
\hdashline A_{i_{g}}
\end{array}\right]
$$

where the subblocks of this matrix are given by

$$
A_{r_{g}} \in \mathbb{R}^{m_{r} \times n_{g}}, \quad A_{v_{g}} \in \mathbb{R}^{m_{v} \times n_{g}}, \quad \text { and } \quad A_{v_{g}} \in \mathbb{R}^{m_{i} \times n_{g}}
$$

3B. Create the node voltage potential vector.
We create the entire list of node voltage potentials and store these variables in the vector $\mathbf{u}_{g} \in \mathbb{R}^{n_{g}}$. This list of node voltage potentials is organized as a column vector. At this point in the modeling process, we have yet to designate a ground node. Thus, the vector $\mathbf{u}_{g}$ contains all nodes identified in step 1 of this algorithm.

3C. Create the voltage drop vector.
Define the voltage-drop vector $\mathbf{v} \in \mathbb{R}^{m}$ whose individual entries store the voltage drop across each circuit element, with

$$
\mathbf{v}=\left[\begin{array}{c}
\mathbf{v}_{r} \\
\hdashline \mathbf{v}_{v} \\
\hdashline \mathbf{v}_{i}
\end{array}\right] \quad \text { where } \quad \mathbf{v}_{r} \in \mathbb{R}^{m_{r}}, \mathbf{v}_{v} \in \mathbb{R}^{m_{v}}, \text { and } \mathbf{v}_{i} \in \mathbb{R}^{m_{i}}
$$

3D. Create the current vector.
Define the current vector $\mathbf{i} \in \mathbb{R}^{m}$ whose individual entries store the current running through each circuit element, with

$$
\mathbf{i}=\left[\begin{array}{c}
\mathbf{i}_{r} \\
\cdots \mathbf{i}_{v} \\
\cdots \mathbf{i}_{i}
\end{array}\right] \quad \text { where } \quad \quad \mathbf{i}_{r} \in \mathbb{R}^{m_{r}}, \mathbf{i}_{v}, \in \mathbb{R}^{m_{v}}, \text { and } \mathbf{i}_{i} \in \mathbb{R}^{m_{i}}
$$

4. State the entire set of circuit equations.

4A. State the entire set of Kirchhoff's current laws (KCLs).
Finally we state the entire set of KCLs using the equation

$$
A_{g}^{T} \mathbf{i}=\mathbf{0} \quad \Leftrightarrow \quad\left[A_{r_{g}}^{T}\left|A_{v_{g}}^{T}\right| A_{i_{g}}^{T}\right]\left[\begin{array}{c}
\mathbf{i}_{r} \\
\ldots \mathbf{i}_{v} \\
\ldots \\
\mathbf{i}_{i}
\end{array}\right]=\mathbf{0} .
$$

Since both $A_{g}$ and $\mathbf{i}$ are block partitioned matrices, we restate our complete list of $K C L$ 's in sublock form as

$$
A_{r_{g}}^{T} \mathbf{i}_{r}+A_{v_{g}}^{T} \mathbf{i}_{v}=-A_{i_{g}}^{T} \mathbf{i}_{i}
$$

4B. State the brach constitutive relations (BCRs).
To state the branch constitutive relations for the resistors in our circuit, we use a matrix version of Ohm's law given by the equation

$$
\mathbf{v}_{r}=R \cdot \mathbf{i}_{r} \quad \Leftrightarrow \quad \mathbf{i}_{r}=G \cdot \mathbf{v}_{r}
$$

where $R \in \mathbb{R}^{m_{r} \times m_{r}}$ is a diagonal matrix. Here, we store the appropriate resistance value in each diagonal entry, yielding scalar equations $v_{k}=r_{k} \cdot i_{k}$ for $k=1,2, \ldots, m_{r}$. Since the $k$ th resistor Rk has positive resistance value $r_{k}>0$, we can also rewrite our $O h m$ 's law equations in conductance form, where the conductance matrix $G=R^{-1}$ is a diagonal and the main diagonal entries are defined by the individual conductances $g_{k}=1 / r_{k}$.

4C. State the entire set of Kirchhoff's voltage laws (KVLs).
We recall that the complete set of circuit equations begins with Kirchhoff's voltage law (KVL) in node potential form. In the LANA algorithm, we state this set of equations using matrix multiplication:

$$
A_{g} \mathbf{u}_{g}=\mathbf{v} \quad \Leftrightarrow \quad\left[\begin{array}{c}
A_{r_{g}} \mathbf{u}_{g} \\
\hdashline A_{v_{g}} \mathbf{u}_{g} \\
\hdashline A_{i_{g}} \mathbf{u}_{g}
\end{array}\right]=\left[\begin{array}{c}
\mathbf{v}_{r} \\
\hdashline \mathbf{v}_{v} \\
\hdashline \mathbf{v}_{i}
\end{array}\right]
$$

Using the subblock partition of the entire incidence matrix $A_{g}$ and the voltage drop vector $\mathbf{v}$, we state the resulting element-specific KVLs as follows:

$$
A_{r_{g}} \mathbf{u}_{g}=\mathbf{v}_{r}, \quad A_{v_{g}} \mathbf{u}_{g}=\mathbf{v}_{v}, \quad \text { and } \quad A_{i_{g}} \mathbf{u}_{g}=\mathbf{v}_{i}
$$

4D. Combine the circuit equations.
Using steps $4 \mathrm{~A}, 4 \mathrm{~B}$, and 4 C , we can re-write the KCL equations in terms of the vector $\mathbf{u}_{g}$ as follows

$$
\begin{equation*}
A_{r_{g}}^{T} G A_{r_{g}} \mathbf{u}_{g}+A_{v_{g}}^{T} \mathbf{i}_{v}+=-A_{i_{g}}^{T} \mathbf{i}_{i} \tag{1}
\end{equation*}
$$

with unknown vectors $\mathbf{u}_{g}$ and $\mathbf{i}_{v}$.
5. Identify the ordinary and generalized nodes.

Define a generalized node to be any set of nodes connected by a path of voltage sources. Any node to which no voltage source is connected is called an ordinary node. To identify ordinary and generalized nodes, we use the deactivated circuit heuristic in which we deactivate the power sources by setting the value of each independent source to zero. This is equivalent to drawing a deactivated resistor network where we replace the voltage sources with short circuits and current sources with open circuits.
6. Create a minimal set of independent node potentials.

6 A . Impose one constraint for each voltage source.
Start with the element-specific KVLs from step 4C and focus on the voltage-source general linear-systems problem in the form

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

Produce a complete solution to the voltage-source KVLs in the form

$$
\mathbf{u}_{g}=\mathbf{p}_{g}+Z_{v_{g}} \mathbf{u}_{f}
$$

where $\mathbf{p}_{g} \in \mathbb{R}^{n_{g}}$ is a particular solution, the columns of $Z_{v_{g}} \in \mathbb{R}^{n_{g} \times n_{f}}$ form a basis for $\operatorname{Nul}\left(A_{v_{g}}\right)$, the dimension $n_{f}=n_{g}-m_{v}$ represents the number of free variables, and $\mathbf{u}_{\mathbf{f}} \in \mathbb{R}^{n_{f}}$ is the vector of free variables.

6B. Impose a single constraint for the ground node.
Choose a single ground node from the remaining $\left(n_{g}-m_{v}\right)$ free variables and shift the corresponding entry of the vector $\mathbf{u}_{f}$ from unknown to known. Realize this dimension reduction using multiplication with deflation matrix $D_{f_{0}} \in \mathbb{R}^{n_{f} \times n}$ where the vector

$$
\mathbf{u}=D_{f_{0}}^{T} \mathbf{u}_{f}
$$

stores the minimal list of independent variables needed to fully analyze the circuit. 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 as seen below.

6C. Combine the constraints together.
Create the completely reduced solution to the voltage-source KVLs given by

$$
\begin{equation*}
\mathbf{u}_{g}=\mathbf{p}_{g}+Z \mathbf{u} \quad \text { where } \quad Z=Z_{v_{g}} D_{f_{0}} \tag{2}
\end{equation*}
$$

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 as seen below.
7. State and solve the equilibrium equation for the circuit

Define matrices

$$
A_{r}=A_{r_{g}} Z, \quad A_{v_{g}} Z=0, \quad \text { and } \quad A_{i}=A_{i_{g}} Z
$$

Looking back at the combined circuit equations (1) from step 4D, we replace vector $\mathbf{u}_{g}$ with our completely reduced solution (2) from step 6 C . Then we multiply the entire equation (1) on the left-hand side by the matrix $Z^{T}$. This yields the matrix equation

$$
\begin{equation*}
A_{r}^{T} G A_{r} \mathbf{u}=A_{r}^{T} G \mathbf{b}-\mathbf{f} \tag{3}
\end{equation*}
$$

where $\mathbf{b}=-A_{r_{g}} \mathbf{p}_{g}$ and $\mathbf{f}=A_{i}^{T} \mathbf{i}_{i}$. Solve this equation using any method. For almost any circuit that is used in real-world applications, the stiffness matrix $K=A_{r}^{T} G A_{r}$ is nonsingular.

OUTPUT:

This algorithm outputs the modeled values for all independent node voltage potentials. We can then use these node potential to solve for any circuit variable we desire.

