ABSTRACT This paper proposes a Petri-net-based specification of cyber-physical systems dedicated to the control of a direct matrix converter with space vector modulation (SVM) and transistor commutation. The technique employed is further applied for hardware implementation in a programmable logic device [namely, field-programmable gate array (FPGA)]. Contrary to the traditional SVM computation methods, concurrency aspects of the digital devices are highly utilized in the presented solution. Therefore, the hardware system is specified by a live and safe Petri net, which is based on the parallelism. Moreover, such a specification can be easily analyzed and verified against the structural properties in order to avoid formal errors and prototyping mistakes (such as deadlocks or non-reachable states). The proposed idea is illustrated by a case-study example of the real prototype of the SVM algorithm. The system has been specified by a live and safe Petri net, analyzed, verified, and finally implemented in the FPGA device. The obtained results of the physical implementation are presented and discussed.
I. INTRODUCTION
A cyber-physical system (CPS), [1] , [2] , creates a set of components that interact with each other, integrating cybernetic aspects with physical processes. The operation of such a system is, by nature, concurrent, enabling the execution of multiple operations simultaneously. For example, one cyberphysical system is a power electronic converter, which is used to control digital circuits and must interact with the physical environment. Increasingly, digital control systems for power converters must meet high requirements for advanced modulation and commutation process, as well as control of executive devices. Additionally, it is possible to exchange information about the state of the converter or its failures with the physical environment. The development of converters is related to the progress of control systems and user interfaces as well as power semiconductor components. All these require the use of sophisticated hardware specification algorithms.
The associate editor coordinating the review of this manuscript and approving it for publication was Luis Gomes.
Development of power semiconductor devices and the increase in the areas of their application has brought on the development of complex converter configurations and various control schemes [3] . The main stage of the power converter is usually conceived as a combination of elementary semiconductor power devices (transistors and diodes) with passive reactance elements (capacitors, inductors or transformers). Recent advances in semi-conductor technology have led to an increase in the transistor switching frequencies in modern power converters, up to a hundred kilohertz (by application of Silicon Carbide (SiC) [4] , [5] or Gallium nitride (GaN) [6] transistors). Increasing switching frequency makes possible a reduction in the size and weight of the reactance elements as well as of the entire converter. At the same time, the number of switching devices is increasing in modern power converters. High switching frequencies, a large number of power switches, as well as a complex control strategy, make necessary the use of parallel processing techniques in the control loops.
An example of a power electronic converter with a large number of power electronics switches and sophisticated control schemes is the matrix converter (MC) [7] . For decades, the MC has been an attractive topology for three-phase AC-AC power conversion.
The specificity and complexity of the MC control scheme results directly from its construction as a direct frequency converter. The MC main power stage forms a matrix of bi-directional power electronic switches connected between input and output terminals. Additionally, for good performance, the MC should have a source low pass LC filter, the purpose of which is the minimization of the high frequency components in the input current [8] . Distinctive switch configurations require the generation of appropriate pulse width modulation (PWM) signal patterns for the control of individual transistors with a safe commutation strategy and optimized switching power losses [9] , [10] . Of the many existing modulation strategies MCs, the space vector modulation (SVM) methods are the most widespread. Additionally, to ensure the safe switching of transistors and to minimize the losses generated during switching, different switching sequences, called commutation strategies are used [9] . In the scientific literature, commutation strategies are known in which the switching sequences are defined depending on the direction of the load current or voltage on the switch. Both processes, modulation of the control function and commutation of transistors require relatively large computational resources for control devices such as digital signal processors (DSPs) or microcontrollers (µC). In addition, the converter works with a master control algorithm that results from its specific application (Fig. 1) . For example, a MC can be a power supply for a variable speed drive system, a power electronic interface for distributed AC energy sources, or a part of an electric power conditioner [11] . Depending on the complexity of external algorithms, additional calculations and transformations as well as measurements of external signals are required. This further adds to the demand for available computing power in control devices. At the same time, the process of modulating the control function and commutation of transistors has a constant structure regardless of the type of application. This relatively complex computation fragment of the entire control algorithm (marked with a FIGURE 1. General structure of the power electronic converter control system. red square in Fig. 1.) can be implemented and optimized in CPLD (complex programmable logic devices) or FPGA (field programmable gate array) devices. Considering the above, there is a need to implement the discussed algorithms in FPGA devices and to develop procedures for optimizing and verifying the correctness of the code for the implemented algorithms.
A. OVERVIEW OF EXISTING SOLUTIONS
Nowadays, the most common way to implement digital modulation and commutation algorithms in the MC is to use complex microprocessor systems, often combining DSP and FPGA technologies [12] . Design solutions for research prototypes often use rapid prototyping and diagnostic platforms based on a programming environment equipped with readymade block control functions with a dedicated real-time hardware simulator, e.g. DSpace, Opal-RT [13] , [14] . In the MC the master control and modulation algorithm are in most cases embedded in the DSP, while the FPGA is solely used to execute the functions associated with commutation issues [12] . It should be noted that the DSP is limited in the number of instructions per sampling cycle. This is especially important for very high switching frequencies of several dozen (several hundred) kilohertz, where the time required for performing algorithmic calculations is very short [15] . In addition, the amount of PWM digital signals needed, related to the number of controlled transistors, also significantly increases the number of calculations needed to perform.
Summarizing these considerations, it can be concluded that the use of novel power semiconductors e.g. SiC transistors in matrix converters offers great opportunities associated with reduction of commutation losses and increase in the power density [15] , [16] .
At the same time, the implementation of a complex SVM algorithm and commutation strategy with very short computing times resulting from a high switching frequency can be difficult to implement in classical DSP systems. Therefore, hardware implementations of the SVM algorithm using programmable logic devices have become more popular. FPGA devices due to their flexibility, parallelism, processing speed and reconfigurability are often the best choice of the implementation platform in various fields of industry and science [17] , [18] including SVM algorithm realization [7] , [19] - [21] . Generally, there are two main approaches to SVM algorithm hardware implementation. The first one uses a hybrid of connected DSP and FPGA devices, while the second is based on the FPGA only.
In [19] a typical hybrid DSP-FPGA approach is presented. The DSP module calculates parameters and selects modulation mode, while the programmable device is used for PWM pulse generation. The advantage of such an approach is a low-cost system architecture, but the use of external tools to model the FPGA-part can be seen as a drawback. Using specialized tools (e.g., Matlab/Simulink) forces additional conversions which causes inefficient hardware utilization of the FPGA device. Moreover, the aspects of concurrent computation are not considered in the paper.
A similar DSP-FPGA approach, but without any datatransfer bus, is proposed in [20] . Another advantage of the proposed method is the use of the parallelism feature of FPGAs. Unfortunately, the presented approach requires advanced design knowledge of various design and implementation tools. Moreover, the implementation of the whole SVM algorithm in the FPGA is not considered.
The second group of the discussed hardware implementation techniques uses only the FPGA device (without DSP) to implement the SVM algorithm. It is worth noting that such an implementation (especially when the algorithm uses advanced mathematical functions, e.g., trigonometric functions [22] ) is much more difficult because of the severe restrictions of the synthesis tools (e.g., Xilinx ISE Design Suite) [18] . Nevertheless, application of the FPGA results in benefits that cannot be achieved by the traditional DSP, such as parallelism and computation speed.
Using System-On-a-Chip (SoC) for hardware implementation of an SVM algorithm is presented in [7] . The authors show the benefits of using an embedded processor (a part of FPGA from Xilinx Virtex-4 family) instead of a traditional DSP. As the authors state, using an FPGA as the implementation platform results in a very high modulation frequency and shortens the processing time. Furthermore, the whole system is integrated in one single chip. Unfortunately, the presented approach requires conversion to the VHDL code and the use of external tools (e.g., Matlab/Simulink, ISE-EDK). Moreover, utilization of FPGA with integrated processors increases the final cost of the system. Gulbudak and Santi [21] propose an FPGA-based model predictive controller (MPC) as a matrix converter. The advantages of the presented approach are the use of an FPGA (without DSP) for computation only and utilization of the concurrent feature of the FPGA (some computation tasks are performed simultaneously). Unfortunately, the presented solution is shown at a very general level without the important information regarding the implementation methodology, such as modeling methods or use of special tools or converters.
B. MOTIVATION AND PROBLEM FORMULATION
Summarizing the above discussion, it is worth noting, that a significant trend in the use of programmable logic devices (especially FPGA) as a hardware implementation platform for the SVM algorithm can be observed. The main advantages of FPGAs, such as the parallel task execution feature and very high processing speed, result in the growing popularity of FPGA use in the SVM hardware implementation. Unfortunately, existing solutions usually need external tools (mostly Matlab/Simulink), which requires further translations into the hardware description languages. Moreover, very often the parallel feature of digital devices is not fully exploited. Finally, most of the approaches are based on a FPGA-DSP hybrid structure, where the traditional DSP is responsible for mathematical operations execution.
The paper tries to face the problems mentioned above. The proposed SVM approach is oriented toward the cyber-physical system implemented in a single FPGA. Contrary to the existing solutions, the proposed approach neither requires any additional convertors nor specialized external tools.
There are several approaches for representing the SVM algorithm. The most popular one applies concurrency flowcharts, or block diagrams supplemented by mathematical equations. However, it seems that more efficient options rely on the use of a specialized modeling language, such as Unified Modeling Language [23] or Petri nets [24] , [25] . This paper applies safe and live Petri nets to specify the system. Such an approach results in several benefits. First of all, the proposed technique greatly exploits the parallel features of Petri-net-based specification, since most of the operations are performed simultaneously.
Moreover, Petri nets are supported by various analysis and verification methods [26] - [35] which can be applied in order to ensure that the model is formally correct before going on with the next steps of the design process (description on HDLs, synthesis, implementation). It is worth mentioning that the analysis of the reliability and robustness of the system is also possible [27] , [28] , [36] - [38] , as well as the application of the model checking techniques [33] , [39] , or even detailed analysis of concurrency and sequentiality relations in the system [40] .
Furthermore, dedicated decomposition methods (designed specifically for Petri net models) can be applied in order to split the algorithm into several modules [26] , [41] , [42] . Moreover, each of those modules can be implemented as an independent device, constituting a distributed system [41] - [43] . Additionally, Petri nets allow a comfortable prototyping framework/method enabling further dynamic partial reconfiguration of the targeted FPGA device [18] . This feature is very useful in the case of systems that require modification of part of the system without shutting down the whole system [44] . In other words, a separated part of the algorithm (module) with changed specification can be easily replaced without interruption of other modules [18] , [44] .
Finally, it should be mentioned that there are several types of Petri nets, e.g., Colored Petri nets, Ordinary Petri nets, Unbounded Petri nets, Hybrid Petri nets, S3PR nets, and interpreted Petri nets [18] , [27] - [29] , [41] , [45] - [50] . Each of them contains unique features and thus can be applied in different areas, such as system engineering, concurrent control system implementation in digital devices, distributed systems or flexible manufacturing systems.
In this paper we shall use live and safe Petri nets, which are very efficient for control process modeling [41] , [43] . Furthermore, such nets can relatively easily split the system into sequential components in order to create a distributed system, or to apply the idea of the FPGA dynamic partial reconfiguration feature [18] , [41] .
C. MAIN CONTRIBUTIONS OF THE PAPER
The paper proposes application of Petri net theory to the specification of cyber-physical systems designed to control a direct matrix converter with space vector modulation and transistor commutation. The presented approach involves several steps. Initially, the SVM algorithm is described by an interpreted Petri net. Such a specification naturally reflects the parallel relations of the designed system. Moreover, control systems described with Petri nets can be easily decomposed into sequential modules and allows for application of dedicated analysis and verification methods to check the main properties of the system (liveness, safeness, markings, classification, number of the minimal SMCs that cover the net, etc.).
In short, the main contributions can be summarized as follows:
• A Petri-net based specification of a cyber-physical system designed to control an MC with SVM and modulation is proposed. The method is oriented toward implementation in an FPGA device.
• The proposed idea involves the main benefit of Petri nets and digital devices, that is, their parallelism. It means that several tasks are calculated simultaneously, which is not possible in the case of traditional techniques (based on the DSPs), which execute operations sequentially.
• The method applies to live and safe Petri nets, which permit the analysis and verification of the designed system in order to avoid errors and mistakes at the specification stage.
• The applied specification model allows further decomposition of the system into the sequential modules (state machine components, SMCs). These modules can be applied to form a distributed system or to the dynamic partial reconfiguration of the system.
• The presented idea is illustrated by a real-life case study example. The presented cyber-physical system has been specified by a live and safe Petri net, described in the Verilog language and finally implemented in an FPGA. The structure of the paper is organized as follows. Sections II and III introduce matrix converters and Petri nets, respectively. The main idea of the proposed technique is shown in Section IV, while the subsequent section presents the case-study example. The results of analytical, numerical and hardware verification of the system are presented in Section VI. Finally, Section VII concludes the paper and shows possible directions for future research.
II. MATRIX CONVERTER TOPOLOGY AND SPACE VECTOR MODULATION ALGORITHM
The direct matrix converter (MC) is a power converter topology based on controlled bidirectional switches, as shown in Fig. 2 [7] - [10] .
The MC is an alternative to the conventional back-to-back converter. The MC can offer significant advantages in terms of weight and volume (high power density) and it does not require any energy storage element. The matrix converter input/output voltage or current relationships are defined by the equations (1) and (2) [9] . 
Different modulation strategies for matrix converters, including the low frequency modulation function (Venturini and the scalar method), space vector modulation (SVM) techniques and predictive control, have been previously reported in science literature [10] . The SVM algorithm is most often used in matrix converter applications because of its favorable control properties. The SVM is based on the instantaneous space vector representation of MCs signals.
The transform from the three-phase line-to-line output voltages u ab (t), u ba (t), u ca (t) to the complex vector u OL is given by (3) while the transformation of the MC input currents i A (t), i B (t), i C (t) is given by (4) .
In the MC with SVM the output voltage reference spacevectors u OL and input current reference space-vectors i S are constructed by selecting four ''active'' and one ''zero'' switch combinations in the sequence period T Seq [9] . Allowed ''active'' and ''zero'' switch configurations and the corresponding values of output voltages and grid currents for individual output or input terminals are listed in Table 1 .
Voltage and current vectors with non-zero amplitude are created during ''active'' switch configurations. The zero configurations are applied to complete time interval T Seq . In Fig. 3 the output voltage and input current vectors corresponding to the ''active'' switch configurations are shown, respectively. The complex coordinate system is divided into six sectors S O for output voltages and six sectors Si for source current. The resulting voltage vector creates an α O angle while the current vector creates a β i angle between the origin of the coordinate system.
The synthesis process of reference output voltage and source current space vectors is presented in Fig. 4 , according to dependence (5) .
where:
Relative switching times in each sequence period T Seq are defined by the following equations [9] :
For equations (6)- (9), new anglesα O andβ i are defined relative to the bisecting line of the current sector of the complex coordinate system and reference voltage and current space vectors, respectively. The new angles are limited to the following values:
The switching pattern of the switches depends on the position of the reference vectors in a sector S O and S i and is summarized in Table 2 [9]. The distribution of zero vectors in a given switching sequence is determined by the d IV sign, which is summarized in Table 3 . The advantage of SVM is the ability to control the input displacement angle ϕ i between the source current and the voltage as is shown in Fig. 4b . The disadvantage of the matrix converter is voltage gain, the maximum value of which is equal q max = √ 3 Safe commutation of individual transistors of the matrix converter is connected with the fulfillment of the following rules: i) should not cause a short circuit between the two input phases, because the consequent high circulating current might destroy the switches, ii) should not cause an interruption of the output current, because the consequent overvoltage might likely destroy the switches [9] . In order to meet these rules, several commutation strategies have been proposed [51] , [52] . The most common solution is the fourstep commutation strategy. In this method the direction of current flow through the commutation cells can be controlled (Fig. 5, top) , and the current direction is used to determine which device in the active switch cell is not current conducting. The commutation process as a timing diagram and a state diagram is shown at the bottom of Fig. 5 . An identical switching sequence occurs between any two bidirectional switches in each output phase of the MC. Commonly in MC control systems, the commutation process is carried out with FPGAs due to the limited computing power of DSPs, while the modulation and control part of the control algorithm is implemented on DSP devices [12] . Digital controllers for power converters are being more and more implemented in FPGAs due to the increasing complexity of modulation and commutation algorithms, higher switching frequencies, and concurrence requirements. In this paper, due to the high switching frequency of PWM signals, both the modulation and commutation processes will be implemented in the FPGA device.
III. PETRI NETS
Let us introduce the main definitions and notations necessary to explain the proposed idea. The presented definitions correspond to the notations from [18] , [28] , [41] , [43] , and [53] - [57] .
Definition 1: A Petri net PN is a 4-tupe: N = (P, T , F, M 0 ) where P is a finite set of places, T is a finite set of transitions, F⊆ (P × T )∪(T × P) is a finite set of arcs, M 0 : P → N is an initial marking. Sets of input and output places of a transition are defined as: t = {p ∈ P : (p, t) ∈ F, t = {p ∈ P : (t, p) ∈ F, while sets of input and output transitions of a place are denoted as:
Definition 2: A state of a Petri net N = (P, T , F, M 0 ) is called a marking. A marking is a vector P of nonnegative integer numbers assigning to every place p ∈ P number of tokens. Definition 5: A marked graph net (MG-net) is a Petri net PN = (P, T , F, M 0 ) for which every place p has exactly one input transition and exactly one output transition i.e. ∀p ∈ P: | • | = |p| = 1.
Definition 6: A state machine net (SM-net) is a Petri net PN = (P, T , F, M 0 ) for which every transition t has exactly one input place and exactly one output place i.e. ∀t ∈ T : | • | = |t| = 1, and there is exactly one token at the initial marking.
Definition 7: A state machine component (SMC) of a Petri net PN = (P, T , F, M 0 ) is a Petri net S = (P , T , F , M 0 ) such that S is an SM-net.
Definition 8: A Petri net PN = (P, T , F, M 0 ) is SMcoverable, if for each place p ∈ P there is an SMC S = (P , T , F , M 0 ) of PN such that p ∈ P .
Definition 9: An incidence matrix of a Petri net PN = (P, T , F, M 0 ) with n = |P| places and m = |T | transitions is an A m×n=[a ij ] matrix (where m refers to rows, and n refers to columns) of integers, given by:
Definition 10: A place invariant (p-invariant) of a Petri net PN = (P, T , F, M 0 ) is a vector y of nonnegative integers that solves the equation y·A T = 0, where y = 0 and A T is a transposed incidence matrix of the net.
IV. THE IDEA OF THE PROPOSED TECHNIQUE
The idea of the proposed method is based on the specification of the cyber-physical system in the form of a live and safe Petri net (Fig. 6 ). There are 19 places and 11 transitions in the net. It is assumed that tasks executed by the hardware system are associated to the places of the net, as shown in Tab. 3. There are 19 main stages (tasks) in the proposed hardware method. They are directly represented by the particular places of the net. Note that most of tasks are executed concurrently, especially computations regarding values for load voltages and source currents (places p 2 , . . . , p 5 ). Furthermore, all the duty cycles are calculated in a simultaneous manner 19 ).
Let us now describe each of the above tasks in more detail. Initially, the instantaneous values of the load voltages u ab , u bc , u ca and source currents i A , i B , i C are set based on the input values. This task is associated with the place p1 in the presented Petri net. Then, the real and imaginary parts for the space vectors u OL and i S are simultaneously computed. In particular, the following tasks are executed [9] :
1. Computation of the real part (Re) of the space vector for u OL (place p 2 ):
2. Computation of the imaginary part (Im) of the space vector for u OL (place p 3 ):
3. Computation of the real part (Re) of the space vector for i S (place p 4 ):
4. Computation of the imaginary part (Im) of the space vector for i S (place p 5 ):
VOLUME 7, 2019
Once the real and imaginary parts of the space vectors are obtained, the calculations regarding angles and sectors are performed. Note that such operations are executed simultaneously for voltages and currents. Indeed, places p 6 , p 8 , and p 10 refer to the computation angleα O for u OL (angle α O computation, the sector S O computation and angle α O scaling, respectively), while angleβ i for i S (angle β computation, the sector S i computation and angleβ i scaling) is computed by tasks associated to places p 7 , p 9 , and p 11 . In particular, computation of the angle α O between the real and imaginary parts of the space vector for u OL is executed according to the equation (place p 6 ):
Further computation of the sector S O for the voltage space vector is based on the angle α O (place p 8 ). Finally, normalization (scaling) of the angle α O from the initial range −π ≤ α O ≤ π to the range − π 6 ≤α O ≤ π 6 is executed depending on the sector S O [9] (place p 10 ).
Computation of the angle β i between the real and imaginary parts of the space vector for i S is performed in the same manner (place p 7 ):
Similarly, computation of the sector S i for the voltage space vector is calculated based on the angle β i (place p 9 ). Finally, angle β i is normalized from the initial range −π ≤ β i ≤ π to the range − π 6 ≤β i ≤ π 6 (place p 11 ). The modulation duty cycles are computed within places p 12 , . . . , p 15 . Those values are calculated simultaneously, according to equations (6)- (9) . Indeed, the value of the modulation duty cycle d I is obtained by the execution of place p 12 , the value of cycle d II is computed by the operations performed within place p 12 , and so on. Based on those values, the switches (internal PWM signals S aA , . . . , S cC ) are generated. This task is executed within place p 16 .
Finally, the output commutation signals (
, T aC2 ) are computed. They are evaluated concurrently by places p 17 , p 18 , p 19 . Each place represents a task referred to at a particular line. Therefore, place p 17 represents operations related to the line a, place p 18 is related to the line b, while place p 19 refers to the line c. Note that thanks to the applied Petri net-based specification, the tasks for particular lines are executed concurrently.
V. CASE-STUDY EXAMPLE (HARDWARE IMPLEMENTATION OF THE PROPOSED METHOD)
Let us now present the hardware implementation of the Petrinet specification of the system shown in the previous section. Fig. 7 shows the block-diagram of the system. It is assumed that each place of the Petri-net refers to the hardware module of the system. For example, place p 2 corresponds to the component that is responsible for computation of the real part of the space vector for voltages, etc. All but two of the modules have been prepared (written) in a pure Verilog hardware language, the exceptions being two sub-components that are dedicated to the trigonometric operations, which we shall discuss later.
All the modules of the system are connected via internal buses. Most of components are synchronous, thus an external clock signal clk is delivered (see Fig. 7 ). Furthermore, seven blocks of the system are zeroed by the reset signal (four modules that compute duty cycles d I ,. . . , d IV , and three commutation blocks). Let us briefly describe all the components of the presented hardware system.
A. COMPUTATION OF THE REAL AND IMAGINARY PARTS OF THE SPACE VECTOR FOR VOLTAGES AND CURRENTS (FOUR MODULES)
There are four blocks that are responsible for calculation of the real or imaginary parts of the space vectors. All those tasks are executed concurrently. The upper two modules (denoted as Re and Im on the block diagram) refer to places p 2 and p 3 of the Petri net and they are applied in order to compute the proper values of the space vector for voltages. Similarly, two bottom modules Re and Im are designed to obtain the real and imaginary parts of the space vectors for currents (places p 4 and p 5 of the net). All those components are prototyped as combinational circuits, thus no clock nor reset signal are delivered. The internal computation of the trigonometric function (arctangent) is performed with the use of a COordinate Rotation DIgital Computer (CORDIC) technique. In particular, the dedicated Intellectual Property (IP-core) from Xilinx is applied [58] .
B. ANGLE COMPUTATION OF THE SPACE VECTORS (TWO MODULES)
This is a sequential module that computes the proper angle between the real and the imaginary parts of the space vectors. There are two instances of this block. The first one refers to place p 6 of the presented Petri net. This module calculates angle α O of the load voltages space vector, based on the values generated by the blocks Re and Im from the previous step. Similarly, the second component computes angle β i of the source currents space vector. Listing I shows the sample Verilog code of the block Angle computation. The same module is used in order to compute α O and β i , however different input values are delivered for particular instances. The main part of the module is for calculation of the real and imaginary parts of the space vector (both components are instantiated within the code). Furthermore, additional conversions between natural binary code and the 1QN system (used by Xilinx CORDIC) is performed. Note that those operations are executed by sub-components prepared in a pure Verilog language.
C. SECTOR COMPUTATION OF THE SPACE VECTORS (TWO MODULES)
There are two instances of this component. The first one (denoted as Sector S O computation in Fig. 7 ) computes sector S O of the space vector for load voltages. This instance corresponds to place p 8 of the Petri net. The result is obtained on the value of the angle α O . Furthermore, the second instance (SectorS i computation, place p 9 of the net) computes sector S i for source currents, based on the angle β i .
D. ANGLE NORMALIZATION (TWO MODULES)
Two modules are designed in order to normalize the angles to the range − π 6 , π 6 . The first one, Angle α O normalization, refers to the place p 10 of the net and it scales the angle for voltages. The second component, Angle β i normalization corresponds to place p 11 and it adjusts the angle for currents. Both modules are prepared as a combinational logic. The resulting (normalized) angle is computed according to the angle α O (for load voltages) or β i (for source currents), depending on the current sector of the space vectors (S O or S i , respectively).
E. DUTY COMPUTATION AND ORGANIZATION (CONSISTS OF FOUR MODULES)
There are four modules that are in response of the computation of the modulation duty cycles of switches. Those components refer to places p 12 , . . . , p 15 of the Petri net from (6)- (9) . All four components are shown on the diagram (Fig. 7) . Since there are several input signals to those modules, they are grouped into the top-module, called Duty computation and organization order, to increase the visibility of the schema. Furthermore, each module is synchronous, and it applies clock signal. The external frequency divisor (denoted as clk div duty) is applied in order to adjust the adequate sequence period. Therefore, the switching time can be set depending on the user needs.
Listing II shows the sample Verilog code of the top-module Duty computation and organization. Particular values of duty cycles (denoted as d1,. . . , d4) are computed with the use of trigonometric function (namely, cosine function is calculated). To obtain the results, the CORDIC module is applied once more. Additional sub-components (Multiply_Three_1QN) are used in order to perform basic mathematical operations (they are written in a pure Verilog code).
F. SWITCH COMPUTATION (ONE MODULE)
This module corresponds to the place p 16 sets the adequate switch configuration by generation of the nine PWM signals (S aA , . . . , S cC ). Those values are computed according to Table 2 ''zero'' configurations (bottom line of the listing), depending on the relative switching times. This operation is also performed by a combinational logic (simple multiplexer).
G. FOUR-STEP COMMUTATION (THREE MODULES)
Finally, the output signals of the system are produced by three components that perform four-step commutation. Each module is dedicated for each output line (a, b, c) and they refer to the places p 17 , p 18 , and p 19 of the Petri net. The four-step commutation strategy is implemented as a finitestate machine. The switching sequence is executed in four main steps. It is possible to parameterize the commutation time according to the user needs. Moreover, the applied commutation technique assures proper switching in the case of high frequency of input signals. In particular, the operation is immediately terminated if changes to the input signals are detected.
VI. ANALYTICAL, NUMERICAL AND HARDWARE VERIFICATION OF THE SYSTEM
The proposed method has been verified analytically, numerically and experimentally. Initially, the specification of the system was analyzed and verified. Next, the numerical validation of the proposed method was performed. Finally, the system was implemented in an FPGA device. Let us discuss the above procedures in more detail with a brief summarization regarding limitations and scope of the presented technique.
A. VERIFICATION AND ANALYSIS OF THE SPECIFICATION OF THE PROPOSED SYSTEM
The Petri-net based specification of the proposed system has been verified and analyzed with the application of the set of dedicated tools that are available on-line at: http://gres.uninova.pt (the IOPT-Tools developed at Universidade Nova de Lisboa [39] , [44] ) and http://www.hippo.iee.uz.zgora.pl (Hippo system developed at University of Zielona Góra). In particular, the main properties of the net have been checked such as: liveness, safeness, number of states (markings), classification, number of the minimal SMCs that cover the net, etc. The complete results of the analysis are shown in Table 5 . The net has been added to the Hippo system and it is available on-line at: http:// www.hippo.iie.uz.zgora.pl/index.php?id=petri_net&nr=482
Results of analysis of the Petri net that specifies the proposed hardware system (from Fig. 3 ).
From the above results, it can be noticed that the Petri net is live and safe. Those two properties are crucial regarding further design of the hardware system. Loosely speaking, the prototyped Petri net is free of any deadlocks and unreachable states (redundancy). It means that from the formal point of view the system is properly specified.
Furthermore, the detailed analysis indicates that the net is classified as a Marked Graph. Such information can be useful in case of further optimizations and additional analyses, since this particular class of Petri nets has unique properties (please refer to [41] , [54] - [57] , and [61] -[70] for more details). Moreover, there are 20 reachable markings (states) in the net, while the total number of place invariants in the net is equal to 48. All of those invariants correspond to the state machine components of the Petri net, thus there are 48 SMCs in the specified system. Finally, the net is SM-coverable. It means that there is a possibility of further decomposition (splitting) of the system into sequential components. This operation is especially useful in the case of application of sequential devices (such as programmable logic controllers, PLCs) or dynamic partial reconfiguration of the system implemented in FPGA (please refer to [18] for more details).
To summarize the above discussion, it should be pointed out that analysis of the Petri net shows that the net has been properly designed. It is live and safe. Furthermore, it is possible to apply further optimizations of the net (such as decomposition into SM-components) in order to split the system into sequential components, or to apply the idea of dynamic partial reconfiguration [18] , [41] .
B. NUMERICAL VERIFICATION OF THE PROPOSED HARDWARE SYSTEM
The correct operation of the control systems of complex power converters before the final verification in the experimental prototype should be checked by numerical experiment. Therefore, the numerical validation of the algorithm was carried out using the Matlab Simulink program. A testing procedure is presented in Fig. 8 . The control signals generated in the Active-HDL simulator (Aldec Inc.) were stored in a text file as a sequence of samples with a sampling frequency of 10 MHz. Then the saved results were loaded into the Matlab Simulink program. The numerical verification of the correctness of the algorithm is shown in Fig. 9 , where the time waveforms of source and load currents and MC output line-to-line voltage u ab are depicted. The correctness of the implemented SVM algorithm and four-stage commutation has been tested. Because these algorithms are a constant element for various MC applications, their correct verification for a typical load gives information that possible errors in operation will be associated with incorrect implementation of the main program control in a given application. 
C. HARDWARE VERIFICATION OF THE SYSTEM WITH FPGA DEVICE
Finally, the proposed hardware system has been verified with the application of the real FPGA. In particular, the XC7A100T device from Xilinx has been used (Artix-7 family, Nexys 4 DDR board). To perform such a task, the following values were set:
• the input clock signal (clk) frequency was set to 100 MHz (it applies the internal oscillator of the FPGA),
• the modulation sequence period was set to 100 kHz (T Seq = 10µs),
• the commutation switch period was set to 0.2 µs.
• the value of the parameter φ i was assumed as a constant (φ i = 0). The whole system was described with the Verilog language, as mentioned in Section 5. Furthermore, it was logically synthesized and implemented in order to program the FPGA device (Vivado ver. 2017.2 was applied). The utilization of the resources was as follows:
• the number of utilized Look-Up Tables (Luts): 4830 (which is below 8% of the device), • the number of utilized Flip-Flop registers: 4304 (below 4% of the device),
• the number of built-in digital signal processing (DSP) blocks: 16 (below 7% of the device).
The above results can be summarized thus, that the utilization of the hardware resources is relatively very low (below 8%). This means that the FPGA can be additionally used for other modules or components, such as analog-to-digital converters, etc.
In order to verify the functionality of the implemented system, the outputs of the FPGA were connected to the oscilloscope (Tektronix MSO 2024). Fig. 10 shows the experimental results of control signals for output phase ''a''. In the presented oscillogram, the control signals of the switches S aA , S aB , S aC after SVM process, as well as the individual transistors T aA1 , T aA2 , T aB1 , T aB2 , T aC1 , T aC2 , after the commutation strategy and the signal of the direction of the output current sign(i a ) are presented. As can be seen, different switching sequences occur for opposite directions of the load current flow. For the negative current direction, the S aB is switch-on and the S aA is switch-off. The transistor switching sequence is as follows: T aA1 → OFF, T aB2 → ON, T aA2 → OFF, T aB1 → ON. For the positive current direction, the SaC is in the switch-on position and the S aB , in the switch-off position. The transistor switching sequence is as follows: The switching time of the next transistors for both current directions is 0.2 µs. Both presented switching sequences correspond to the general switching pattern depicted in Fig. 4 . The verified program code can be further tested in the real prototype, which will be the subject of further work.
VII. CONCLUSIONS
The novel design method of cyber-physical systems aimed at controlling power converter modulation and commutation processes has been proposed in the paper. The presented technique is based on the Petri net theory, which naturally reflects the concurrency relations in the system. Furthermore, the design can be easily analyzed with the set of existing methods and tools in order to verify whether the system is specified properly. Contrary to similar approaches, the presented solution does not involve any specialized external tools, nor additional conversions. Moreover, the algorithm greatly utilizes the concurrency properties of digital devices (especially FPGA).
On the other side, the proposed solution also has several limitations. First of all, the proposed specification of the cyber-physical system relies on a Petri net theory. This can be considered a great benefit (concurrency, verification and analysis of the specification), but on the other hand such a specification requires specialized knowledge from the designer. Fortunately, there exist computer-aided tools that permit user-friendly specification of the design by a Petri net (for example in a graphical way), and additionally offer an automated (or semi-automated) prototyping process (including verification, analysis, decomposition of the system). Moreover, the proposed hardware implementation of a cyber-physical system is written in a pure Verilog-HDL. This means that any changes to the design require knowledge of this hardware language. On the other side, neither external converters nor advanced tools are required in order to specify, design and implement the cyber-physical system.
Plans for future research include enhancement of the proposed technique. It is planned to optimize the computation tasks in order to increase the switching frequency. Furthermore, other variants of cyber-physical systems specified by Petri nets are going to be designed and verified. Moreover, it is also planned to apply the decomposition methods and to check the possible effects of the dynamic partial reconfiguration of the system. Finally, other forms of analysis, verification and validation techniques (e.g., model checking or methods based on perfect graphs and c-exact hypergraphs) are going to be utilized.
[70] M. Naybour, R. Remenyte-Prescott, and M. J. Boyd, ''Reliability and efficiency evaluation of a community pharmacy dispensing process using a coloured Petri-net approach,'' Rel. He is a member of the research project Hippo. His research interests include Petri nets and modeling, analysis, and decomposition of concurrent systems.
