

# Implementation of a Three-Phase Grid-Connected Inverter Controller

Processor-in-the-Loop Implementation on TI C2000 F28379D

Rohan Lalwani

Department of Electrical Engineering  
IIT Roorkee

March 6, 2024

## Abstract

This report details the implementation of a digital control system for a 10 kVA three-phase Grid-Connected Inverter (GCI). The system is designed to inject 3000 W of active power and 3000 VAR of reactive power into a 415 V, 50 Hz balanced grid. The control strategy employs a Synchronous Reference Frame Phase Locked Loop (SRF-PLL) for synchronization and a decoupled dq-frame current controller for power regulation. The entire control loop, including a discrete-time model of the L-filter and grid, is implemented on a TI C2000 F28379D microcontroller in a Processor-in-the-Loop (PIL) configuration. The results demonstrate accurate grid synchronization and precise tracking of power references.

## Contents

|                                                        |          |
|--------------------------------------------------------|----------|
| <b>1 Problem Statement</b>                             | <b>3</b> |
| <b>2 Section 1: Open Loop 3-Ph Voltages Generation</b> | <b>3</b> |
| 2.1 Methodology . . . . .                              | 3        |
| 2.2 Implementation . . . . .                           | 3        |
| 2.3 Results . . . . .                                  | 4        |
| <b>3 Section 2: Grid Synchronization (SRF-PLL)</b>     | <b>4</b> |
| 3.1 SRF-PLL Theory . . . . .                           | 4        |
| 3.2 Discrete Implementation . . . . .                  | 4        |
| 3.3 Results . . . . .                                  | 5        |
| <b>4 Section 3: Closed Loop Control (PIL)</b>          | <b>5</b> |
| 4.1 Control Structure . . . . .                        | 5        |
| 4.2 Discrete Plant Model . . . . .                     | 6        |
| 4.3 Power and Current Control . . . . .                | 6        |

|                                      |          |
|--------------------------------------|----------|
| <b>5 Results and Conclusion</b>      | <b>7</b> |
| 5.1 Controller Performance . . . . . | 7        |
| 5.2 Conclusion . . . . .             | 8        |

# 1 Problem Statement

The objective of this project is to implement a control scheme for a three-phase inverter with the following specifications

- **DC Bus Voltage:** 800 V
- **Grid Voltage:** 415 V (Line-to-Line), 50 Hz
- **Switching Frequency:** 10 kHz
- **Power Injection:** 3000 W (Active), 3000 VAR (Reactive)
- **Filter Parameters:** Inductance drop of 10% of grid voltage; Resistance  $0.1\Omega$ .

The project is divided into three implementation sections:

1. Open-loop generation of three-phase balanced sinusoidal voltages using ePWM.
2. Implementation of SRF-PLL to obtain grid phase angle.
3. Full closed-loop control (Current and Power loops) with a discrete domain plant model.

## 2 Section 1: Open Loop 3-Ph Voltages Generation

### 2.1 Methodology

The first stage involves verifying the ePWM and DAC peripherals. Three sinusoidal reference signals shifted by  $120^\circ$  are generated. The instantaneous values are scaled and sent to the Digital-to-Analog Converter (DAC) for verification on an oscilloscope.

### 2.2 Implementation

The implementation uses a timer interrupt at 10 kHz. In every interrupt, the phase angle  $\theta$  is incremented based on the reference frequency (50 Hz).

```
1 // Interrupt Service Routine for ePWM
2 extern interrupt void epwm2_isr(void){
3     // Update angle
4     theta = theta + (2 * PI * ref_freq * 100e-6); // 100us sampling
5     if (theta > 2*PI) theta -= 2*PI;
6
7     // Generate balanced three-phase voltages
8     va = Vm * sin(theta);
9     vb = Vm * sin(theta - 2*PI/3);
10    vc = Vm * sin(theta - 4*PI/3);
11
12    // Scale and output to DAC for visualization
13    DacaRegs.DACVALS.bit.DACVALS = (0.5 + (va/Vm)/2.0) * 4095;
14    DacbRegs.DACVALS.bit.DACVALS = (0.5 + (vb/Vm)/2.0) * 4095;
15
16    // Acknowledge Interrupt
17    PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
```

```

18 EPwm2Regs.ETCLR.bit.INT = 1;
19 }

```

Listing 1: SPWM Generation Logic

## 2.3 Results

The code successfully generates three sinusoidal waves. The DAC output observed on the DSO confirms the  $120^\circ$  phase shift and accurate frequency generation of 50 Hz.



Figure 1: Open-loop SPWM generation showing balanced 3-phase voltages.

## 3 Section 2: Grid Synchronization (SRF-PLL)

### 3.1 SRF-PLL Theory

Grid synchronization is achieved using a Synchronous Reference Frame PLL. The three-phase grid voltages  $v_{abc}$  are transformed to the rotating  $dq$  frame. The PLL controller regulates the q-axis voltage  $v_q$  to zero. When  $v_q = 0$ , the d-axis is aligned with the grid voltage vector, and the estimated angle  $\theta_{PLL}$  tracks the grid angle.

### 3.2 Discrete Implementation

The PI controller for the PLL is discretized using the Tustin transformation. The coefficients  $b_0$  and  $b_1$  are pre-calculated based on the sampling time ( $T_s = 100\mu s$ ) and PI gains ( $K_p = 0.687$ ,  $K_i = 77.47$ ).

```

1 // ABC to DQ Transformation
2 vd = (2.0/3.0)*((va*sin(thetaPLL)) + (vb*sin(thetaPLL - 2*PI/3))
3           + (vc*sin(thetaPLL - 4*PI/3)));
4 vq = (2.0/3.0)*((va*cos(thetaPLL)) + (vb*cos(thetaPLL - 2*PI/3))
5           + (vc*cos(thetaPLL - 4*PI/3)));
6

```

```

7 // PI Controller (Tustin)
8 delta_f = delta_f_pre + b0*vq + b1*vq_pre;
9
10 // Frequency and Angle Integration
11 f = delta_f + line_freq; // Feedforward 50Hz
12 thetaPLL1 = thetaPLL_pre + PI*sampling_time*(f + f_pre);
13
14 // Wrap angle to 0-2pi
15 thetaPLL = (thetaPLL1 <= 2*PI) ? thetaPLL1 : (thetaPLL1 - 2*PI);
16
17 // Update History Terms
18 vq_pre = vq;
19 delta_f_pre = delta_f;
20 thetaPLL_pre = thetaPLL;
21 f_pre = f;

```

Listing 2: SRF-PLL Implementation

### 3.3 Results

The PLL accurately locks onto the generated grid voltage. The oscilloscope results (Figure 2) show the grid voltage (Channel 1) and the PLL angle sawtooth wave (Channel 2) are perfectly synchronized.



Figure 2: Grid phase angle tracking using SRF-PLL. Channel 1: Grid Voltage (Yellow), Channel 2: PLL Angle (Green).

## 4 Section 3: Closed Loop Control (PIL)

### 4.1 Control Structure

The complete control system consists of:

1. **Outer Power Loop:** Generates  $i_d^*$  and  $i_q^*$  references to track  $P_{ref}$  and  $Q_{ref}$ .

2. **Inner Current Loop:** Regulates  $i_d$  and  $i_q$  using decoupling terms to handle cross-coupling between axes.
3. **Plant Model (PIL):** Simulates the behavior of the L-filter and grid interaction directly on the MCU.

## 4.2 Discrete Plant Model

To validate the controller without high-voltage hardware, the inverter and grid dynamics are modeled using difference equations derived from:

$$v_{inv} - v_{grid} = L \frac{di}{dt} + iR \quad (1)$$

```

1 void inverter(void) {
2     // Reconstruct Inverter Phase Voltages
3     vao = vdc * refa;
4     vbo = vdc * refb;
5     vco = vdc * refc;
6     vno = (vao + vbo + vco) / 3.0; // Neutral Voltage
7
8     // Voltage across inductor
9     vla = vao - va - vno;
10    vlb = vbo - vb - vno;
11    vlc = vco - vc - vno;
12
13    // Update Currents (Discrete Integration)
14    ia = (-b3*ia + (vla + vla_pre)) / b2;
15    ib = (-b3*ib + (vlb + vlb_pre)) / b2;
16    ic = (-b3*ic + (vlc + vlc_pre)) / b2;
17
18    // Store previous values
19    vla_pre = vla;
20    vlb_pre = vlb;
21    vlc_pre = vlc;
22 }
```

Listing 3: Inverter Plant Model (PIL)

## 4.3 Power and Current Control

The controller implements decoupling to ensure independent control of Active and Reactive power.

```

1 // --- Power Loop ---
2 // Calculate P and Q
3 pdq = 1.5 * vd * id;
4 qdq = 1.5 * vd * iq;
5
6 // PI Control for References
7 error_p = pref - pdq;
8 idref = idref + (b4*error_p) + (b5*error_p_pre);
9
10 error_q = qref - qdq;
11 iqref = iqref + (b6*error_q) + (b7*error_q_pre);
12
```

```

13 // --- Current Loop ---
14 error_id = idref - id;
15 ud = ud + (b8*error_id) + (b9*error_id_pre);
16
17 error_iq = iqref - iq;
18 uq = uq + (b8*error_iq) + (b9*error_iq_pre);
19
20 // --- Decoupling & Inverse Transform ---
21 md = (ud - iq*omegaL + vd) * 2 / vdc;
22 mq = (uq + id*omegaL + vq) * 2 / vdc;
23
24 // Inverse Park Transform (dq to abc)
25 ma = sin(thetaPLL)*md + cos(thetaPLL)*mq;
26 mb = sin(thetaPLL + 2*PI/3)*md + cos(thetaPLL + 2*PI/3)*mq;
27 mc = sin(thetaPLL - 4*PI/3)*md + cos(thetaPLL - 4*PI/3)*mq;
28
29 // PWM Duty Cycle Generation
30 refa = (ma + 1) / 2;
31 refb = (mb + 1) / 2;
32 refc = (mc + 1) / 2;

```

Listing 4: Current and Power Control Loops

## 5 Results and Conclusion

### 5.1 Controller Performance

The system was tested with a reference of  $P_{ref} = 3000$  W and  $Q_{ref} = 3000$  VAR.

- **Current Tracking:** The generated current references  $(i_{d_{ref}}, i_{q_{ref}})$  stabilized at approximately 6.9 A, consistent with theoretical expectations for the given power levels.
- **Waveforms:** The oscilloscope results (Figure 3) display the grid voltage (Channel 1) and the injected current (Channel 2). The waveforms are sinusoidal and stable, indicating successful closed-loop control.



Figure 3: Closed-loop GCI operation. Channel 1 (Yellow): Grid Voltage, Channel 2 (Green): Injected Grid Current.

## 5.2 Conclusion

The project successfully demonstrated the implementation of a full digital control stack for a Grid-Connected Inverter on the C2000 F28379D MCU. The use of Processor-in-the-Loop simulation allowed for the verification of the PLL, current loops, and power loops in a safe environment. The results confirm that the controller can accurately regulate power injection into the grid with fast dynamic response and robust synchronization.