1. Introduction and Problem Formulation
Petri nets, a versatile and powerful formal modeling tool, have been instrumental in advancing the design process of control and complex systems [
1]. Originally introduced by Carl Adam Petri in 1962, Petri nets provide an intuitive graphical representation for describing and analyzing the dynamics of concurrent systems [
2]. Over the years, Petri nets have found widespread applications in various domains, including computer science [
3], manufacturing [
4,
5,
6], biology [
7], and cyber-physical systems [
8]. Recently, the Petri net-based modeling approach has become especially popular in the modeling of real-life industrial systems (e.g., they are applied by manufacturing companies) [
9,
10,
11].
The main advantage of Petri nets lies in their simplicity and graphical formal representation, which can be constructed relatively very easily. In addition, a Petri net can also be considered as a mathematical modeling framework that reflects the behavior of systems through the directed bipartite graph. Such a graph consists of places and transitions that are connected by directed arcs [
12]. A place is active (marked) if it contains a token. Places that are marked at the same time represent states (markings). Furthermore, transitions reflect actions in a system. In particular, a transition may fire, by removing tokens from all its input places and relocating them to all its output places. Consequently, such an action changes the state in the system [
13]. Furthermore, tokens may be used to model resources of the system elements [
14] or indicate a logical behavior of the system [
13,
15]. Finally, Petri nets are heavily supported by formal analysis techniques [
1,
16,
17,
18]. There exist methods that allow for verification (sometimes even validation) of the system at the early specification stage. Such a combination of graphical and mathematical approaches makes Petri nets an intuitive and comfortable tool for the modeling, analysis, and verification of systems that strongly utilize concurrency [
19,
20]. 
Moving on to the concurrency aspects, it should be emphasized that Petri nets reflect such a relation by their nature [
21]. In particular, one or more places can be marked at the same time. It means that operations associated with those places are executed concurrently. This makes Petri nets applicable in many areas of human life, especially including industry applications [
22]. For example, they can be found in modern industries, such as resilient manufacturing, where 3D printing techniques are applied [
23]. It should also be noted that Petri nets provide a robust means of modeling the intricate interactions and dependencies in such systems, allowing for a detailed examination of their behavior [
24].
On the other hand, the modeled concurrent system ought to be carefully examined against possible errors and designer mistakes. Systems that involve concurrency are exposed to serious risks, including deadlocks or an infinite number of states (if wrongly designed). There are two fundamental properties of Petri nets that are related to the above mentioned problems: liveness and boundedness [
25]. The first one, liveness, guarantees that a system can reach any desirable state under certain conditions (formally after a final firing sequence), ensuring that the system remains responsive and operational at all times [
26]. Furthermore, boundedness implies that the number of tokens in a Petri net does not exceed predefined limits in each place, preventing uncontrolled behavior or resource depletion [
27]. An unbounded Petri net with those specification assumptions could lead to uncontrolled behavior [
28]. Such a condition can be defined more strictly. There exist Petri net systems that are required to be 1-bounded (safe) [
29]. This means that in each place, in any state, there can be at most only one token. This restriction is especially useful in the case of binary control systems, where safeness assures the accurate logical behavior of the system [
30,
31]. 
Let us move on to the interpreted Petri nets. Such a class is an extension of the ordinary Petri nets; however, they additionally contain input and output signals that permit communication with the environment [
6,
13,
32]. These extensions can capture real-world phenomena, such as reading from sensors or activating tasks [
33]. Input (logical) signals are associated with transitions while outputs are assigned to places [
11]. In the interpreted Petri net, a transition must additionally fulfil a logical equation of its input signals to be fired. This is an extended rule of an ordinary Petri net, where the firing of a transition requires a token at all input places only. However, this rule can be considered as a great advantage of interpreted Petri nets, since input signals may be used to resolve conflicts in non-free choice nets [
13]. In short, a conflict in a Petri net corresponds to a non-deterministic situation, where two or more transitions may be fired. Therefore, such input signals may resolve conflicts very easily and comfortably. Finally, output signals are associated with places. Usually, they represent operations executed by the Petri net-based system. Sometimes, such signals can also trigger (activate) associated tasks especially in management systems [
5]. In conclusion, it should be noted that interpreted Petri nets are live and bounded (or safe) by their definition. This is a huge advantage of this class, since the described system is assured to be absent of deadlocks and to have a finite number of states. On the other hand, such an excessive demand requires a solid examination of the system at the early prototyping stage. 
Finally, let us briefly introduce Field-Programmable Gate Arrays (FPGAs) and relate them to Petri nets. In general, an FPGA is a hardware device that can be reprogrammed in order to perform specific logic operations. A typical FPGA consists of logical blocks whose core is a 
look-up table (LUT) [
34]. LUTs are in charge of the realization of combinational logic (usually up to 5–6 variables). Furthermore, FPGAs include flip-flops to perform sequential operations. Due to their flexibility, and high performance, FPGAs have found applications in a multitude of industries, including aerospace, automotive, and telecommunications [
35,
36]. It is worth noting that advanced FPGA platforms allow for dynamic partial reconfiguration [
37,
38,
39]. This allows for changing the behavior of a part of the system without turning off the device. Thus, it has found application in special critical fields such as Mars missions [
40]. Leveraging Petri nets to model control systems, especially when targeting FPGA implementation is beneficial also due to their concurrent nature [
41]. It should be underlined that both—Petri nets and FPGAs—are concurrent by nature. Contrary to the sequential systems, where particular operations are performed in sequence, concurrent systems allow for simultaneous operations at the same time. Therefore, FPGAs seem to be an excellent destination for the implementation of Petri-net based systems [
13,
42,
43]. 
In general, the implementation of the Petri net-based concurrent system within FPGA is a relatively easy process. The modeled system is transformed to the hardware description language (HDL), which is a base for further realization within the FPGA. In short, the functionality of particular places and transitions of a Petri net are translated into the set of equations that are written within the hardware language Verilog or VHDL (Very High Speed Integrated Circuit Hardware Description Language) [
44]. Going into detail, each place of a Petri net is assigned to one flip-flop in a sequential circuit [
13]. Thus, a set of flip-flops active at the same time reflect the current marking (state) of the system. Similarly, transitions are transformed into logical functions (combinational circuit) [
43]. Those functions stimulate flip-flops associated with places. Finally, output signals are directly assigned to the particular places [
13,
43]. The technique described above is effective (the translated system reflects the model) and relatively easy to perform (the transformation can be conducted automatically), thus it seems to be the most popular nowadays. However, there is an important drawback that refers to the relatively high utilization of hardware resources of an FPGA. As already mentioned, an FPGA consists of LUTs and flip-flops (FFs). Although a single LUT allows for the implementation of any logic function, it is limited to a relatively small number of variables (usually 5–6). This means that larger functions ought to be divided (decomposed) into subfunctions with a small number of variables [
45,
46,
47,
48]. Obviously, such a decomposition heavily influences the number of logic blocks used to implement the modeled system. Therefore, the final implementation of the Petri net-based design may drastically increase. Let us now briefly overview the most popular logical function decomposition techniques of systems implemented within an FPGA. 
The first decomposition algorithms were developed in the 1990s and they were initially oriented on the optimization of the gate structures (with further adoption to FPGAs). These methods include the 
MIS-PGA, 
ASYL, 
Chortle, and 
Xmap algorithms. Their essence was to optimize the multi-level implementation of logical functions. Later, as a result of the development of decomposition methods, tools such as 
Demain [
49], 
FGsyn [
50], and 
Decomp [
51] were developed. Those techniques are based on the classical decomposition model [
52], and they provide efficient solutions (in terms of the number of logic blocks or the number of layers), but their main drawback is high computational complexity. Therefore, the optimization possibilities of complex circuits were highly limited, since the long synthesis time made them difficult to use in practical approaches. In the 2000s, plenty of academic tools appeared, together with the representation of logic functions in the form of And-Inverter Graphs (AIGs). Such a graph can be found, for example, in the 
ABC [
53] and 
DAOmap [
54] systems. Meanwhile, the re-synthesis techniques were developed [
55,
56], benefiting systems such as the Delay-Driven BDD (
DDBDD) [
57] and BDS-PGA 2.0 [
58], which use Binary Decision Diagrams (BDDs) to represent logical functions. Furthermore, development of technology and the expansion of logic blocks in the programmable circuits resulted in the appearance of tools that permit the configuration of logic blocks, e.g., 
ALMmap [
59]. 
Getting back to the current times, there is no doubt about the importance of decomposition in logical synthesis. Such a process is a subject of extensive research in the context of synthesis dedicated to FPGAs and Programmable Array Logic (PAL)-based systems [
60]. Decomposition is also used in the synthesis process oriented to Complex Programmable Logic Devices (CPLDs) [
61,
62,
63]. In logical synthesis algorithms, the way in which a logical function is represented is especially important. Functions can be represented in the form of a table description [
52], cube description, and graph description. Nevertheless, methods that utilize BDDs [
57,
64] are of great interest. The achievements of Ashenhurst and Curtis laid the foundations for subsequent types of decomposition, but memory-inefficient decomposition tables (
Karnaugh tables) were used to represent the logical functions. Looking from the terms of memory consumption, a much better solution is the BDD representation [
57,
58,
65]. The description of logical functions in the form of BDD leads to the significant reduction in computer memory and better speed performance of operations on these functions. Moreover, a dozen standard libraries for manipulating BDDs are available. To be precise, the reduced and ordered form of BDD (ROBDD) is used. These advantages have led to the development of tools such as BDS or DDBDD and MultiDec [
66] that lead to effective solutions. Good solutions are also provided by mentioned tools such as DAOmap or ABC [
67], which use AIGs. The newest academic synthesis tools of industry-standard strength are coupled with HDL compilers [
67,
68,
69]. The latest algorithms also combine the advantages of AIG manipulation [
69] and the representation of functions in the form of BDD [
70]. There are also many approaches to the use of BDD that allow for multiple output functions to be represented. The most popular forms of describing multi-output functions are shared BDD (SBDD) and multi-terminal binary decision diagram (MTBDD) [
71]. In conclusion, it should be pointed out that there exist plenty of decomposition methods, aimed at various goals to be achieved. One of them is the minimization of the number of blocks [
45,
46,
47,
71,
72], while others are focused on the optimization of the number of logical layers [
66,
73] or the reduction in the dissipated power [
74,
75,
76,
77]. Moreover, proper optimization strategies may target both combinational and sequential circuits [
78,
79]. Finally, the most important aspect lies in the adequate division of the system and effective decomposition of logic functions in order to reduce the number of utilized logic blocks (LUTs and FFs) of an FPGA.
To summarize the discussion above, the following research gaps can be noticed in the design and optimization of a Petri net-based concurrent control system oriented toward implementation within FPGA devices. Firstly, as designs become complex, using adequate effective modeling techniques becomes extremely important. The method proposed in this paper involves Petri nets, which are intuitive and comfortable modeling tools, joining the graphical and mathematical representation of the system. Another serious bottleneck in the design of concurrent control systems refers to the scalability of the concurrent systems. Therefore, this paper focuses on the reduction of logic resources to ensure efficient FPGA utilization. Such an optimization involves effective decomposition techniques which are crucial in the proposed techniques. In conclusion, in this work, a novel technique oriented toward the adequate modeling and design optimization of the Petri net-based concurrent control system is proposed. The main aim of the presented method is to reduce the number of utilized logic blocks (LUTs and flip-flops) of the destination FPGA device. 
The main contributions are summarized as follows:
- Proposition of a novel design technique of a Petri net-based concurrent control system oriented toward the reduction in the resources (logic blocks) of an FPGA. The presented prototyping flow applies an interpreted Petri net, and additionally permits conflict resolution in the modeled system; 
- Proposition of a novel optimization technique of the Petri net-based design. The method includes both the functional decomposition of the combinational part of the system and the optimization of the sequential part of the system; 
- Proposition of a photovoltaic control system as a case study of the presented prototyping flow. The applied system reflects the real-life concurrent control system further optimized and implemented within the FPGA device. 
- Experimental verification of the proposed technique and comparison to the existing functional decomposition methods from the literature. 
  3. Case Study: Design and Implementation of the Photovoltaic Control System
The modeling and design technique proposed in this paper is explained by a real-life case study example. 
Figure 8 shows the concept of a smart photovoltaic control system. The main aim of the presented concurrent system is to control the solar panels depending on their temperature and current power production in order to prevent the overloading of the electricity grid. As photovoltaic systems become more popular nowadays, the risk of grid overloading increases [
90,
91]. Therefore, the presented concurrent control system permits the control of the production and allows for the reduction in the production by the dynamical switching on/off of particular solar cells.
In the realm of renewable energy, smart photovoltaic (PV) control systems represent a significant leap forward in managing and optimizing energy production. However, the current landscape of these systems is characterized by a reliance on traditional control methodologies that are often rigid and unable to capitalize on the dynamic nature of solar energy fully. These conventional systems are limited by their rule-based algorithms which cannot adequately handle the variability and unpredictability inherent in solar irradiance and weather conditions. As a result, a substantial gap exists between the potential and actual performance of PV systems, leading to inefficiencies and energy losses [
92]. The proposed hybrid approach seeks to bridge this gap by introducing a sophisticated layer of machine learning algorithms that can learn from data, predict future conditions, and make intelligent decisions in real time [
92]. This approach is inspired by recent advancements in subsurface engineering environments, where intelligent decision-making strategies have been successfully applied to predict fire intensity and rockburst events. By adopting similar machine learning techniques, such as t-SNE for dimensionality reduction, K-Means Clustering for pattern recognition, and XGBoost for predictive modeling, the hybrid system aims to overcome the limitations of existing PV control methodologies [
93]. This integration of machine learning not only enhances the adaptability and efficiency of the control system but also paves the way for a more resilient and responsive energy grid. Thus, the novelty of the hybrid approach lies in its potential to transform the smart PV control landscape, offering a solution that is both innovative and imperative for the advancement of sustainable energy systems [
94].
Going into the details of the proposed photovoltaic system, each panel of the presented photovoltaic system is composed of eight solar cells (modules), denoted by  . Furthermore, each module contains built-in sensors that allow for the measurement of its temperature and current power production. The measured data are sent to the operational center. Depending on the needs, the operational center dynamically configures the system by adjusting the number of enabled solar cells. The system works as follows. Firstly, the system examines whether the particular solar cell is enabled or disabled. The measurement is performed only for the enabled modules. If such a condition is fulfilled, the current temperature and power production are read from the sensors. The obtained data are analyzed by the modeled concurrent control system according to the over-high temperature and overload of the power. Finally, the result is sent to the operational center, which makes a decision about switching on or off the particular panels to prevent the overloading of the electricity grid. To avoid improper measurements (e.g., in the case where the particular module is disabled), particular sensors are active only if the referred module is enabled. Let us formally specify the discussed smart photovoltaic system by an interpreted Petri net.
  3.1. Modeling of the Photovoltaic Control System
The Petri net-based model of the proposed photovoltaic control system is shown in 
Figure 9. The discussed Petri net consists of 109 places and 108 transitions.
Looking from the general point of view, the presented model consists of eight block modules that strictly refer to the particular photovoltaic modules (solar cells). Since the whole specification is large, a single module (a part of the system) is shown in 
Figure 10.
The specification has been initially prepared in the 
IOPT-Tools v 1.2 software and further exported to the 
Hippo system [
19]. Note that the presented figures are directly taken from 
Hippo, and they show the general overview of the system (without input/output signals associated with places/transitions). 
Table 1 shows the associations between the input signals and transitions. Note that there are values for the first module presented, while the associations for the remaining modules are similar. For example, signal  
  (1st module is enabled) is assigned to the transition  
, etc.
Similarly, output signals are associated with places of the interpreted Petri net. There are 12 outputs in total grouped into three 4-bit vectors, as shown in 
Table 2. The outputs contain the values determined by the system (status of the system): the number of enabled (working) modules, the number of panels with correct power (e.g., within the assumed ranges), and the number of panels with the correct temperature.
Once the system was modeled within IOPT-Tools, it was verified and validated. The validation was conducted within IOPT-Tools by simulating the behavior of the system. However, IOPT-Tools was not able to perform the verification of the system due to the state explosion problem. Moreover, the application of another popular tool PIPE [
84] was also not successful. Therefore, the modeled system was converted to the Hippo system and analyzed with the use of the authors’ methods and techniques (see [
20,
23,
88] for more details). The verification was successful, and the system was ready for further steps of the proposed prototyping flow.
  3.2. Transformation of the Petri Net-Based Description into Verilog HDL Code
The transformation of the modeled photovoltaic system to the Verilog code was performed strictly according to the rules presented in 
Section 2.2. Listing 4 shows the declaration of the main module and input/output signals of the system.
		
| Listing 4. Declaration of the module of the photovoltaic system. | 
| ![Applsci 14 05212 i004]() | 
There are 12 registered outputs that strictly refer to the output signals described in the previous section. Moreover, there are 26 input signals in total, and 24 of them correspond to the input signals associated with photovoltaic modules, while the 2 remaining refer to the clock and reset signals. Listing 5 shows the sample equations for transitions and places. According to the rules described in 
Section 2.2, transitions are declared as wires and utilize continuous assignments, while places are declared as registers and involve procedural assignments. Since the system is synchronous, the states (markings) are changed with the rising edge of the clock signal. Furthermore, the asynchronous reset signal zeroes the system by returning to the initial marking. It can be noticed that there are equations that include six input variables and more. For example, the equation for transition 
t2 (line 04) involves eight input signals (logical conjunction of eight variables). According to the discussion shown in 
Section 3.3, such equations can be a good basis for the functional decomposition and reduction in the FPGA resources. However, in the presented photovoltaic system, other equations are going to be optimized.
        
| Listing 5. Equations for transitions and places. | 
| ![Applsci 14 05212 i005]() | 
Listing 6 presents sample equations for the outputs. The particular values (
status_e, 
status_p, and 
status_t) are computed based on the current status of sensors. The computation is performed by combinational logic. Each of the resulting equations is formulated by the disjunctive normal form (DNF) as a sum of products (minterms). Let us underline that equations for the three lower bits of each output (that is, 
status_e[0], 
status_e[1], 
status_e[2], 
status_p[0], 
status_p[1], 
status_p[2], and 
status_t[0], 
status_t[1], 
status_t[2]) include multiple products (even over one hundred). Therefore, the code shown in Listing 6 presents the sample values (products). The complete equations for the output 
status_e can be found in 
Appendix A (the remaining two outputs 
status_p and 
status_t are computed in a similar way). Obviously, such a huge number of minterms can be an excellent object for further optimization. The next subsection presents the functional decomposition of the discussed photovoltaic system.
       
| Listing 6. Equations for outputs. | 
| ![Applsci 14 05212 i006]() | 
  3.3. Optimization of the Photovoltaic Control System
According to the proposed prototyping flow, both the sequential and combinational parts of the concurrent control system are the subject of optimization. Firstly, the redundant expressions and possible number of flip-flops are minimized and reduced. The minimization process is presented for the registers representing places  
,  
, and  
. The original equations that describe the concurrent control system are as follows:
		However, inserting  
  into the equation of  
 we obtain the following:
		Furthermore, the original equations are the following:
		Inserting  
  and  
  into  
, we obtain the following:
		Finally, the original equations of  
  are the following:
		Inserting  
  and  
  into  
, we obtain the following:
As it is shown, places  ,  , and    can be merged and replaced by the single flip-flop. The final result is achieved by algebraic transformations. However, the algorithm applies BDDs, where the function representation is canonical, and the equivalence of the presented flip-flops can be immediately checked.
Moving on to the optimization of the combinational part, we will follow the 
status_e signals, while the complete description of the whole system is presented in 
Appendix A (Listings A1–A4). Firstly, the logical equation is decomposed according to the procedure shown in 
Section 2.3 and combined with finding common subfunctions. The resulting description is shown in Listing 7. There are bound functions 
g0, …, 
g5 which are arguments of the logic function 
status_e[0], …, 
status_e[3]. Let us underline that the number of arguments of each decomposed function does not exceed 5. This means that they can be implemented in the single LUT 5 (a five-input LUT) blocks.
Figure 11 shows a schematic of the decomposed functions. Note that functions 
g2, ..., 
g5 are used only once, which means that their outputs are connected only to one input of another LUT. However, 
g0 and 
g1 functions are arguments of several other functions. This means that they are shared among the other functions. Such sharing is essential in the decomposition process and may lead to the significant reduction in the utilized FPGA resources.
 | Listing 7. Equation for output after decomposition. | 
| ![Applsci 14 05212 i007]() | 
  3.4. Realization of the Photovoltaic System within FPGA
Finally, the designed photovoltaic Petri net-based system is implemented within the FPGA. As a destination, the XC7A100T device from the Artix-7 family is selected. The implementation process is performed within the dedicated Xilinx tool, Vivado ver. 2023.1.
To perform the final implementation, the system ought to be firstly logically synthesized. This process is executed within the Vivado 2023.1 tool, exactly according to the Xilinx requirements [
95]. Logical synthesis returns no errors, which confirms the proper description of the system in the Verilog hardware description language. At the next step, the logical implementation is executed. As shown in 
Figure 12, this process does not return errors in the designed photovoltaic system, as well. This means that the designed system is properly prepared in accordance with the device structure and can be physically implemented within the selected FPGA.
However, in order to validate the functionality before the physical implementation, the designed system is simulated within the Vivado environment. 
Figure 13 shows the results of validation. Based on the stimulated input signals, adequate output signals are obtained. Let us underline that the achieved results confirm the assumptions and thus the proper functionality of the photovoltaic system. Let us now evaluate the proposed optimization technique by the analysis of the utilization of the FPGA resources.
Finally, the system is physically implemented and validated within the real FPGA device. To perform this, the Nexys4 DDR prototyping board was used. The presented concurrent control system was implemented with XC7A100T FPGA. This board contains switches and a 7-segment display, that are used to stimulate remaining input and output values, respectively. Due to the limited number of switches, there is a possibility of controlling the first five panels (it is just assumed that the remaining three are working properly). Additionally, the seven-segment display is used to indicate the number of panels successfully powered on, with correct power and optimal temperature. The count of panels with proper power or temperature is visible on the display after pressing the corresponding momentary button.
Figure 14 shows the experimental setup of the discussed system. Note that the presented figure corresponds to the results of simulation shown in 
Figure 13. At the illustrated state (marking) of the system, six panels are enabled (which is signalized by the seven-segment display). Indeed, two panels are turned off since switches that correspond to signals  
  and  
  are in a low state.
   5. Conclusions
A novel design approach of a Petri net-based concurrent control system is proposed in this paper. The method is oriented toward effective realization of the system in an FPGA device. To achieve this, the system is optimized by authors’ techniques. In particular, the sequential and combinational parts of the system are reduced and optimized. The proposed design flow includes all the necessary steps that are required to implement the concurrent control system within the programmable device. Firstly, the system is modeled by an interpreted Petri net, which is transformed into the Verilog hardware description language. The optimization of the design is performed by reducing the redundant sequential logic and further functional decomposition. Finally, the system is implemented within an FPGA.
The efficiency of the proposed technique was verified experimentally. To perform this, a real-life example of a photovoltaic concurrent control system was designed and optimized. The obtained results indicate a high reduction in the number of utilized logic blocks compared to the traditional solutions. A photovoltaic system designed and optimized with the presented method requires 91 LUTs and 114 flip-flops, while the classical approach utilized 126 LUTs and 114 FFs. This means that the number of LUTs was decreased by 28%, which is a very good result. It should be underlined that thanks to the introduced sequential reduction in the system, the number of logic blocks significantly decreased, while the number of flip-flops remained unchanged.
Although the experimental results confirm the high efficiency of the proposed technique, there are also limitations of the presented method. First of all, the introduced sequential optimization idea can be applied only to the systems operating in a single-clock domain. This means that all registers of the design ought to be oscillated by the same clock. Nevertheless, let us point out that such a situation is usual in the case of FPGA-oriented systems. Furthermore, the presented method involves Petri net theory. Although the modeling of the system with Petri net is relatively easy and comfortable, it requires specific knowledge from the designer, especially in terms of concurrent systems oriented toward implementation within FPGA devices. Finally, the proposed method assumes the transformation of the system to the Verilog code and further optimization of the sequential and combinational parts. At this moment, the above mechanisms are semi-automated. There exists the transformation of the Petri net-based system to the Verilog code (within the authors’ Hippo system), but it ought to be supplemented by adequate input and output signals. Similarly, there is a tool for functional decomposition, PdekBDD (developed by the authors). Nevertheless, the authors of this paper plan to extend their tools, especially with such optimistic experimental results.
Plans for the future include further development of the proposed idea. In particular, it is planned to apply the verification of the system at the early prototyping stage. Such an examination may help avoid mistakes caused by the designer that are usually detected during the synthesis process. Furthermore, the presented photovoltaic system is going to be extended to the farms of panels. As shown by the preliminary research results, the traditional realization permits the implementation of 503 controllers of solar panels, while the presented technique allows for the realization of 696 cells within the single FPGA. Therefore, it is planned to perform more complex research in order to confirm such a high efficiency of the proposed technique.