In this paper, the implementation of a sequential AC/DC power flow computation algorithm for Multi-terminal Voltage Source Converter High Voltage Direct Current (VSC MTDC) systems is discussed. The already available models for two-terminal Voltage Source Converter High Voltage Direct Current (VSC HVDC) presented in literature have certain shortcomings and are often not general enough, which can impede their extension to MTDC models. Due to a general formulation of the problem, the proposed algorithm allows to incorporate multiple DC grids with arbitrary topologies. The algorithm includes converter station losses and allows to access the DC grid variables in a way similar to AC power flow programs.
Introduction
The power engineering world is showing an increasing interest in transmission schemes based on High Voltage Direct Current (HVDC) technology in Multi-Terminal (MTDC) configurations. Suggestions have been made to construct whole new overlaying DC supergrids to connect the growing share of renewable energy sources. The DC grids could be even offshore, connecting various offshore wind farms and other renewable energy sources. A lot of research has already been carried out on the incorporation of MTDC technology based on Current Source Converter (CSC HVDC) in power flow algorithms [1, 2] . Voltage Source Converter High Voltage Direct Current technology (VSC HVDC) has much better prospects for an operation in a multi-terminal configuration than CSC HVDC, hence justifying the need for a general approach. However, the two-terminal VSC HVDC models used in commercial software and presented in literature have certain shortcomings and are often not general enough, which can impede their extension to MTDC models. This paper discusses the implementation of a general sequential AC/DC power flow computation algorithm that can incoorperate multiple DC grids with arbitrary grid topologies in AC power flow programs. The remainder of this paper is organised as follows: In a second section, the assumptions made and the errors introduced in the available approximate models for two-terminal VSC HVDC systems are illustrated. The paper also discusses the possibilities of extending these approximate models to MTDC systems and summarises earlier attempts to incorporate VSC MTDC models in AC power flows. The third section discusses a fully flexible sequential AC/DC power flow computation algorithm that overcomes the shortcomings of the already available models and is capable of solving multiple MTDC systems. The algorithm elaborates further on the general approach presented in [3] , with a focus on the implementation aspects. It is shown that a well thought-out renumbering of both AC and DC buses allows a simple integration of multiple DC grids, which can have fully arbitrary grid topologies with respect to the underlying AC system. The extended algorithm allows to include DC buses without an AC grid connection, as well as converter and line outages. Finally, simulation results are discussed in the fourth section. The results are obtained by integrating the proposed sequential approach into MATPOWER [4] , the open source Matlab toolbox.
VSC HVDC Representation
This section addresses the modelling of both two-terminal VSC HVDC systems and MTDC systems available in literature and commercial software. A first part introduces a general model for a VSC HVDC system. The second part addresses the simplifications that have been made in previously published work and commercial software tools. Fig. 1 shows a general 3-phase representation of a VSC Converter station, constituting of a transformer, low pass filters and phase reactors. The filtering requirements are dependent on the technology and on the switching method used to synthesise the converter voltage U c . Their effect at the fundamental grid frequency can be represented by a shunt capacitor. The recently developed multimodular converter (MMC) approach does not need low pass filtering since the voltage waveforms can be synthesised without a Pulse Width Modulation (PWM) technique. In this paper, the filters are not included. They can be easily represented by shunt capacitances at the filter bus, as done in commercial software tools such as PSS/E. The converter equations reduce to these of an impedance with a controllable converter voltage. With U s = U s ∠δ s the AC bus voltage, U c = U c ∠δ c the converter bus voltage and Z c = G c + B c the complex equivalent impedance, the equations for the power injected into the AC grid are given by
System layout
The power flowing to the AC network at the converter end can be written as
A general converter model should also incorporate the converter losses, which are taken into account in this paper by a formula quadratically depending on the converter current I c [5] . As shown in the remainder of this paper, the inclusion of the converter losses introduces an additional iterative calculation in the sequential AC/DC power flow. With regard to the AC grid, the converter can either control its reactive power output (Q-control) or adapt its reactive power output to keep up the voltage at the system bus (V -control). All converters can also independently control their active power injection (P -control). In a two-terminal VSC HVDC system, one of the two converters is assigned the task of the DC slack and it therefore adapts its active power output to keep up its DC voltage U dc . Extending this principle to a MTDC system with n buses, results in one DC slack bus per DC grid and n − 1 buses that can be either in P V or P Q-control. Contrary to stability studies [6] , the DC capacitor can be omitted, as well as the distributed DC line capacitance and inductance since only steady state is addressed. All DC lines can thus be represented as lumped resistances if leakage currents are neglected.
Simplified steady-state models
A two-terminal VSC HVDC link can be incorporated in power flow programs in different ways. The complexity of the combined AC/DC power flow algorithm depends on the details of the model and on the assumptions. This part briefly discusses different representations and addresses how assumptions and simplifications can impede the extension of these models to a MTDC system. As discussed above, a VSC can be represented in power flow programs as a voltage source behind a reactance. The VSC therefore shows a steady-state behaviour that is similar to that of a synchronous generator. When the power injections are defined with respect to the system bus instead of the converter bus, as is
23-24
Siemens Energy, Inc., Power Technologies International 
VSCDYN Module
The VSCDYN module has been developed to represent the control functions of a VSC converter. The VSCDYN module recognizes the following actions by the controls:
• AC voltage control or reactive power control,
• Active power control or DC voltage control, and
• Current output limitation.
Additionally, the VSCDYN module accommodates the following actions by the user:
• Power ramping, and
• Converter blocking.
Active Power Reference Regulation
Typically, the active power order is set manually and power stepping unit carries out the ramping of power order reference. The VSCDYN module has provision for accepting a power order directly (P_aux) via VAR(L) for VSC # 1 or VAR(L+12) for VSC #2. The model also has provision for receiving a power order from the DCLINE module via VAR(L+7) for VSC # 1 or VAR(L+19) for VSC # 2. When in the stand-alone operating mode, this power order value remains constant, as set during initialization.
In normal operation of a two-terminal VSC dc system, active power is controlled in one station while the other converter controls dc voltage. The user specifies whether a VSC is in active power or dc voltage control by the TYPE parameter in power flow input data.
AC Voltage Control
The AC Voltage Control function varies the reactive power order to control the ac voltage at the regulated bus. The regulated bus is the ac filter bus by default, however, the user can specify any remote bus by entering the bus number via ICON(M+1) for VSC # 1 and ICON(M+3) for VSC # 2.
If these values are zero, the model takes the bus numbers from the power flow input data, REMOT parameter. In a VSC dc system, the AC Voltage Control is independent in each VSC.
The AC Voltage Control has the provision for droop (CON(J+6) for VSC # 1, or CON(J+19) for VSC # 2), to be included in the function to effectively alter the voltage reference point. This feature allows Figure 2 . PSS/E model [7] . is used. The ac filters are represented by an equivalent reactive power shunt element, i.e. capacitor.
5(35)
The dynamic behaviour of the dc transmission is modelled by introducing the two user models DC_HL2 and CHVDCL interacting with the representation in the load flow model and with each other as shown in Figure 1 .
One of the converters/stations is named the:
• First converter and the other the
This naming is only to give the converters different references. There is no priority or differences in controls based on this naming. Either converter can operate in inverter or rectifier mode.
One of the converters is in dc voltage control and the other is in active power control. Either of these can be the converter operating in inverter or rectifier mode. Each of the converters can independently be set in ac voltage or reactive power control mode. 
DC_HL2

First converter
DC system
The dynamic model, DC_HL2, represents the dynamic behaviour of the dc system. In general the model is based on a simple sT 1 block where T corresponds to the time constants of the capacitances in the dc system:
• dc capacitance of the two converters
• dc cable capacitance
In addition to the dynamic behaviour, the model includes the losses in the system:
• Load losses Figure 3 . HVDC Light model [8] .
often done to simplify calculations, the VSC can be represented as a P Q node or as a P V node when under voltage control. However, there exists a relationship between the active powers of the different converters as the slack bus converter adapts its power output to keep up the DC grid voltage. For a two-terminal system, the slack bus active power setpoint P * s,1 can be written as P * s,1 = P * s,1 − P loss with P loss the overall system losses, including both converter losses and DC line losses. This simplified two-terminal model is often used in commercial software due to its easy integration in existing power flow algorithms. As a disadvantage, the DC system is not accessible and all information on internal DC variables is therefore lacking. As the overall VSC HVDC system losses are not known beforehand, the overall results are only as good as the approximation of these losses. Two commercially available VSC HVDC models, both implemented in PSS/E, are briefly discussed in the remainder of this part to make a comparison with the generalised model discussed in this paper. The first model comes with PSS/E. The second model, the ABB HVDC Light model [8] , is a manufacturer developed model. The PSS/E model in Fig. 2 consists of three modules: two converter modules and a DC line model. The power injections and voltage setpoint are specified with respect to the filter bus. Transformers and filters have to be modelled explicitly by adding a transformer branch and a fixed or switched shunt reactance at the filter bus. The model does not support multi-terminal calculations. The PSS/E model is of the simplified type, with a few additions such as operating limits and a loss model. The HVDC Light model, represented in Fig. 3 , has been developed to serve as a starting point for dynamic simulations. The converters are modelled as generators and no DC line is modelled. The model is thus of the simplified type. As in the PSS/E model, filters and transformers are added separately. In both models, the converter bus is not accessible. The PSS/E model includes a linear loss model, whereas the HVDC Light model does not include losses.
P loss,j convdc busdc branchdc Figure 4 . Subdivision of the DC system data in matrices.
Due to the simplifications in available models, there is a need for a more general approach to include DC grids in power flow calculations. Most of the methods previously presented in literature are not general enough and suffer from the same drawbacks as the commercial models: In [9] an approximate solution is obtained by neglecting converter losses and losses in the phase reactor, whereas in [10] converter losses are neglected, DC variables are not accessible and the power flow setpoints are defined at the converter bus instead of the system bus. This simplifies the calculations, but is not in accordance with current practice in actual VSC HVDC systems. A unified power flow approach was presented in [11] . However, the DC grid was not explicitly represented in the model. The next sections discusses the implementation aspects and mathematical modelling of a more general representation of VSC MTDC grids.
VSC MTDC Implementation
In this part, the implementation of a general AC/DC power flow algorithm [3] is discussed. Meanwhile, the algorithm is extended and a bus renumbering algorithm is proposed to introduce floating DC buses without a connection to the underlying AC grid. The extension also allows an easy integration of multiple DC grids, converter outages and branch outages. After presenting the data input together with the bus renumbering, a second part of this section addresses the modelling of the DC grid, the interconnection with the AC grid and the sequential power flow procedure.
Data input and preparation
The DC network data and converter parameters are handled in a way similar to the AC network representation in MAT-POWER, where a distinction is made between bus, gen and branch matrices. They respectively contain all data of the AC buses, the synchronous generators and the AC lines and cables. The AC/DC power flow program adds busdc, convdc and branchdc matrices to this set, which fulfill a similar role in the DC grid as their AC counterparts do in the AC grid. Fig. 4 shows how all DC power flow data is related to these matrices for an arbitrary converter linking AC bus i and DC bus j. Similar to the bus matrix in the AC power flow, the busdc matrix contains power injections and bus voltages. The matrix also contains information on the connection of the DC buses with AC buses. The convdc matrix contains all converter data and forms the actual link between the AC and DC grids. The matrix contains input data such as loss coefficients and converter reactances as well as output data such as converter losses and powers and voltages at the converter bus. The converters fulfill a role to the DC grid similar to that of the generators in an AC grid. Finally, matrix branchdc links the different DC buses and contains all line parameters. Fig. 5 shows the interconnection of an AC grid with v buses and x DC grids with a total of w buses. Without lack of generality, we assume the last AC bus v to be connected to the x-th DC grid. With v > w, there are v − w AC buses without a connection to a DC grid. The DC buses have been numbered in a logical order for convenience, although the algorithm does not impose any restrictions to the numbering of the DC buses as such. Each grid can have an arbitrary number of converter-connected DC buses, as well as DC buses without an AC interconnection (e.g. DC bus 2 in grid 1) and DC buses facing a converter outage (e.g. DC bus j in grid 1). The numbering of all converter data refers to the corresponding DC bus. The different bus indices for the AC grid and the DC grids result in a maximum flexibility for the user to enter the different grid layouts in the power flow algorithm. However, this double numbering hampers a straight-forward implementation of the algorithm. After a per unit conversion of the AC and DC grid quantities, the sorting algorithm depicted in Fig. 6 renumbers the DC and AC buses to overcome these difficulties. After renumbering the DC buses and sorting them per DC grid, the algorithm groups converter-connected DC buses and renames their AC buses correspondingly, e.g. buses 1 to k for the first DC grid in Fig. 6 . Thereafter, arbitrary AC buses without DC connections are assigned to the DC buses without an AC connection, e.g. buses k + 1 to n in Fig. 6 . All converter outages are considered equally to DC buses without a converter. The renumbering allows an easy and straightforward access to both AC grid and DC grid variables during the power flow without compromising the flexibility of the user interface. The Figure 6 . AC-DC interconnection scheme after renumbering.
next section briefly discusses the mathematical modelling of the sequential power flow algorithm. 
Mathematical modelling
Dummy AC generators are included for converters in V -control, as their reactive power injection is unknown prior to the AC power flow. Meanwhile, the AC buses to which these converters are connected, are changed from P Q-nodes into P V -nodes. The active power injection P s of the DC slack buses is adapted to keep up the voltage of the DC grids. As a first estimate, all converter stations as well as the DC grids are assumed to be lossless. To simplify notation, but without loss of generality, we assume the first converter of every grid to be the DC slack bus converter. Hence, for the first DC grid, we can write:
For the k th iteration, the solution from the previous iteration cycle is used as an estimate for P (k) s,1 . After calculating all converter side powers S c , voltages U c and converter losses P loss , the power injections into the DC grids are known.
The power flows in the DC grid itself can be obtained in a way similar to those in an AC grid. The current injected at a DC node i can be written as the current flowing to the other n − 1 nodes in the network:
with Y dc,ij equal to 1/R dc,ij . Combining all currents injected in the DC network results in
with I dc = [I dc,1 , I dc,2 . . . I dc,k , 0 . . . 0] T the DC current vector with n − k zero elements due to floating DC buses and converter outages,
T the DC voltage vector and Y dc the DC bus matrix. When line outages are taken into account, the DC bus matrix needs to be updated accordingly. Assuming a monopolar, symmetrically grounded DC grid, the active power injected in node i can be written as
The current injections I dc are not known prior to the power flow solution for the DC grid, whereas the active power injections P dc are known for all buses except for the DC slack bus as a results of the AC power flow. Combining (9) and (10) results in a system of non-linear equations:
With the first converter as the DC slack bus, the vector of the unknowns can now be written as
The DC bus admittance matrix of the first DC grid is partitioned as follows:
with y 11 a scalar, Y 12 a row vector of length n − 1, Y 21 a column vector of length n−1, and Y 22 a matrix of dimension (n−1) × (n−1). This leads to a system of equations that can be solved by an iterative Newton method:
with
Explicitly representing the DC circuit without a prior knowledge of the injected currents thus results in an additional iterative calculation.
The same methodology can now be applied to all other DC grids.
Combining all DC bus matrices Y dcj of the DC grids in one matrix results in a sparse band matrix Y dc :
Writing (14) - (15) for all DC grids results in a system of w equations, with x equations in the form of (14), that can be jointly solved with one iterative method. After convergence, the DC line currents can easily be obtained by premultiplying the DC bus voltage vector U dc by the system branch admittance matrices Y dcf and Y dct , which are obtained as a byproduct of the construction of the DC bus matrix Y dc . After solving the DC network power flow, an additional iterative calculation is needed to recalculate the slack buses' power injections into the AC grid. In [3] , it was suggested not to alter the AC grid state during this additional iteration: the grid side voltage of all slack buses U s,1 is thus kept constant (both in magnitude and phase angle), as well as the reactive power grid injection Q s,1 , while the converter active power injection P c,1 is iteratively updated. As an alternative to this approach, the reactive power injection at the converter bus Q c,1 can be kept constant as well. However, it was found that a constant value of Q s,1 results in less overall iteration cycles, due to the stronger relationship between Q s,1 and U s,1 , which is also kept constant during one overall iteration cycle. After a convergence of all slack buses' power injections, the AC grid values are updated until overall convergence is reached.
Simulation results
The proposed AC/VSC MTDC power flow algorithm has been integrated with MATPOWER the Polish 400, 220 and 110 kV networks during winter evening peak conditions. The results of the 8-bus network are withheld in this paper. All AC line data are obtained from the test network in [12] . One of the VSC HVDC systems is a 5 terminal meshed DC grid with 6 DC buses, the other system is a two-terminal link. With a tolerance of 1e-8 p.u. for the slack bus powers P s , the sequential algorithm converges in 4 overall iterations, with an increase of the calculation time by a factor 10 when compared to the AC power flow without the MTDC systems. Based on 1000 subsequent simulations, the main contributions are 33% to calculate the AC power flows, 54% to calculate the DC power flows and 11% for the slack bus iterations.
Figs. 8 -9 show the power flows in the AC and DC systems, respectively without and with the MTDC systems. Tables 1 -2 show the bus voltages and converter quantities. The converters at DC buses 1 and 8 are the DC slack buses of the two different DC networks and the converters at DC buses 4 and 8 are also controlling the AC system bus voltage (Table 2) . With the MTDC system in operation, the bus voltages are all close to unity due to the voltage control at some of the VSC connected buses and the low residual load on the underlying AC grid. Table 2 . Power flow solution with the VSC MTDC systems -Converter stations.
Conclusion
The general sequential AC/DC power flow algorithm proposed in this paper includes VSC MTDC systems with arbitrary grid topologies in AC power flow programs. Due to a general formulation of the problem and a bus renumbering algorithm, the implementation of the algorithm can also include DC buses without AC connection, as well as converter outages and line outages. The algorithm has been implemented in Matlab and properly tested.
