# A Direct Modulation for Matrix Converters based on the One-cycle Atomic operation developed in Verilog HDL

Pawel Szczepankowski<sup>©</sup>, Member, IEEE, Wojciech Sleszynski<sup>©</sup>, Member, IEEE, Tomasz Bajdecki<sup>©</sup>

Abstract—This paper presents a fast direct Pulse Width Modulation (PWM) algorithm for the Conventional Matrix Converters (CMC) developed in Verilog Hardware Description Language (HDL). All PWM duty cycle calculations are performed in one cycle by an atomic operation designed as a digital module using an FPGA basic blocks. The algorithm can be extended to any number of output phase. The improved version of the discontinuous Direct Analytic Voltage PWM (DAV-PWM) method is proposed, in which the use of trigonometry, angles and program loops has been eliminated. The proposed DAV-PWM is equivalent to the Space Vector Modulation (SVM), it can be applied during input asymmetry and also allows for the control of the displacement input angle. The proposal has been verified using the circuit simulation in PSIM, digital structure modelling in ModelSim, and finally through an experiment.

*Index Terms*—matrix converters, AC/AC converters, pulse width modulation, fpga device.

## Nomenclature

- Transposition of the matrix.
- $\mathbf{v}_{i}$  Measured input voltages  $[v_{i1}, v_{i2}, v_{i3}]^{T}$ .
- $\mathbf{v}_{o}$  Averaged output voltages  $[v_{o1}, v_{o2}, v_{o3}]^{T}$ .
- $\mathbf{i}_{i}$  Averaged input currents  $[i_{i1}, i_{i2}, i_{i3}]^{T}$ .
- $\mathbf{i}_{\text{o}}$  Measured output currents  $[i_{\text{o}1}, i_{\text{o}2}, i_{\text{o}3}]^T$ .
- **D** PWM duty cycle matrix with size  $3 \times 3$ .
- x Real signal component.
- y Imaginary signal component.
- $\mathbf{v}_{\mathrm{ix}}$  Matrix of  $\mathbf{v}_{\mathrm{i}}$  in-phase components.
- $\mathbf{v}_{iv}$  Matrix of  $\mathbf{v}_i$  quadrature components.
- $\mathbf{v}_{\text{ox}}$  Real parts of reference voltages  $[v_{\text{o1x}}, v_{\text{o2x}}, v_{\text{o3x}}]^T$ .
- $\mathbf{v}_{\text{oy}}$  Imag. parts of reference voltages  $[v_{\text{o1y}}, v_{\text{o2y}}, v_{\text{o3y}}]^T$ .
- $\phi_i$  Input displacement angle.
- $s_i, s_o$  Input, output voltage sectors.
- $\omega_i = 2\pi f_i$ , where  $f_i$  is the input frequency.
- $\omega_{\rm o} = 2\pi f_{\rm o}$ , where  $f_{\rm o}$  is the output frequency.
- $q = V_{\rm o}/V_{\rm i}$ , Voltage transfer ratio.
- $q_{\text{max}} = \sqrt{3}/2$ , Maximum value of q.

 $T_{\rm PWM}$  Modulation period.

 $f_{\rm s} = 1/T_{\rm PWM}$  sampling frequency.

## I. Introduction

THE CMC, shown in Fig. 1, contains semiconductor switches arranged into a matrix configuration divided into three cells  $\{h_{11}, h_{21}, h_{31}\}$ ,  $\{h_{12}, h_{22}, h_{32}\}$ , and

 $\{h_{13}, h_{23}, h_{33}\}$ . Comparing to AC/DC/AC back–to–back converters with large capacitors in DC–link, the CMC allows for direct AC–AC conversion using the small input filter, which is an advantage of these solutions [1]–[3]. The general motor drive application scheme with the matrix converter is illustrated in Fig. 1. Such a topology permits for regenerative power from the electrical motor M with negligible input grid current harmonic content. An important feature of the CMC control is the possibility to adjust the input displacement angle to zero [4]–[6]. The single switch h can be built from two transistors with two diodes or two RB–IGBT devices [1], [7].



Fig. 1. Classic Matrix Converter and its typical application scheme.

The single CMC's cell is properly controlled to prevent line to-line short circuits and to maintain a continuous waveform of the load current. Due to the safe commutation process requirement, the dead-time mechanism should be applied during the generation of switches control signals. The overvoltage upon the switch, caused by an interruption of the inductive current, has to be absorbed by a clamp circuit [8], [9]. The reduction of the scale of both the input filters, and the clamp circuit, can be reached by applying faster semiconductors with a high operations frequency, thus a panel size of the CMC can be significantly reduced [10]. Attempts to integrate this panel with the electric motor have already taken place [11]. Gallium Nitride (GaN) and Silicon Carbide (SiC) semiconductors offer fundamental advantages over silicon solutions [12]-[15]. The switch's operation frequency can be very high compared to the silicon counterparts, which makes these devices great for highfrequency application, which also includes high-speed drives in compressors or high-speed generators in gas turbines [16]-[18]. Such applications require complex calculations within a short period of time.

TABLE I
THE SUMMARY OF THE CONDUCTED RESEARCH PATH.

Conducted using Matlab R2020a software, containing symbolic formal analysis variables, matrix operations and graphical visualization of the vectors arrangement. ANSI C Verilog HDL code The algorithm code written in Equivalently, the same functionality has been developed using Verilog HDL language using ModelSim developing ANSI C/C++ was developed in Visual Studio 2019 as a function of the user DLL block for power electronic circuit Intel Fpga Starter Edition modelling software - PSIM 11 simulation Simulation has been performed For early validation of the Verilog HDL synthesizability, the Quartus 18.1 has been used using the complete electrical scheme of CMC and RL load validation using PSIM11 software. The with SignalTap Logic Analyzer control board was emulated with conjunction with using the DLL user block. DE10-Lite evaluation board. A 5kW CMC with control board based on multicore experiment ADSP-SC589 DSP from Analog Devices and MAX10 Intel FPGA device. The bidirectional power switch was built using two SiC transistors C3M0075120D.

The paper presents an approach to computations performed in FPGA in one step, during one—cycle, without trigonometry and angles. Thus, the execution time of the PWM duty cycles calculation is atomic and limited only by the critical timing constraints of the FPGA device. The development of a digital structure that performs such an algorithm, in one clock cycle, requires the use of an appropriate modulation method that uses only simple arithmetic operations supported by the Verilog HDL. Moreover, the proposed solution should allow to obtain the maximum voltage transfer ratio and to adjust the angle at the input of the system, which is a characteristic feature of the PWM modulation for CMC [1].

PWM modulation strategies for CMC have been widely reported in literature, as the direct control by Venturini approach [3], [19], [20], scalar control realized according to Roy method [21], and the Space Vector Modulation (SVM) [1], [22]. Other control methods, like hysteresis and Direct Torque Control (DTC), are interesting alternatives [23], [24]. However, the torque ripple in the low-speed region or switching frequency variations according to the change of the motor speed are drawbacks of these approaches. The mentioned methods are not suitable for developing the simplest solution, which should be built from basic digital elements like multiplexes, adders and multipliers. A simplified carrier-based modulator based on the concept of a virtual matrix converter was presented in [25]. The proposed algorithm allows for obtaining the same instantaneous matrix states as the SVM method with a smaller number of calculations. Although the solution represents a more synthetic and systematic approach, this original approach has a major disadvantage. An input displacement angle is permanently equal to zero and cannot be adjusted.

The concept of simplifying and generalizing the PWM modulation algorithm is also presented in publications [26], [27]. As with the previous method, the proposal makes it possible to calculate PWM duty cycles without trigonometry with minimal computational effort. Moreover, the proposed computation scheme allows for the application of various methods of power

factor control. Among the described modulation methods, the authors indicated that the Direct Analytic Voltage Pulse Width Modulation (DAV-PWM) is optimal because it allows reaching the maximum voltage transfer ratio equal to 0.866 with the same switch states collection as the SVM modulation. This algorithm has been developed as a sequential code, which contains a program loop for preselection input voltage vectors. Such a program loop has to be eliminated within the atomic and concurrent implementation based on an FPGA device. The paper mainly addresses this issue and proposes certain improvements, which are clarified in section II. The theoretical basis of an improved DAV-PWM modulation algorithm, ready for the HDL conversion, has been presented in the next section. Power electronics simulation, modelling based on the Hardware Description Language (HDL), and Hardware-Inthe-Loop (HIL) verification have been presented in section IV. The conducted research path is summarized in Table I. Experimental results are presented in section V. The Verilog HDL code of the improved DAV-PWM algorithm is available as an appendix after the conclusion section.

### II. PROPOSAL FOR CHANGES IN THE DAV-PWM

The use of an FPGA chip offers new possibilities to design the computation structure with a short execution time, provided that these algorithms do not use advanced mathematical functions, such as trigonometric functions, and not contain the program loops. Therefore, the computation scheme of the DAV–PWM modulation should be optimised. The most important modifications of the DAV–PWM algorithm are explained in the following section.

# • The quadrature component generation of an input voltage

Each input voltage with the pulsation  $\omega_i$  can be expressed as a rotating vector as shown in Fig. 3. For pure sinusoidal input voltages with an amplitude V the imaginary coordinates are just quadrature components. Thus, the analytic signals corresponding to input voltages can be expressed as follows

$$\mathbf{v_i} = V \begin{bmatrix} \cos(\omega_i t) & \sin(\omega_i t) \\ \cos(\omega_i t - 2\pi/3) & \sin(\omega_i t - 2\pi/3) \\ \cos(\omega_i t + 2\pi/3) & \sin(\omega_i t + 2\pi/3) \end{bmatrix}$$
(1)

If the input voltages are not perfectly sinusoidal, all coordinates should be determined using Hilbert filter or FFT/DFT based operation [28]-[30], which cannot be easily implemented in FPGA without using an advanced Intellectual Property Core. However, calculations using Clarke's triple transforms, although simple, in the case of asymmetry cause a distortion of the input current [26]. In practice, error signals in the form of DC offsets, glitches, and momentary voltage sags may occur in measurements. Therefore, coordinates can be computed by Double Second Order Generalized Integrator with loop feedback extension functioning as Orthogonal Signal Generator (DSOGI-OSG), shown in Fig. 2, which in the OSG part prevents unexpected resonance and variables overflow [31]–[33]. If processed signal frequency does not have an exact value, another extension of SOGI structure, called the Frequency Locked Loop FLL, may be applied [34]-[36].





Fig. 2. DSOGI-OSG structure in continuous time-domain.

## • A simpler approach to the input displacement angle regulation

According to the concept proposed in papers [26] and [27], an input angle displacement regulation is realised by tilting the trajectory  $\Gamma$  by the desired displacement angle, exactly equal to  $\phi_i$ , as is illustrated in Fig. 3. The modification of the  $\Gamma$  trajectory results in decreasing the voltage transfer ratio q. Thus, reference output voltages can be represented by the following formula

$$\mathbf{v_o} = q \cdot \cos(\phi_i) \begin{bmatrix} \cos(\omega_o) + v_{cm} \\ \cos(\omega_o - 2\pi/3) + v_{cm} \\ \cos(\omega_o + 2\pi/3) + v_{cm} \end{bmatrix} \begin{bmatrix} 1 & \tan(\phi_i) \end{bmatrix}$$
(2)

where the common–mode signal  $v_{\mathrm{cm}}$  is expressed as follows

$$\begin{aligned} v_{\rm cm} &= -0.5({\rm max_o + min_o}) \\ {\rm max_o} &= {\rm MAX}\{\cos(\omega_{\rm o}), \cos(\omega_{\rm o} - 2\pi/3), \cos(\omega_{\rm o} + 2\pi/3)\} \\ {\rm min_o} &= {\rm MIN}\{\cos(\omega_{\rm o}), \cos(\omega_{\rm o} - 2\pi/3), \cos(\omega_{\rm o} + 2\pi/3)\}. \end{aligned}$$

To achieve the maximum voltage transfer ratio, the trajectory  $\Gamma$  should to be shifted to the nearest vertex of the triangle  $\Delta_{[1,2,3]}$ . According to the origin DAV–PWM algorithm, coordinates of the shift vector are designated by the program loop routine, in which the algorithm selects the best candidate among the input voltage vectors set [26]. This solution can also be improved to meet the optimization requirements. The Gamma  $\Gamma$  modification in equation (2) can be replaced by a formula containing a rotation matrix. Thus, the relation between input and output voltages in CMC may be written in a following general form

$$\mathbf{v_o} \cdot \mathbf{R} = \mathbf{D} \cdot \mathbf{v_i} \tag{4}$$

where

$$\mathbf{R} = \begin{bmatrix} \cos(\phi_{i}) & -\sin(\phi_{i}) \\ \sin(\phi_{i}) & \cos(\phi_{i}) \end{bmatrix}$$
 (5)

and D is a square matrix that contains all PWM duty cycles

$$\mathbf{D} = \begin{bmatrix} d_{11} & d_{12} & d_{13} \\ d_{21} & d_{22} & d_{23} \\ d_{31} & d_{32} & d_{33} \end{bmatrix}$$
 (6)

for switches  $h_{11} - h_{33}$ . Taking into account the properties of the R matrix, equation (4) can be finally rewritten as

$$\mathbf{v_0} = \mathbf{D} \cdot (\mathbf{v_i} \cdot \mathbf{R}^{-1}) = \mathbf{D} \cdot \mathbf{v_{iR}} \tag{7}$$

Now, the desired angle of displacement  $\phi_i$  can be achieved by angular displacement of the input vector collection (1). This result has a significant impact on the optimization



Fig. 3. Regulation of an input power factor in CMC by tilting the trajectory  $\Gamma$ 



Fig. 4. A new synthesis field  $\Delta_{R[1,2,3]}$  after rotation of the original input vectors.

of the origin DAV–PWM algorithm because all calculations can be performed for reference voltage, which always has a zero imaginary component. Hence, the selection of the shift coordinates is simplified and free from an undesired program loop. Reference to the new synthesis field  $\Delta_{R[1,2,3]}$  shown in Fig. 4, the shift vector always correspondes to an intermediate vertex between the top and the bottom vertex, which can be immediately selected in a much simpler way using comparators instead of the program loop.

• Simplification of the reference output voltage generation. The trajectory shift operation eliminates the common voltage from equation (2). Therefore, this component can be deleted in the proposed version of the DAV-PWM algorithm. In consequence, only the sinusoidal voltage references can be applied in the algorithm.

#### III. AN IMPROVED DAV-PWM MODULATION ALGORITHM

A schematic diagram of the improved DAV–PWM modulation algorithm is presented in Fig. 5. The input voltage  $\{v_{i1},v_{i2},v_{i3}\}$  from measurements is converted into analytic signal pairs using DSOGI–OSG or DSOGI–FLL structure. Next, all input vectors are multiplied by the rotation matrix  ${\bf R}$  (5), which takes arguments –  $\cos\phi_i$  and  $\sin\phi_i$  – from the input power factor control routine. Three coordinates pairs for



TABLE II DEPENDENCE OF THE SHIFT VECTOR COORDINATES  $v_{\rm s}$ ,  $\max_{\rm o}$ , and  $\min_{\rm o}$  on input and output sector number.

| $s_{ m iR}$ or $s_{ m o}$ | $v_{ m sx}$                          | $v_{ m sy}$         | $\max_{o}$   | $\min_{o}$   |
|---------------------------|--------------------------------------|---------------------|--------------|--------------|
| 1                         | $v_{\mathrm{iR2x}} - \mathrm{min_o}$ | $v_{\mathrm{iR2y}}$ | $v_{ m o3x}$ | $v_{ m o1x}$ |
| 2                         | $v_{\mathrm{iR1x}} - \mathrm{min_o}$ | $v_{\mathrm{iR1y}}$ | $v_{ m o2x}$ | $v_{ m o3x}$ |
| 3                         | $v_{iR3x} - max_o$                   | $v_{\mathrm{iR3y}}$ | $v_{ m o2x}$ | $v_{ m o1x}$ |
| 4                         | $v_{\mathrm{iR3x}} - \mathrm{min_o}$ | $v_{\mathrm{iR3y}}$ | $v_{ m o1x}$ | $v_{ m o2x}$ |
| 5                         | $v_{iR1x} - max_o$                   | $v_{\mathrm{iR1y}}$ | $v_{ m o3x}$ | $v_{ m o2x}$ |
| 6                         | $v_{iR2x} - max_o$                   | $v_{\mathrm{iR2y}}$ | $v_{ m o1x}$ | $v_{ m o3x}$ |

modulating signals

$$\mathbf{v_o} = \begin{bmatrix} v_{\text{o1x}} + v_{\text{sx}} & v_{\text{sy}} \\ v_{\text{o2x}} + v_{\text{sx}} & v_{\text{sy}} \\ v_{\text{o3x}} + v_{\text{sx}} & v_{\text{sy}} \end{bmatrix}$$
(8)

are selected according to the input sector  $s_{iR}$  and the output sector  $s_{o}$ . Both sectors are directly identified using comparators as shown in Fig. 6 and Fig. 7.



Fig. 5. Schematic diagram of the improved DAV-PWM modulation algorithm.



Fig. 6. Identifying the sector of the rotated input vectors using three comparators during an amplitudes asymmetry.



Fig. 7. Identifying the output voltage sector using three comparators.

Dependencies of the shift vector coordinates on the input and output sectors are referred to in Table II. The collection of PWM duty cycles for switches  $h_{11}$ ,  $h_{21}$ , and  $h_{31}$  can be calculated without trigonometry and angles using the following formulas

$$d_{11} = \xi \cdot \left| \det \begin{bmatrix} v_{iR2x} - \mathbf{v_o}(1, 1) & v_{iR2y} - \mathbf{v_o}(1, 2) \\ v_{iR3x} - \mathbf{v_o}(1, 1) & v_{iR3y} - \mathbf{v_o}(1, 2) \end{bmatrix} \right|$$
(9)

TABLE III
THE PWM DUTY CYCLE MATRICES D WITHIN AN INPUT AND OUTPUT
VOLTAGE SECTORS IN DAV-PWM MODULATION.

|                            |                                                                                                                 | $s_0$                                                                                                            |                                                                                                                 |
|----------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| $^{\mathrm{s}}\mathrm{iR}$ | 4,6 (1,3)                                                                                                       | 2,3 (4,5)                                                                                                        | 1,5 (2,6)                                                                                                       |
| 2(5)                       | $\left[\begin{array}{ccc} 1 & d_{12} & d_{13} \\ 0 & d_{22} & d_{23} \\ 0 & d_{32} & d_{33} \end{array}\right]$ | $\left[\begin{array}{cccc} d_{11} & 1 & d_{13} \\ d_{12} & 0 & d_{23} \\ d_{13} & 0 & d_{33} \end{array}\right]$ | $\left[\begin{array}{ccc} d_{11} & d_{12} & 1\\ d_{12} & d_{22} & 0\\ d_{13} & d_{32} & 0 \end{array}\right]$   |
| 1(6)                       | $\left[\begin{array}{ccc} 0 & d_{12} & d_{13} \\ 1 & d_{22} & d_{23} \\ 0 & d_{32} & d_{33} \end{array}\right]$ | $\left[\begin{array}{cccc} d_{11} & 0 & d_{13} \\ d_{21} & 1 & d_{23} \\ d_{31} & 0 & d_{33} \end{array}\right]$ | $\left[\begin{array}{ccc} d_{11} & d_{12} & 0 \\ d_{21} & d_{22} & 1 \\ d_{31} & d_{32} & 0 \end{array}\right]$ |
| 3(4)                       | $\left[\begin{array}{ccc} 0 & d_{12} & d_{13} \\ 0 & d_{22} & d_{23} \\ 1 & d_{32} & d_{33} \end{array}\right]$ | $\left[\begin{array}{cccc} d_{11} & 0 & d_{13} \\ d_{21} & 0 & d_{23} \\ d_{31} & 1 & d_{33} \end{array}\right]$ | $\left[\begin{array}{ccc} d_{11} & d_{12} & 0 \\ d_{21} & d_{22} & 0 \\ d_{31} & d_{32} & 1 \end{array}\right]$ |

$$d_{21} = \xi \cdot \left| \det \begin{bmatrix} v_{iR1x} - \mathbf{v_o}(1, 1) & v_{iR1y} - \mathbf{v_o}(1, 2) \\ v_{iR3x} - \mathbf{v_o}(1, 1) & v_{iR3y} - \mathbf{v_o}(1, 2) \end{bmatrix} \right|$$
(10)

$$d_{31} = 1 - d_{11} - d_{21} (11)$$

where det means the determinant of the matrix  $2 \times 2$ , and

$$\xi = \left| \det \begin{bmatrix} v_{iR2x} - v_{iR1x} & v_{iR2y} - v_{iR1y} \\ v_{iR3x} - v_{iR1x} & v_{iR3y} - v_{iR1y} \end{bmatrix} \right|^{-1}$$
(12)

Others PWM duty cycles, in the second and third row of (8), can be computed analogously. The PWM duty cycle matrices  $\mathbf{D}$  within an input  $\mathbf{s}_{iR}$  and output  $\mathbf{s}_{o}$  voltage sectors in DAV–PWM modulation are summarized in Table III. The  $\mathbf{D}$  matrix consists of nine duty cycles  $d_{11}-d_{33}$ , which are transformed into the sequence of logical signals for switches state control. These sequences are usually generated by the specialized digital structure based on counters and comparators according to the selected commutation strategy in CMC [37]–[41]. The Cyclic Venturini approach and the 4–step commutation strategy have been chosen [5].

## IV. POWER ELECTRONICS SIMULATION, HDL MODELLING, HIL VERIFICATION.

This section presents results obtained during the functional simulation in PSIM11 software, behavioural modelling of the Hardware Description Language (HDL) using ModelSim Intel FPGA environment, and the Hardware–In–the–Loop (HIL) verification using Quartus Intel FPGA software with Signal Tap Logic Analyzer (STLA) tool.

## • Simulation and switch state sequences comparison for DAV-PWM and SVM

The PSIM environment was used to simulate CMC control and verify the algorithm compiled as the user DLL block, which is written in C-language. The proposed improved algorithm maintains the important properties of DAV-PWM modulation proposed in [26]. The obtained sequences of switch states, including the waveforms of line-to-line voltages, remain unchanged. An input voltage amplitude asymmetry or phase angle disturbance change the shape and area of the synthesis field limiting the value of the voltage transfer ratio q. However, during operation with a unity power factor, currents on both sides of the converter are sinusoidal, as can be seen in Fig. 8 where three selected input conditions for RL load type are presented. The article proposes a direct modulation algorithm, in which the switch states are not explicitly declared as in the conventional SVM modulation method. Table IV presents



Fig. 8. Three selected source voltage conditions during operation with a unity power factor at the input – simulation using PSIM11 software.

TABLE IV THE SWITCH STATES COLLECTION FOR SVM METHOD.

| 9   | 8     | 7     | 6              | 5              | 4     | 3     | 2               | 1              |
|-----|-------|-------|----------------|----------------|-------|-------|-----------------|----------------|
| 0 • | • • 0 | • 0 0 | • • •          | 00•            | o • • | 0 • 0 | • • 0           | • 0 0          |
| • 0 | 000   | 0 0 0 | 0 0 0          | • • 0          | • 0 0 | • 0 • | 000             | 0 0 0          |
| 18  | 17    | 16    | 15             | 14             | 13    | 12    | 11              | 10             |
| 0 0 | 000   | 000   | 000            | 000            | 000   | • • • | 00•             | o • •          |
| • • | • • • | • 0 0 | • • •          | • • o          | • • • | 0 • 0 | • • o           | • 0 0<br>0 0 0 |
| 27  | 26    | 25    | 24             | 23             | 22    | 21    | 20              | 19             |
| 0 0 | 000   | • • • | 00•            | 0 • 0          | • 0 0 | 00•   | 0 • 0           | • 0 0          |
| 0 0 | • • • | 000   | 0 • 0<br>• 0 0 | • 0 0          | 0 0 • | • o o | • • •           | 0 • 0          |
|     |       |       |                |                |       |       |                 |                |
| 25  | 10    | 11    | 14             | 3 <b>27</b> 13 | 1     | 14    | <b>25</b> 10 11 | 2              |
| 15  |       |       |                |                |       |       |                 |                |

Fig. 9. Two periods of the load voltage for the 10-switch-double-sided modulator for conventional SVM method.



Fig. 10. Two periods of the load voltage for 8-switch-double-sided switch states sequence for SVM and DAV-PWM modulations.

all switch states of CMC. Black dots represent the active switches in the matrix panel. Several modulation techniques are compared in paper [42] and analyzed in [43]. Among the described switch state sequences two of them can be distinguished: 10–switch double–sided shown in Fig. 9, and low–distortion 8–switch sequence illustrated in Fig. 10. The

TABLE V
DECODED SVM SWITCHING SEQUENCES FOR DAV–PWM MODULATION
WITH CYCLIC VENTURINI SCHEME.

|          |                            | $S_0$                      |                                              |
|----------|----------------------------|----------------------------|----------------------------------------------|
| $s_{iR}$ | 6(1)                       | 2(5)                       | 3(4)                                         |
| 5(2)     | 25,02,01,02,25,08,07,08,25 | 25,02,03,02,25,08,09,08,25 | 25,10,09,10,25,04,03,04,25                   |
| 4(3)     | 27,01,02,01,27,13,14,13,27 | 27,03,02,03,27,15,14,15,27 | 27,03,04,03,27,15,16,15,27                   |
| 6(1)     | 26,11,10,11,26,14,13,14,26 | 26,11,12,11,26,14,15,14,26 | 26,07,12,07,26,16,15,16,26                   |
| 2(5)     | 25,04,05,04,25,10,11,10,25 | 25,12,11,12,25,06,05,06,25 | 25,06,01,06,25,12,07,12,25                   |
| 3(4)     | 27,05,04,05,27,17,16,17,27 | 27,05,06,05,27,17,18,17,27 | 27,01,06,01,27,13,18,13,27                   |
| 1(6)     | 26,07,08,07,26,16,17,16,26 | 26,18,17,18,26,09,08,09,26 | $26,\!18,\!13,\!18,\!26,\!09,\!10,\!09,\!26$ |

switch states for DAV–PWM modulation can be derived using the switch state parser connected with all 9 control signals  $h_{11}-h_{33}$ . The state parser is a Matlab script, which operates on the PSIM data saved in CSV file format. Decoded SVM switching sequences for DAV–PWM modulation with Cyclic Venturini scheme are collected in Table V. The following major conclusions can be formulated based on the switch state sequences comparison:

- both, the SVM method and DAV-PWM use the same active vectors in their input and output voltage sectors,
- the construction of the switch state sequences in the DAV– PWM method is identical to the sequence for SVM shown in Fig. 10,
- the proposed DAV–PWM allows for reducing the harmonic distortion by having two zero vectors per period as reported in [42], but only the approach illustrated in Fig. 9 permits for reduction of switch operation frequency,
- tabularizing the switch state sequences is not necessary for a carrier-based modulation such as DAV-PWM.

## • HDL compilation

The ModelSim software was applied for modelling the digital module of the PWM duty cycle computation, in which the behavioural equivalent of the C-language developed DAV-PWM modulation had been coded using the Verilog HDL. The ModelSim simplified simulation diagram is shown in Fig. 11. This software is usually dedicated for digital core or module simulation but here that software has been used for developing the matrix converter control module. The fixed-point Q15 format arithmetic, in comparison with the single-precision format, often permits for developing very fast algorithms without pipelines and recursive operations. Continuous signals, such as input voltages, can be represented by the large tables of 16-bit values. The discreet sampling time was generated by the counter with auto-reload. An input displacement angle has been expressed as a sin-cos pair expressed by constant Q15 values. For simulation purpose only, the Cyclic-Venturini switching strategy was developed in Verilog HDL using nonsynthesizable modelling based on the signal delay command. This Verilog HDL piece of code is intentionally depicted in the drawing. Selected electrical waveforms, sectors, and PWM duty cycles in the analogue form, modelled using ModelSim simulation environment, are shown in Fig. 12. The load current was modelled using the first-order Infinite Impulse Response filter (IIR). All line-to-line load voltages were generated using the signal switching approach controlled by the input sector number.



Fig. 11. ModelSim simplified simulation diagram.





Fig. 12. Waveforms in the analogue form obtained by modelling of DAV–PWM algorithm written in Verilog HDL using ModelSim environment: (a)  $q=0.86, \, \phi_{\rm i}=0, \, \omega_{\rm i}=2\omega_{\rm o},$  (b)  $q=0.75, \, \phi_{\rm i}=-\pi/6, \, \omega_{\rm i}=2\omega_{\rm o}.$ 

## • HIL verification

For early validation of the Verilog HDL project file synthe-



Fig. 13. Early validation scheme of the improved DAV-PWM algorithm developed in Verilog HDL.



Fig. 14. Improved DAV-PWM algorithm signals during the debug session using the Signal Tap Logic Analyzer.

sizability, the Quartus 18.1 with Signal Tap Logic Analyzer was used. An evaluation board DE10–Lite was used during the HIL test. Two debugging tools were used during the validation stage. As shown in Fig. 13, the In–System Sources and Probes tool was used to give phase and frequency of signals generated by CORDIC Numerically Controlled Oscillators (NCO), while the Signal Tap Analyzer tool allowed to visualize and record of the selected signals in real–time. Fig. 14 shows an improved DAV–PWM algorithm signals during the debug session using the Signal Tap Logic Analyzer for  $\omega_{\rm i}/\omega_{\rm o}=2.67,\,f_s=1$  MHz, and q=0.8. The proposed PWM duty cycle computation module resource utilization is presented in Table VI.

TABLE VI
AN IMPROVED DAV–PWM DUTY CYCLE COMPUTATION MODULE
RESOURCE UTILIZATION.

| resource name            | utilization |  |
|--------------------------|-------------|--|
| Logic Cells              | 1454        |  |
| Dedicated Logic Register | 211         |  |
| DSP Elements             | 40          |  |
| DSP 18x18 multipliers    | 20          |  |

## V. EXPERIMENTAL RESULTS

A 5kW CMC with the control board, shown in Fig. 15, based on multicore ADSP–SC589 DSP from Analog Devices and MAX10 Intel FPGA device were used during experiment stage. The bidirectional power switch was build using two SiC transistors C3M0075120D. The schematic diagram of the experiment configuration is shown in Fig. 16. The block diagram of performed computation by FPGA device during an experiment is presented in Fig. 17. Q15 symbol indicates digital structures based on fixed–point arithmetic, while SP means the floating–point IP core used for time cycles scaling. This element is needed to preserve constant modulation frequency. The modulation period was  $100\mu s$ , while algorithm computation in Q15 blocks was accomplished through 100ns positive clock pulse.



Fig. 15. A 5kW matrix converter with the DSP-FPGA control board.



Fig. 16. The schematic diagram of the experiment configuration.



Fig. 17. The block diagram of performed computation by FPGA device during an experiment.

The waveforms for the normal operation with a zero displacement angle value  $\phi_{\rm i}$  and modulation with  $\phi_{\rm i}=-\pi/4$  are shown in Fig. 18. The proposed modulation method can be used in the case of supply voltage asymmetry. Despite such conditions, the input currents in each phase are sinusoidal. Experimental results for a significant asymmetry of input voltages  $\{V_{\rm i1}=75V,\ V_{\rm i2}=100V,\ {\rm and}\ V_{\rm i3}=125V\}$ , are shown in Fig. 19.



(a) 
$$q = 0.86$$
,  $\phi_i = 0$ 



(b) 
$$q = 0.6$$
,  $\phi_i = -\pi/4$ 

Fig. 18. Experimental results for  $\omega_{\rm o}/\omega_{\rm i}=0.5$  and symmetric input amplitudes for: (a) unity power factor, (b) reactive power generation.



Fig. 19. An output and input currents for asymmetrical input voltage source for DAV–PWM modulation:  $q=0.55,~\omega_{\rm o}/\omega_{\rm i}=0.5.$ 

### VI. CONCLUSION

The proposed computation scheme of PWM duty cycles does not require trigonometry operation and angles resulting in simplistic matrix converter control algorithm. All calculation is based on basic arithmetic operations that can be easily implemented in the FPGA within one clock tact. The proposed general direct modulation is an SVM equivalent when the low–distortion 8–switch double–sided modulator is applied. However, compared with SVM, the proposed DAV–PWM algorithm is much simpler. The comparision of the SVM and the improved DAV–PWM is presented in Table VII. With regard to the solution presented in [26], the following benefits were obtained, as presented in Table VIII.

 $\label{thm:table VII} The comparision of the SVM and the improved DAV–PWM.$ 

|                                                                 | SVM                                                                                                                           | DAV-PWM                                                                                                                                                                         |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| maximum voltage transfer ratio $q$ if $\cos(\phi_{ m i})=1$     | 0.866                                                                                                                         | 0.866                                                                                                                                                                           |
| an input angle control                                          | yes                                                                                                                           | yes                                                                                                                                                                             |
| the $q$ dependency from the input angle $\phi_1$                | $q = 0.866 \cdot \cos(\phi_i)$                                                                                                | $q = 0.866 \cdot \cos(\phi_i)$                                                                                                                                                  |
| trigonometric functions in the formulas for the PWM duty cycles | yes                                                                                                                           | no                                                                                                                                                                              |
| implementation in FPGA using HDL                                | difficult                                                                                                                     | simple                                                                                                                                                                          |
| execution time of the PWM duty cycle                            | several hundred<br>clock cycles                                                                                               | one clock                                                                                                                                                                       |
| switch states table                                             | switch state<br>sequences are<br>pre–selected and<br>placed in the<br>look–up table                                           | tabularizing of the<br>switch state<br>sequences is not<br>needed                                                                                                               |
| ready for hybrid modulation                                     | no – this algorithm<br>is hermetic and the<br>modulation can not<br>be modified in the<br>fly during the<br>device is running | yes – it is enough to<br>modify the<br>reference voltage<br>waveform                                                                                                            |
| ready for multiphase output (5 or more terminals)               | no – both, the<br>optimal switch state<br>sequences and the<br>PWM duty cycles<br>formulas must be<br>elaborated again        | yes – a new output<br>phase is represented<br>by the same<br>commutation cell,<br>an only new double<br>multiplier block is<br>required for the<br>PWM duty cycles<br>computing |
| PLL requirements                                                | yes – for the indication of the output voltage sectors and also the input current sectors                                     | no – there is no<br>PLL needed                                                                                                                                                  |

The discussed approach is suitable and more robust for FPGA implementation than a conventional approach such as SVM. For a better understanding of the solution developing process, the paper also briefly describes the HDL project compilation stage and HIL verification. Moreover, an early functional simulation of the CMC control can be performed using the ModelSim software. Finally, the solution can be represented only by one Verilog HDL file, thus an export to another FPGA vendor platform is not complicated and is not necessary to explicitly predefined the semiconductor switch states as in the SVM methods. Each converter cell is controlled independently in a direct way. This is especially convenient when the number of outputs is greater than the standard three. Simulation files are provided in the IEEE DataPort portal to increase understanding of the paper. The first file is a script for the Matlab environment, which is a presentation of the

TABLE VIII
THE COMPARISION OF THE PREVIOUS [26] AND THE IMPROVED DAV—PWM ALGORITHMS.

|                                                                                | previous                                                                                                  | present                                                                         |
|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| maximum voltage transfer ratio $q$ if $\cos(\phi_1)=1$                         | 0.866                                                                                                     | 0.866                                                                           |
| an input angle control<br>method                                               | the reference voltages' trajectory $\Gamma$ slope                                                         | based on the input voltage rotation matrix ${f R}$                              |
| the extraction method of the<br>quadrature components of<br>the input voltages | the Clarke transformation on each natural axis a-b-c                                                      | using the DSOGI-OSG structure                                                   |
| the occurrence of program loops in the algorithm                               | yes – for selection of the best<br>reference voltage trajectory<br>position inside the synthesis<br>field | no program loop                                                                 |
| ready to use in                                                                | DSP and processors only using the C-code                                                                  | C-code and HDL-code allow<br>the use in both, DSP and<br>FGPA based application |
| shortening the calculation time                                                | _                                                                                                         | $\approx$ 30% in DSP, one–cycle operation in the FPGA device                    |

proposed modulation. The second file contains the testbench of the proposed Verilog HDL modulator [44].

#### **APPENDIX**

The Verilog HDL code of the improved DAV-PWM algorithm.

```
module ImprovedDAVPWM #(parameter MSB=33,LSB=18)
 input iCLK,
 input signed [15:0] vilx,vi2x,vi3x,vily,vi2y,vi3y, input signed [15:0] volx,vo2x,vo3x,R_cos,R_sin, output reg[15:0] dll,d21,d31,d12,d22,d32,d13,d23,d33,sum,
 output reg [2:0] si,so
//x-coordinate difference
reg signed [16:0] vilx_volx,vi2x_volx,vi3x_volx;
reg signed [16:0] vilx_vo2x,vi2x_vo2x,vi3x_vo2x;
reg signed [16:0] vilx_vo3x,vi2x_vo3x,vi3x_vo3x;
reg signed [16:0] vily_py,vi2y_py,vi3y_py;
reg signed [16:0] vilx_vi2x,vi2x_vi3x,vi3x vilx;
reg signed [16:0] vily_vi2y,vi2y_vi3y,vi3y_vily;
reg signed [15:0] min_vox,max_vox;
//shift vector coordinates
reg signed [15:0] vsx,vsy;
reg signed [31:0] viRlxx,viR2xx,viR3xx,viRlyy,viR2yy,viR3yy;
reg signed [15:0] viRlx, viR2x, viR3x, viR1y, viR2y, viR3y;
reg signed [15:0] volxx,vo2xx,vo3xx;
reg signed [33:0] dllw,d2lw,d3lw,d12w,d22w,d32w,d13w,d23w,d33w,d00w;
reg signed [33:0] d11ww,d21ww,d31ww,d12ww,d22ww,d32ww,d13ww,d23ww,d33ww,d00ww;
always @(posedge iCLK)
so[2] = (volx \ge vo2x)? 1:0; so[1] = (vo2x \ge vo3x)? 1:0; so[0] = (vo3x \ge vo1x)? 1:0;
1: max_vox = vo3x;2: max_vox = vo2x;3: max_vox = vo2x;
4: max_vox = vo1x;5: max_vox = vo3x;6: max_vox = vo1x;
endcase
 case (so)
1: min vox = volx:2: min vox = vo3x:3: min vox = volx:
4: min_vox = vo2x;5: min_vox = vo2x;6: min_vox = vo3x;
 endcase
//rotation of the input vectors
\forall villxx = vilx * R_cos - vily * R_sin; viRlyy = vilx * R_sin + vily * R_cos; \forall viR2xx = vi2x * R_cos - vi2y * R_sin; viR2yy = vi2x * R_sin + vi2y * R_cos; \forall vi3xx = vi3x * R_cos - vi3y * R_sin; viR3yy = vi3x * R_sin + vi3y * R_cos;
//scaling of the foldated input vectors with x=viRlxx[30:15]; viRlx=viRlxx[30:15]; viRly=viRlyy[30:15]; viRly=viRlyy[30:15]; viRly=viRlyy[30:15]; viRly=viRlyy[30:15];
si[2]=(viR1y>=viR2y)? 1:0; si[1]=(viR2y>=viR3y)? 1:0; si[0]=(viR3y>=viR1y)? 1:0;
5,2: vsy=viRly; 4,3: vsy=viR3y; 6,1: vsy=viR2v;
6: vsx=viR2x-max_vox; 1: vsx=viR2x-min_vox; 3: vsx=viR3x-max_vox;
4: vsx=viR3x-min_vox; 5: vsx=viR1x-max_vox; 2: vsx=viR1x-min_vox;
//the real line-to-line input voltage vilx_vi2x=viR1x - viR2x; vi2x_vi3x=viR2x - viR3x; vi3x_vi1x=viR3x - viR1x;
vily_vi2y=viR1y - viR2y; vi2y_vi3y=viR2y - viR3y; vi3y_vi1y=viR3y - viR1y;
```



```
//shifted the real coordinates of output voltages
volxx=volx+vsx; vo2xx=vo2x+vsx; vo3xx=vo3x+vsx;
//x-coordinate difference
vilx_volx=viRix - volxx; vi2x_volx=viR2x - volxx; vi3x_volx=viR3x - volxx;
vi1x_vo2x=viRix - vo2xx; vi2x_vo2x=viR2x - vo2xx; vi3x_vo2x=viR3x - vo2xx;
vi1x_vo3x=viRix - vo3xx; vi2x_vo3x=viR2x - vo3xx; vi3x_vo3x=viR3x - vo3xx;
vi1x_vo3x=viR1x - vo3xx; vi2x_vo3x=viR2x - vo3xx; vi3x_vo3x=viR3x - vo3xx;
//y-coordinate difference
vi1y_py=viR1y - vsy; vi2y_py=viR2y - vsy; vi3y_py=viR3y - vsy;
//rational functions
dilu=(vi2x_vo1x*vi3y_py) - (vi3x_vo1x*vi2y_py);
d2lu=(vi3x_vo1x*vi1y_py) - (vi1x_vo1x*vi3y_py);
d2lu=(vi3x_vo1x*vi1y_py) - (vi1x_vo1x*vi3y_py);
d2lu=(vi2x_vo2x*vi3y_py) - (vi2x_vo1x*vi1y_py);
d2lu=(vi2x_vo2x*vi3y_py) - (vi3x_vo2x*vi2y_py);
d32u=(vi1x_vo2x*vi2y_py) - (vi2x_vo2x*vi1y_py);
d32u=(vi1x_vo2x*vi2y_py) - (vi2x_vo3x*vi2y_py);
d32u=(vi1x_vo3x*vi3y_py) - (vi1x_vo3x*vi3y_py);
d33u=(vi1x_vo3x*vi3y_py) - (vi1x_vo3x*vi3y_py);
d3u=(vi1x_vo3x*vi3y_py) - (vi1x_vo3x*vi3y_py);
```

### REFERENCES

- [1] J. Rodriguez, M. Rivera, J. Kolar, and P. Wheeler, "A review of control and modulation methods for matrix converters," *IEEE Trans. Ind. Electron.*, vol. 59, DOI 10.1109/TIE.2011.2165310, no. 1, pp. 58– 70, Jan. 2012.
- [2] L. Helle, K. Larsen, A. Jorgensen, S. Munk-Nielsen, and F. Blaabjerg, "Evaluation of modulation schemes for three-phase to threephase matrix converters," *IEEE Trans. Ind. Electron.*, vol. 51, DOI 10.1109/TIE.2003.821900, no. 1, pp. 158–171, Feb. 2004.
- [3] T. Friedli and J. Kolar, "Milestones in matrix converter research," *IEEJ Journal of Industry Application*, vol. 1, DOI 10.1541/ieejjia.1.2, no. 1, pp. 2–14, Jul. 2012.
- [4] H. M. Nguyen, H.-H. Lee, and T.-W. Chun, "Input power factor compensation algorithms using a new direct-svm method for matrix converter," *IEEE Trans. Ind. Electron.*, vol. 58, DOI 10.1109/TIE.2010.2044736, no. 1, pp. 232–243, Jan. 2011.
- [5] M. Apap, J. Clare, P. Wheeler, and K. Bradley, "Analysis and comparison of ac-ac matrix converter control strategies," *IEEE* 34th Annual Conference on Power Electronics Specialist, DOI 10.1109/PESC.2003.1216774, pp. 1287–1292, Jun. 2003.
- [6] W. Xiong, Y. Sun, J. Lin, M. Su, H. Dan, M. Rivera, and J. M. Guerrero, "A cost-effective and low-complexity predictive control for matrix converters under unbalanced grid voltage conditions," *IEEE Access*, vol. 7, DOI 10.1109/ACCESS.2019.2908446, pp. 43 895–43 905, 2019.
- [7] S. Mori, M. Aketa, T. Sakaguchi, H. Asahara, T. Nakamura, and T. Kimoto, "Suppression of punch-through current in 3 kv 4h-sic reverseblocking mosfet by using highly doped drift layer," *IEEE Journal of the Electron Devices Society*, vol. 6, DOI 10.1109/JEDS.2018.2819681, pp. 449–453, 2018.
- [8] S. Tammaruckwattana, Chenxin Yue, Y. Ikeda, and K. Ohyama, "Comparison of switching losses of matrix converters for commutation methods," in 2014 16th European Conference on Power Electronics and Applications, DOI 10.1109/EPE.2014.6910995, pp. 1–10, Aug. 2014.
- [9] Y. Guo, Y. Guo, W. Deng, J. Zhu, and F. Blaabjerg, "An improved 4-step commutation method application for matrix converter," in 2014 17th International Conference on Electrical Machines and Systems (ICEMS), DOI 10.1109/ICEMS.2014.7014112, pp. 3590–3593, Oct. 2014.
- [10] O. Simon, J. Mahlein, M. N. Muenzer, and M. Bruckmarm, "Modern solutions for industrial matrix-converter applications," *IEEE Transactions on Industrial Electronics*, vol. 49, DOI 10.1109/41.993273, no. 2, pp. 401–406, Apr. 2002.
- [11] P. W. Wheeler, J. C. Clare, M. Apap, D. Lampard, S. J. Pickering, K. J. Bradley, and L. Empringham, "An integrated 30kw matrix converter based induction motor drive," in 2005 IEEE 36th Power Electronics Specialists Conference, DOI 10.1109/PESC.2005.1581967, pp. 2390–2395, Jun. 2005.
- [12] A. Hassan, Y. Savaria, and M. Sawan, "Gan integration technology, an ideal candidate for high-temperature applications: A review," *IEEE Ac*cess, vol. 6, DOI 10.1109/ACCESS.2018.2885285, pp. 78790–78802, 2018.
- [13] M. Ishida, T. Ueda, T. Tanaka, and D. Ueda, "Gan on si technologies for power switching devices," *IEEE Transactions on Electron Devices*,

- vol. 60, DOI 10.1109/TED.2013.2268577, no. 10, pp. 3053–3059, Oct. 2013.
- [14] D. Lan, P. Das, and S. K. Sahoo, "A high-frequency link matrix rectifier with a pure capacitive output filter in a discontinuous conduction mode," *IEEE Transactions on Industrial Electronics*, vol. 67, DOI 10.1109/TIE.2019.2893838, no. 1, pp. 4–15, Jan. 2020.
- [15] R. J. Kaplar, M. J. Marinella, S. DasGupta, M. A. Smith, S. Atcitty, M. Sun, and T. Palacios, "Characterization and reliability of sic- and gan-based power transistors for renewable energy applications," in 2012 IEEE Energytech, DOI 10.1109/EnergyTech.2012.6304627, pp. 1–6, May. 2012.
- [16] C. Bailey, D. M. Saban, and P. Guedes-Pinto, "Design of high-speed direct-connected permanent-magnet motors and generators for the petrochemical industry," *IEEE Transactions on Industry Applications*, vol. 45, no. 3, pp. 1159–1165, 2009.
- [17] J. Benzaquen, M. B. Shadmand, and B. Mirafzal, "Ultrafast rectifier for variable-frequency applications," *IEEE Access*, vol. 7, DOI 10.1109/AC-CESS.2019.2891351, pp. 9903–9911, 2019.
- [18] Q. Wu, M. Wang, W. Zhou, X. Wang, G. Liu, and C. You, "Analytical switching model of a 1200v sic mosfet in a high-frequency series resonant pulsed power converter for plasma generation," *IEEE Access*, vol. 7, DOI 10.1109/ACCESS.2019.2930535, pp. 99 622–99 632, 2019.
- [19] M. Venturini and A. Alesina, "The generalised transformer: A new bidirectional, sinusoidal waveform frequency converter with continuously adjustable input power factor," in 1980 IEEE Power Electronics Specialists Conference, pp. 242–252, 1980.
- [20] A. Alesina and M. G. B. Venturini, "Analysis and design of optimumamplitude nine-switch direct ac-ac converters," *IEEE Transactions on Power Electronics*, vol. 4, no. 1, pp. 101–112, 1989.
- [21] A. K. Dey, G. Mohapatra, T. K. Mohapatra, and R. Sharma, "A modified venturini pwm scheme for matrix converters," in 2019 IEEE International Conference on Sustainable Energy Technologies and Systems (ICSETS), DOI 10.1109/ICSETS.2019.8745014, pp. 013–018, Feb. 2019.
- [22] Z. Malekjamshidi, M. Jafari, and J. Zhu, "Analysis and comparison of direct matrix converters controlled by space vector and venturini modulations," in 2015 IEEE 11th International Conference on Power Electronics and Drive Systems, DOI 10.1109/PEDS.2015.7203550, pp. 635–639, Jun. 2015.
- [23] C. Ortega, A. Arias, C. Caruana, J. Balcells, and G. M. Asher, "Improved waveform quality in the direct torque control of matrix-converter-fed pmsm drives," *IEEE Transactions on Industrial Electronics*, vol. 57, no. 6, pp. 2101–2110, 2010.
- [24] M. Rivera, A. Wilson, C. A. Rojas, J. Rodriguez, J. R. Espinoza, P. W. Wheeler, and L. Empringham, "A comparative assessment of model predictive current control and space vector modulation in a direct matrix converter," *IEEE Transactions on Industrial Electronics*, vol. 60, no. 2, pp. 578–588, 2013.
- [25] F. Gruson, P. Le Moigne, P. Delarue, A. Videt, X. Cimetiere, and M. Arpilliere, "A simple carrier-based modulation for the svm of the matrix converter," *IEEE Transactions on Industrial Informatics*, vol. 9, no. 2, pp. 947–956, 2013.
- [26] P. Szczepankowski, P. Wheeler, and T. Bajdecki, "Application of analytic signal and smooth interpolation in pulse width modulation for conventional matrix converters," *IEEE Transactions on Industrial Electronics*, DOI 10.1109/TIE.2019.2956391, pp. 1–1, 2019.
- [27] P. Szczepankowski, T. Bajdecki, and R. Strzelecki, "Direct modulation for conventional matrix converters using analytical signals and barycentric coordinates," *IEEE Access*, vol. 8, pp. 22 592–22 616, 2020.
- [28] A. Reilly, G. Frazer, and B. Boashash, "Analytic signal generationtips and traps," *IEEE Trans. Signal Process.*, vol. 42, DOI 10.1109/78.330385, no. 11, pp. 3241–3245, Nov. 1994.
- [29] L. Marple, "Computing the discrete-time "analytic" signal via fft," *IEEE Trans. Signal Process.*, vol. 47, DOI 10.1109/78.782222, no. 9, pp. 2600–2603, Sep. 1999.
- [30] L. Asiminoael, F. Blaabjerg, and S. Hansen, "Computing the discrete-time "analytic" signal via fft," *IEEE Ind. Appl. Mag.*, vol. 13, DOI 10.1109/MIA.2007.4283506, no. 4, pp. 22–33, Jul. 2007.
- [31] Q. Yan, R. Zhao, X. Yuan, W. Ma, and J. He, "A dsogi-fll-based dead-time elimination pwm for three-phase power converters," *IEEE Transactions on Power Electronics*, vol. 34, no. 3, pp. 2805–2818, 2019.
- [32] Z. Xin, R. Zhao, F. Blaabjerg, L. Zhang, and P. C. Loh, "An improved flux observer for field-oriented control of induction motors based on dual second-order generalized integrator frequency-locked loop," *IEEE Journal of Emerging and Selected Topics in Power Electronics*, vol. 5, no. 1, pp. 513–525, 2017.



- [33] N. Hoffmann, R. Lohde, M. Fischer, F. W. Fuchs, L. Asiminoaei, and P. B. ThA, gersen, "A review on fundamental grid-voltage detection methods under highly distorted conditions in distributed powergeneration networks," in 2011 IEEE Energy Conversion Congress and Exposition, pp. 3045–3052, 2011.
- [34] P. Rodriguez, A. Luna, M. Ciobotaru, R. Teodorescu, and F. Blaabjerg, "Advanced grid synchronization system for power converters under unbalanced and distorted operating conditions," in IECON 2006 - 32nd Annual Conference on IEEE Industrial Electronics, pp. 5173-5178,
- [35] K. R. Patil and H. H. Patel, "Modified dual second-order generalised integrator fll for synchronization of a distributed generator to a weak grid," in 2016 IEEE 16th International Conference on Environment and Electrical Engineering (EEEIC), pp. 1–5, 2016.
- [36] X. He, H. Geng, and G. Yang, "A generalized design framework of notch filter based frequency-locked loop for three-phase grid voltage," IEEE Transactions on Industrial Electronics, vol. 65, no. 9, pp. 7072-7084,
- [37] P. W. Wheeler, J. Clare, and L. Empringham, "Enhancement of matrix converter output waveform quality using minimized commutation times,' IEEE Transactions on Industrial Electronics, vol. 51, no. 1, pp. 240-244,
- [38] H. Nguyen and H. Lee, "A modulation scheme for matrix converters with perfect zero common-mode voltage," IEEE Transactions on Power Electronics, vol. 31, no. 8, pp. 5411-5422, 2016.
- [39] H. She, H. Lin, B. He, X. Wang, L. Yue, and X. An, "Implementation of voltage-based commutation in space-vector-modulated matrix converter," IEEE Transactions on Industrial Electronics, vol. 59, no. 1, pp. 154-166, 2012.
- [40] H. Hara, E. Yamamoto, Jun-Koo Kang, and T. Kume, "Improvement of output voltage control performance for low-speed operation of matrix converter," IEEE Transactions on Power Electronics, vol. 20, no. 6, pp. 1372-1378, 2005.
- [41] J. Mahlein, J. Igney, J. Weigold, M. Braun, and O. Simon, "Matrix converter commutation strategies with and without explicit input voltage sign measurement," IEEE Transactions on Industrial Electronics, vol. 49, no. 2, pp. 407-414, 2002.
- [42] K. B. Larsen, A. H. Jorgensen, L. Helle, and F. Blaabjerg, "Analysis of symmetrical pulse width modulation strategies for matrix converters," in 2002 IEEE 33rd Annual IEEE Power Electronics Specialists Conference. Proceedings (Cat. No.02CH37289), vol. 2, pp. 899-904 vol.2, 2002.
- [43] L. Helle and S. Munk-Nielsen, "A novel loss reduced modulation strategy for matrix converters," in 2001 IEEE 32nd Annual Power Electronics Specialists Conference (IEEE Cat. No.01CH37230), vol. 2, pp. 1102-1107 vol.2, 2001.

[44] P. Szczepankowski, "Direct analytic voltage pulse width modulation using fpga and verilog hdl." 2020. [Online]. Available: https: //dx.doi.org/10.21227/8xgm-6h16



Pawel Szczepankowski (M'18) received his PhD degree in electrical engineering in 2009 and D.Sc. in 2020 from Gdansk University of Technology, Poland. He authored or co-authored more than 50 scientific and technical papers. His research interests include design, control, diagnostics, modelling and simulation of power electronic converters, including multilevel, matrix and modular topologies. He deals with designing and programming microprocessor control systems with DSP processors and FPGA devices.



Wojciech Sleszynski (M'20) He received the M.Sc. degree in control engineering and the Ph.D. degree in electrical engineering from Gdansk University of Technology, Poland, in 2000 and 2007 respectively. Since 2001, he has been with the Faculty of Electrical and Control Engineering, Gdansk University of Technology, where he is currently an Assistant Professor. His research and teaching interests include power electronics, digital signal processing, semiconductor switch diagnostic, and control of the energy coversion.



Tomasz Bajdecki received M.S. in electrical engineering from the Czestochowa University of Technology, Poland. in 1992. In 2003 he received a Ph.D. degree from Gdansk of Technology University for dissertation 'Control strategy for the matrix converter'. He is now with the Institute of Power Engineering, Gdansk, as a Research Staff Member. His main current interest is in control of the high area of converters.