# SOFTWARE IMPLEMENTATION OF A MODERN VOLTAGE CONTROLLER

### Paul BURLACU<sup>1</sup> Florențiu DELIU<sup>2</sup>

<sup>1</sup>"Mircea cel Batran" Naval Academy Constanta <sup>2</sup>"Mircea cel Batran" Naval Academy Constanta

**Abstract** - This paper presents a real-time software implementation of a robust voltage controller developed for multimachine power system. The software implementation is realized in LabVIEW and the hardware target is a PXI system with analog inputs, analog outputs connected to a power amplifier.

## 1. Introduction

In [1] was developed a robust voltage controller for naval power system. This controller improves the quality of voltage regulation onboard ships, addressing the problem of ships power system quality. The continuous model of the robust controller is put in a discrete form and a software implementation in LabVIEW Real-Time is realized. A real-time hardware is composed from a PXI chassis from National Instruments with DAQ cards. Also a power amplifier is design for connection with the excitation system of the generator.

### 2. Voltage controller model

The controller was developed through H<sub>\*</sub> techniques from the naval power system model developed in [1]. As stated in [1], the equations that describe the bus bar voltages are:

$$u_d = \alpha u_d + \beta u_q + \eta_1 e_f \tag{1}$$

$$u_q = \sigma u_d + \gamma u_q + \eta_2 e_f \tag{2}$$

where the coefficients are functions that depends of generators parameters and system operating point. With the variables defined as:

$$z_1 = \int \left( u_d^2 + u_q^2 - 1 \right) dt$$
(3)

$$z_2 = u_d^2 + u_q^2 - 1 \tag{4}$$

where  $u_d$  and  $u_q$  are bus bar voltages on dq axes, the system is summarized as:

$$z_1 = z_2 \tag{5}$$

$$z_2 = v_1 + \Phi(t)\theta(t) \tag{6}$$

where:

 $v_1$  - a new variable which will control the system.

$$\Phi(t) = \begin{bmatrix} 2u_d^2 & 2u_du_q & 2u_du_q & 2u_q^2 & 2u_de_f & 2u_qe_f \end{bmatrix}$$

$$\theta(t) = \begin{bmatrix} \alpha - \alpha_n \\ \beta - \beta_n \\ \sigma - \sigma_n \\ \gamma - \gamma_n \\ \eta_1 - \eta_{1n} \\ \eta_2 - \eta_{2n} \end{bmatrix}, \text{ vector of variation of the functions from their nominal values.}$$

The excitation voltage is:

$$e_{f} = \frac{v_{1} - f(u_{d}, u_{q})}{g(u_{d}, u_{q})}$$
(7)

Where the f and g functions are defined in [1] and depend on the generators characteristics and system operating point. A new control variable is chosen as:

 $v_2 = v_1 - z_1$ 

79

(8)

With this new variable the system becomes:

$$z_1 = z_2 \tag{9}$$

$$z_2 = z_1 + v_2 + \Phi(t)\theta(t) \tag{10}$$

Choosing the error weight as:

$$W_{e2} = \frac{0.01(s+10)}{s+10^{-9}} \tag{11}$$

perturbation weight:

$$W_p = \frac{1}{\frac{s}{50 \cdot 2 \cdot \pi} + 1} \tag{12}$$

and the control effort weight:

$$W_{act} = \frac{0.05(s+10)}{s+500} \tag{13}$$

The equation of the robust voltage controller is:

$$\mathbf{\dot{x}} = \begin{bmatrix} 0.0005 & 0.00123 & -31.58 & 0 & 0 \\ -5444 & -1103 & -1.697e4 & -1967 & -66.27 \\ 0.000158 & 38.9e - 5 & -9.998 & 0 & 0 \\ -2.295e4 & -2806 & 0 & -1.023e4 & -355.7 \\ 0.007623 & -2.569e4 & -8.124e5 & 0 & -31.42 \end{bmatrix} \mathbf{x} + \begin{bmatrix} 4103 \\ 2.204e6 \\ 1297 \\ 0 \\ 1.055e8 \end{bmatrix} \mathbf{u}$$
(14)  
$$\mathbf{y} = \begin{bmatrix} -132.5 & -13.8 & 0 & -47.88 & -1.75 \end{bmatrix} \mathbf{x}^{T}$$

where:

u-input vector composed from perturbation and additional variables as defined in [1].

The control signal (excitation voltage) is:

$$e_{f} = \frac{v_{1} - f(u_{d}, u_{q})}{g(u_{d}, u_{q})} = \frac{v_{2} + \int z_{2} - f(u_{d}, u_{q})}{g(u_{d}, u_{q})}$$
(15)

#### 3. Software and hardware implementation

The software used was LabVIEW Real-Time. The application controls duty cycle of a PWM signal connected to a DC to DC buck converter. The converter feeds directly the field winding of the synchronous generator.

The application has a user interface and through an embedded web server the operator can change the parameters online and view the current status of the controller.

The main applications have a configuring front panel as in figure 1. The timing of the acquisition and software loop is based on the analog input clock. The acquisition of the bus bar voltage is made as hardware timed single point.

The transformation of the *abc* to *dq*coordinates are made with a subVI presented in figure 2. The robust controller is implemented as a subVI with inputs the  $v_d$  and  $v_q$  from the acquisition and the output is feed to the counter pin of the dag card.

| DAQ CONFIGURATION                              |                                                                                      | ANALOG OUTPUT CONFIGURATION<br>AO maximum value                                                                                        |  |  |
|------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|
| AI Channels                                    | :hannel 0 - Ur<br>:hannel 1 - Us<br>:hannel 2 - Ut<br>:hannel 3 - n<br>hannel 0 - Ef | All maximum Value     () 10,00     All minimum Value     () -10,00     output terminal configuration     output terminal configuration |  |  |
| rate<br>1000,00<br>warm-up iterations<br>() 20 | -                                                                                    | ANALOG INPUT SCALING PARAMETER:<br>AT 0 scale                                                                                          |  |  |
|                                                |                                                                                      | €) 69,565217<br>AI 1 scale<br>€) 69,874804                                                                                             |  |  |
|                                                |                                                                                      | AI 2 scale<br>69,517885                                                                                                                |  |  |
| ANALOG INPUT CONFIGURATIO                      | N                                                                                    | AI 3 scale                                                                                                                             |  |  |
| AI minimum value                               |                                                                                      | Tensiunea nominala<br>400,00                                                                                                           |  |  |
|                                                |                                                                                      | l uratie nominala                                                                                                                      |  |  |

Figure 1. Front Panel of the main application

| sample length | daq data       | Un               | Odq  |
|---------------|----------------|------------------|------|
| 20            |                | 400,00           | 0,00 |
| initialize    | 4 0.00         | fn               | 0,00 |
|               | 4 0.00         | 50,00            | 0,00 |
|               | 7,0,00         | turatie nominala | p    |
|               | 5,00           | 750,00           |      |
|               | scaling parame | ters             |      |
|               | €)0 €0,00      |                  |      |
|               | £ 0.00         |                  |      |
|               | A 0.00         |                  |      |
|               | - 0,00         |                  |      |
|               | 0,00           |                  |      |

Figure 2. Front Panel of the rr\_abcTo0dq.vi

The front panel of the *regulatorHinf.vi* which implements the robust controller is presented in figure 3.

|            |             |           | R         | EGULA     | for Hi    | inf       |           |       |          |
|------------|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-------|----------|
| vd<br>() D | upper limit | Regulator | A         |           |           |           |           |       | B        |
| vq         | lower limit | ÷O        | 3,005E-2  | 1,565E-4  | -3,162E+1 | 0E+0      | 0E+0      | (÷) o | 2.584E+3 |
| () 0       | -5          | 20        | -4,447E+3 | -1,678E+3 | -4,975E+4 | -4,055E+1 | 2,186E-1  |       | 4.066E+6 |
| f          | a           |           | 9,502E-3  | 4,95E-5   | -9,998E+0 | 0E+0      | 0E+0      | - Ma  | 8.173E+2 |
| <u></u>    | ÷ 0         |           | -2,202E+3 | -5,168E+1 | 0E+0      | -5,201E+2 | -2,666E+0 |       | 0E+0     |
| <u></u>    |             |           | 5,01E-1   | -2,208E+5 | -6,981E+6 | 0E+0      | -3,142E+1 |       | 5,706E+8 |
|            |             |           | c         |           |           |           |           |       | D        |
|            |             | ÷) 0      | -172,1    | -4,04     | 0         | -1,569    | -0,2084   | (÷) o | 0        |
|            |             | ÷) 0      |           |           |           |           |           | ÷)o   |          |
|            |             | ef<br>0   |           |           |           |           |           |       |          |

Figure 3 Front Panel of the regulatorHinf.vi.

The application presents the current status of the voltage controller through the "FUNCTIONARE CURENTA" window, presented in figure 4.

| Finished Late?                     | time step                                         | sample length<br>20                                 |  |
|------------------------------------|---------------------------------------------------|-----------------------------------------------------|--|
| error out<br>status code<br>source | vd (u.r.)<br>0,0131444<br>vq (u.r.)<br>-0,0238995 | ef (u.r.)<br>5<br>Analog output value (volts)<br>10 |  |
|                                    | STOP                                              |                                                     |  |

Figure 4 Controller operation point windows.

The hardware used is composed from PXI-8145RT real time controller, PXI-6251 data acquisition board and a DC to DC converter.

The real-time controller has the following characteristics:

- processor Intel Pentium 266MHz.

- operatingsystem PharLap RTOS

- memory RAM 128MB SDRAM

- watchdog timer

- loop rate 1µs (hardware timing)

- system jitter < 4ns

The data acquisition card has 16 analog inputs with 16bit resolution with an input rate of 1MS/s, two analog output channels and 2 counters with 32 bit resolution.

The voltage transducers used are LV 25-P from LEM. The application has the analog input scaling parameters configuration window, in which the used can change the parameters accordingly with the new voltage tranducers that can be used.

For the amplification a buck DC to DC converter. The converter schema is presented in figure 5.



Figure 5. DC-DC buck converter

The converter is connected to the ship electrical system and is controlled by the counter output of the data acquisition card.

### 4. Conclusions

This paper presents a software implementation in a real-time hardware of a robust voltage controller developed for multimachine power system. The software is fully configurable so future development or hardware components replacements (as voltage transducers) can be done with reconfiguration of application parameters.

### References

[1] Francis A. Okou, Ouassima Akhrif, Louis-A. Dessaint, Roger Champagne, "Application of a Multivariable Feedback Linearization Scheme for Rotor Angle Stability and Voltage Regulation of PowerSystems", IEEE Transactions on Power Systems, vol.14, no.2, 1999J. Clerk Maxwell, A Treatise on Electricity and Magnetism, 3<sup>rd</sup> ed., vol. 2 Oxford: Clarendon, 1892, pp.68-73.

[2] J. Arrilaga, N.R.Watson, "Computer Modelling of Electrical Power Systems", John Wiley & Sons Itd, 2001.