Powerflow

The power flow problem is about the calculation of voltage magnitudes and angles for one set of buses. The solution is obtained from a given set of voltage magnitudes and power levels for a specific model of the network configuration. The power flow solution exhibits the voltages and angles at all buses and real and reactive flows can be deduced from the same.

Power System Model

Power systems are modeled as a network of buses (nodes) and branches (lines). To a network bus, components such a generator, load, and transmission substation can be connected. Each bus in the network is fully described by the following four electrical quantities:

  • Vk\vert V_{k} \vert: the voltage magnitude
  • θk\theta_{k}: the voltage phase angle
  • PkP_{k}: the active power
  • QkQ_{k}: the reactive power

There are three types of networks buses: VD bus, PV bus and PQ bus. Depending on the type of the bus, two of the four electrical quantities are specified as shown in the table below.

Bus TypeKnownUnknown
VDVDVk,θk\vert V_{k} \vert, \theta_{k}Pk,QkP_{k}, Q_{k}
PVPVPk,VkP_{k}, \vert V_{k} \vertQk,θkQ_{k}, \theta_{k}
PQPQPk,QkP_{k}, Q_{k}Vk,θk\vert V_{k} \vert, \theta_{k}

Single Phase Power Flow Problem

The power flow problem can be expressed by the goal to bring a mismatch function f\vec{f} to zero. The value of the mismatch function depends on a solution vector x\vec{x}: f(x)=0 \vec{f}(\vec{x}) = 0

As f(x)\vec{f}(\vec{x}) will be nonlinear, the equation system will be solved with Newton-Raphson:

J(x)Δx=f(x)-\textbf{J}(\vec{x}) \Delta \vec{x} = \vec{f} (\vec{x})

where Δx\Delta \vec{x} is the correction of the solution vector and J(x)\textbf{J}(\vec{x}) is the Jacobian matrix. The solution vector x\vec{x} represents the voltage V\vec{V} by polar or cartesian quantities. The mismatch function f\vec{f} will either represent the power mismatch ΔS\Delta \vec{S} in terms of

[ΔP ΔQ]\left [ \begin{array}{c} \Delta \vec{P} \ \Delta \vec{Q} \end{array} \right ]

or the current mismatch ΔI\Delta \vec{I} in terms of

[ΔIreal ΔIimag]\left [ \begin{array}{c} \Delta \vec{I_{real}} \ \Delta \vec{I_{imag}} \end{array} \right ]

where the vectors split the complex quantities into real and imaginary parts. Futhermore, the solution vector x\vec{x} will represent V\vec{V} either by polar coordinates

[δ V]\left [ \begin{array}{c} \vec{\delta} \ \vert \vec{V} \vert \end{array} \right ]

or rectangular coordinates

[Vreal Vimag]\left [ \begin{array}{c} \vec{V_{real}} \ \vec{V_{imag}} \end{array} \right ]

This results in four different formulations of the powerflow problem:

  • with power mismatch function and polar coordinates
  • with power mismatch function and rectangular coordinates
  • with current mismatch function and polar coordinates
  • with current mismatch function and rectangular coordinates

To solve the problem using NR, we need to formulate J(x)\textbf{J} (\vec{x}) and f(x)\vec{f} (\vec{x}) for each powerflow problem formulation.

Powerflow Problem with Power Mismatch Function and Polar Coordinates

Formulation of Mismatch Function

The injected power at a node kk is given by: Sk=VkIkS_{k} = V_{k} I _{k}^{*}

The current injection into any bus kk may be expressed as: Ik=j=1NYkjVj I_{k} = \sum_{j=1}^{N} Y_{kj} V_{j}

Substitution yields:

Sk=Vk(j=1NYkjVj)=Vkj=1NYkjVj\begin{align} S_{k} &= V_{k} \left ( \sum_{j=1}^{N} Y_{kj} V_{j} \right )^{*} \nonumber \\ &= V_{k} \sum_{j=1}^{N} Y_{kj}^{*} V_{j} ^{*} \nonumber \end{align}

We may define GkjG_{kj} and BkjB_{kj} as the real and imaginary parts of the admittance matrix element YkjY_{kj} respectively, so that Ykj=Gkj+jBkjY_{kj} = G_{kj} + jB_{kj}. Then we may rewrite the last equation:

Sk=Vkj=1NYkjVj=Vkθkj=1N(Gkj+jBkj)(Vjθj)=Vkθkj=1N(GkjjBkj)(Vjθj)=j=1NVkθk(Vjθj)(GkjjBkj)=j=1N(VkVj(θkθj))(GkjjBkj)=j=1NVkVj(cos(θkθj)+jsin(θkθj))(GkjjBkj)\begin{align} S_{k} &= V_{k} \sum_{j=1}^{N} Y_{kj}^{*} V_{j}^{*} \nonumber \\ &= \vert V_{k} \vert \angle \theta_{k} \sum_{j=1}^{N} (G_{kj} + jB_{kj})^{*} ( \vert V_{j} \vert \angle \theta_{j})^{*} \nonumber \\ &= \vert V_{k} \vert \angle \theta_{k} \sum_{j=1}^{N} (G_{kj} - jB_{kj}) ( \vert V_{j} \vert \angle - \theta_{j}) \nonumber \\ &= \sum_{j=1} ^{N} \vert V_{k} \vert \angle \theta_{k} ( \vert V_{j} \vert \angle - \theta_{j}) (G_{kj} - jB_{kj}) \nonumber \\ &= \sum_{j=1} ^{N} \left ( \vert V_{k} \vert \vert V_{j} \vert \angle (\theta_{k} - \theta_{j}) \right ) (G_{kj} - jB_{kj}) \nonumber \\ &= \sum_{j=1} ^{N} \vert V_{k} \vert \vert V_{j} \vert \left ( cos(\theta_{k} - \theta_{j}) + jsin(\theta_{k} - \theta_{j}) \right ) (G_{kj} - jB_{kj}) \end{align}

If we now perform the algebraic multiplication of the two terms inside the parentheses, and collect real and imaginary parts, and recall that Sk=Pk+jQkS_{k} = P_{k} + jQ_{k}, we can express (1) as two equations: one for the real part, PkP_{k}, and one for the imaginary part, QkQ_{k}, according to:

Pk=j=1NVkVj(Gkjcos(θkθj)+Bkjsin(θkθj))Qk=j=1NVkVj(Gkjsin(θkθj)Bkjcos(θkθj))\begin{align} {P}_{k} = \sum_{j=1}^{N} \vert V_{k} \vert \vert V_{j} \vert \left ( G_{kj}cos(\theta_{k} - \theta_{j}) + B_{kj} sin(\theta_{k} - \theta_{j}) \right ) \\ {Q}_{k} = \sum_{j=1}^{N} \vert V_{k} \vert \vert V_{j} \vert \left ( G_{kj}sin(\theta_{k} - \theta_{j}) - B_{kj} cos(\theta_{k} - \theta_{j}) \right ) \end{align}

These equations are called the power flow equations, and they form the fundamental building block from which we solve the power flow problem.

We consider a power system network having NN buses. We assume one VD bus, NPV1N_{PV}-1 PV buses and NNPVN-N_{PV} PQ buses. We assume that the VD bus is numbered bus 11, the PV buses are numbered 2,,NPV2,…,N_{PV}, and the PQ buses are numbered NPV+1,,NN_{PV}+1,…,N. We define the vector of unknown as the composite vector of unknown angles θ\vec{\theta} and voltage magnitudes V\vert \vec{V} \vert:

x=[θV]=[θ2θ3θNVNPV+1VNPV+2VN]\begin{align} \vec{x} = \left[ \begin{array}{c} \vec{\theta} \\ \vert \vec{V} \vert \\ \end{array} \right ] = \left[ \begin{array}{c} \theta_{2} \\ \theta_{3} \\ \vdots \\ \theta_{N} \\ \vert V_{N_{PV+1}} \vert \\ \vert V_{N_{PV+2}} \vert \\ \vdots \\ \vert V_{N} \vert \end{array} \right] \end{align}

The right-hand sides of equations (2) and (3) depend on the elements of the unknown vector x\vec{x}. Expressing this dependency more explicitly, we rewrite these equations as:

Pk=Pk(x)Pk(x)Pk=0k=2,...,NQk=Qk(x)Qk(x)Qk=0k=NPV+1,...,N\begin{align} P_{k} = P_{k} (\vec{x}) \Rightarrow P_{k}(\vec{x}) - P_{k} &= 0 \quad \quad k = 2,...,N \\ Q_{k} = Q_{k} (\vec{x}) \Rightarrow Q_{k} (\vec{x}) - Q_{k} &= 0 \quad \quad k = N_{PV}+1,...,N \end{align}

We now define the mismatch vector f(x)\vec{f} (\vec{x}) as:

f(x)=[f1(x)fN1(x)fN(x)f2NNPV1(x)]=[P2(x)P2PN(x)PNQNPV+1(x)QNPV+1QN(x)QN]=[ΔP2ΔPNΔQNPV+1ΔQN]=0\begin{align} \vec{f} (\vec{x}) = \left [ \begin{array}{c} f_{1}(\vec{x}) \\ \vdots \\ f_{N-1}(\vec{x}) \\ ------ \\ f_{N}(\vec{x}) \\ \vdots \\ f_{2N-N_{PV} -1}(\vec{x}) \end{array} \right ] = \left [ \begin{array}{c} P_{2}(\vec{x}) - P_{2} \\ \vdots \\ P_{N}(\vec{x}) - P_{N} \\ --------- \\ Q_{N_{PV}+1}(\vec{x}) - Q_{N_{PV}+1} \\ \vdots \\ Q_{N}(\vec{x}) - Q_{N} \end{array} \right] = \left [ \begin{array}{c} \Delta P_{2} \\ \vdots \\ \Delta P_{N} \\ ------ \\ \Delta Q_{N_{PV}+1} \\ \vdots \\ \Delta Q_{N} \end{array} \right ] = \vec{0} \end{align}

That is a system of nonlinear equations. This nonlinearity comes from the fact that PkP_{k} and QkQ_{k} have terms containing products of some of the unknowns and also terms containing trigonometric functions of some the unknowns.

Formulation of Jacobian

As discussed in the previous section, the power flow problem will be solved using the Newton-Raphson method. Here, the Jacobian matrix is obtained by taking all first-order partial derivates of the power mismatch functions with respect to the voltage angles θk\theta_{k} and magnitudes Vk\vert V_{k} \vert as:

JjkPθ=Pj(x)θk=VjVk(Gjksin(θjθk)Bjkcos(θjθk))JjjPθ=Pj(x)θj=Qj(x)BjjVj2JjkQθ=Qj(x)θk=VjVk(Gjkcos(θjθk)+Bjksin(θjθk))JjjQθ=Qj(x)θk=Pj(x)GjjVj2JjkPV=Pj(x)Vk=Vj(Gjkcos(θjθk)+Bjksin(θjθk))JjjPV=Pj(x)Vj=Pj(x)Vj+GjjVjJjkQV=Qj(x)Vk=Vj(Gjksin(θjθk)+Bjkcos(θjθk))JjjQV=Qj(x)Vj=Qj(x)VjBjjVj\begin{align} J_{jk}^{P \theta} &= \frac{\partial P_{j} (\vec{x} ) } {\partial \theta_{k}} = \vert V_{j} \vert \vert V_{k} \vert \left ( G_{jk} sin(\theta_{j} - \theta_{k}) - B_{jk} cos(\theta_{j} - \theta_{k} ) \right ) \\ J_{jj}^{P \theta} &= \frac{\partial P_{j}(\vec{x})}{\partial \theta_{j}} = -Q_{j} (\vec{x} ) - B_{jj} \vert V_{j} \vert ^{2} \\ J_{jk}^{Q \theta} &= \frac{\partial Q_{j}(\vec{x})}{\partial \theta_{k}} = - \vert V_{j} \vert \vert V_{k} \vert \left ( G_{jk} cos(\theta_{j} - \theta_{k}) + B_{jk} sin(\theta_{j} - \theta_{k}) \right ) \\ J_{jj}^{Q \theta} &= \frac{\partial Q_{j}(\vec{x})}{\partial \theta_{k}} = P_{j} (\vec{x} ) - G_{jj} \vert V_{j} \vert ^{2} \\ J_{jk}^{PV} &= \frac{\partial P_{j} (\vec{x} ) } {\partial \vert V_{k} \vert } = \vert V_{j} \vert \left ( G_{jk} cos(\theta_{j} - \theta_{k}) + B_{jk} sin(\theta_{j} - \theta_{k}) \right ) \\ J_{jj}^{PV} &= \frac{\partial P_{j}(\vec{x})}{\partial \vert V_{j} \vert } = \frac{P_{j} (\vec{x} )}{\vert V_{j} \vert} + G_{jj} \vert V_{j} \vert \\ J_{jk}^{QV} &= \frac{\partial Q_{j} (\vec{x} ) } {\partial \vert V_{k} \vert } = \vert V_{j} \vert \left ( G_{jk} sin(\theta_{j} - \theta_{k}) + B_{jk} cos(\theta_{j} - \theta_{k}) \right ) \\ J_{jj}^{QV} &= \frac{\partial Q_{j}(\vec{x})}{\partial \vert V_{j} \vert } = \frac{Q_{j} (\vec{x} )}{\vert V_{j} \vert} - B_{jj} \vert V_{j} \vert \\ \end{align}

The linear system of equations that is solved in every Newton iteration can be written in matrix form as follows:

[ΔP2θ2ΔP2θNΔP2VNG+1ΔP2VNΔPNθ2ΔPNθNΔPNVNG+1ΔPNVNΔQNG+1θ2ΔQNG+1θNΔQNG+1VNG+1ΔQNG+1VNΔQNθ2ΔQNθNΔQNVNG+1ΔQNVN][Δθ2ΔθNΔVNG+1ΔVN]=[ΔP2ΔPNΔQNG+1ΔQN]\begin{align} -\left [ \begin{array}{cccccc} \frac{\partial \Delta P_{2} }{\partial \theta_{2}} & \cdots & \frac{\partial \Delta P_{2} }{\partial \theta_{N}} & \frac{\partial \Delta P_{2} }{\partial \vert V_{N_{G+1}} \vert} & \cdots & \frac{\partial \Delta P_{2} }{\partial \vert V_{N} \vert} \\ \vdots & \ddots & \vdots & \vdots & \ddots & \vdots \\ \frac{\partial \Delta P_{N} }{\partial \theta_{2}} & \cdots & \frac{\partial \Delta P_{N}}{\partial \theta_{N}} & \frac{\partial \Delta P_{N}}{\partial \vert V_{N_{G+1}} \vert } & \cdots & \frac{\partial \Delta P_{N}}{\partial \vert V_{N} \vert} \\ \frac{\partial \Delta Q_{N_{G+1}} }{\partial \theta_{2}} & \cdots & \frac{\partial \Delta Q_{N_{G+1}} }{\partial \theta_{N}} & \frac{\partial \Delta Q_{N_{G+1}} }{\partial \vert V_{N_{G+1}} \vert } & \cdots & \frac{\partial \Delta Q_{N_{G+1}} }{\partial \vert V_{N} \vert} \\ \vdots & \ddots & \vdots & \vdots & \ddots & \vdots \\ \frac{\partial \Delta Q_{N}}{\partial \theta_{2}} & \cdots & \frac{\partial \Delta Q_{N}}{\partial \theta_{N}} & \frac{\partial \Delta Q_{N}}{\partial \vert V_{N_{G+1}} \vert } & \cdots & \frac{\partial \Delta Q_{N}}{\partial \vert V_{N} \vert} \end{array} \right ] \left [ \begin{array}{c} \Delta \theta_{2} \\ \vdots \\ \Delta \theta_{N} \\ \Delta \vert V_{N_{G+1}} \vert \\ \vdots \\ \Delta \vert V_{N} \vert \end{array} \right ] = \left [ \begin{array}{c} \Delta P_{2} \\ \vdots \\ \Delta P_{N} \\ \Delta Q_{N_{G+1}} \\ \vdots \\ \Delta Q_{N} \end{array} \right ] \end{align}

Solution of the Problem

The solution update formula is given by:

x(i+1)=x(i)+Δx(i)=x(i)J1f(x(i))\begin{align} \vec{x}^{(i+1)} = \vec{x}^{(i)} + \Delta \vec{x}^{(i)} = \vec{x}^{(i)} - \textbf{J}^{-1} \vec{f} (\vec{x}^{(i)}) \end{align}

To sum up, the NR algorithm, for application to the power flow problem is:

  1. Set the iteration counter to i=1i=1. Use the initial solution Vi=10V_{i} = 1 \angle 0^{\circ}
  2. Compute the mismatch vector f(x)\vec{f}({\vec{x}}) using the power flow equations
  3. Perform the following stopping criterion tests:
    • If ΔPi<ϵP\vert \Delta P_{i} \vert < \epsilon_{P} for all type PQ and PV buses and
    • If ΔQi<ϵQ\vert \Delta Q_{i} \vert < \epsilon_{Q} for all type PQ
    • Then go to step 6
    • Otherwise, go to step 4.
  4. Evaluate the Jacobian matrix J(i)\textbf{J}^{(i)} and compute Δx(i)\Delta \vec{x}^{(i)}.
  5. Compute the update solution vector x(i+1)\vec{x}^{(i+1)}. Return to step 3.
  6. Stop.