The paper presents a new two-step approach to FSM synthesis for PAL-based CPLDs that strives to find an optimum fit of an FSM to the structure of the CPLD. The first step, the original state assignment method, includes techniques of twolevel minimization and aims at area minimization. The second step, PAL-oriented multi-level optimization, is a search for implicants that can be shared by several functions. It is based on the graph of outputs. Results of experiments prove that the presented approach is especially effective for PAL-based CPLD structures containing a low number of product terms.
Introduction
Most CPLDs (Complex Programmable Logic Devices) have architectures consisting of a PAL-like AND-OR structure and multi-level logic capability combined with an integrated array of logic and I/O macrocells. Whereas each CPLD has an original internal structure, its kernel is in most cases formed by a PAL-based structure (Sharma, 1998) . PAL-based logic blocks usually have a strictly defined number of terms connected to the individual output macrocells. This feature of a PAL based block significantly affects the synthesis process of digital circuits based on such devices. The essence of CPLDoriented synthesis of FSMs (Finite State Machines) using PAL-based devices is the implementation of the logic function using logic blocks including k terms (Fig. 1) .
One of the most important stages of the FSM design flow is state assignment. There are many methods of state assignment. Some are considered optimal (Sentovich et al., 1992; Villa and Sangiovanni-Vincentelli, 1990 ). The state assignment problem is often solved together with input and output encoding (Yang and Ciesielski, 1991) . Some methods are based on dichotomies (Villa and Sangiovanni-Vincentelli, 1990) or dominance graphs (Devadas and Newton, 1991) . Sometimes the problem is solved using genetic algorithms (Chyży and Kłosiński, 2002) . There are also many aims of finite state machine synthesis, like reducing power consumption of automata (Mengibar et al., 2005; Chattopadhyay, 2001) or synthesis for testability (Park et al., 2000) . Sometimes, the main idea of logic synthesis is based on functional (Jóźwiak and Volf, 1995) or structural decomposition of FSMs (Barkalov et al., 2007) . These methods are composed for different structures of Mealy and Moore automata (Salauyou et al., 2006) . A vast majority of methods are dedicated for automata which are to be implemented in PLA-based devices (Baranov, 1994; Villa et al., 1997) . Some well-known methods like "one-hot" coding or binary coding, are still part of vendor tools, even though they give results far from optimum.
The aim of the proposed state assignment method is to minimize the number of PAL-based macrocells by fitting the FSM to the structure of the CPLD in the best possible way (Czerwiński and Kania, 2005; Czerwiński, 2006; Czerwiński et al., 2006) . The elements of two-level minimization are included in the state assignment process. Primary and secondary merging conditions, and the implicants distribution table are introduced in the paper. In the final stage, the procedure of code exchange is carried out in order to aid multi-level optimization (Kania, 2003) . This paper is structured as follows: Section 2 introduces some basic information about state assignment and multi-level optimization. Section 3 focuses on the synthesis of FSMs for PAL-based CPLDs. Experimental results are reported in Section 4. The paper closes with conclusions in Section 5.
Basic definitions
The mathematical model of a sequential circuit is a finite state machine, which is represented by a quintuple, {X, Y, S, δ, λ}, where X is a finite input alphabet, Y is a finite output alphabet, S is a finite set of states, δ is the transition function, λ is the output function. The transition function of an FSM determines the next state of the automata (S + ). Let the state weight η si be the number of transits to the state s i of the machine-the number of occurrences as a next state in State Transition Table (STT) . Let the μ-range be the number of bits 1 in the code. The distance ν(A, B) between two minterms A and B is the number of bits they differ in. Let ν(S i , S j ) be the distance between codes of the states S i and S j .
Let f be a multi-output logic function f : B n → B m , where B = {0, 1}. The classical method of implementation of the function f : B n → B m within PAL-based structures is related to the implementation of the minimised functions f : B n → B 1 (i = 1, 2, . . . , m) by means of PAL-based logic blocks consisting of k-terms. Let the discriminant Δ fi be the number of those implicants, provided the function f : B n → B 1 constitutes true values (e.g., Δ δi is the number of implicants of the δ i function).
Let σ fi denote the number of logic blocks necessary for the implementation of the i-th function. In the case when f i > k, the implementation of the f i function by means of PAL-based logic blocks consisting of k-terms needs the realization of feedback loops. Therefore, the number of σ fi = (Δ fi − k)/(k − 1) + 1 PAL-based logic blocks consisting of k-terms will be used, where x denotes the lowest integer number, not less than x. For classical implementation of m-functions (every function has been minimized separately), the implementation of σ 1 f PAL-based logic blocks is necessary, where
Example 1. Let f 1 = bcd +ābc +ābc +bcd and f 0 =ābd + abd + bcd +bcd. Separate implementation of the f 1 and f 2 function requires four logic PAL-based blocks, which include three terms. However, another implementation is also possible. The implementation presented in Fig. 2 requires only three blocks.
The proposed PAL-based multi-level optimization allows a considerable reduction of the number of required logic blocks. The main idea of the method is based on searching for shared mutli-output implicants.
Synthesis of FSMs for PAL-based devices
The proposed logic synthesis process consists of two main procedures:
• PAL-oriented state assignment,
• PAL-oriented multi-level optimization.
An overview of the logic synthesis system is shown in Fig. 3. 
PAL-oriented state assignment.
A coded STT is a collection of multi-output implicants. The total number of implicants of the single function δ i or λ i equals the weight of states for which there is a 1 on i-th position. This brings to mind that codes with a minimal μ-range 
Synthesis of finite state machines for CPLDs

649
should be used to encode states. Moreover, states s j with greater weights η sj should be coded first of all, because those states occur more frequently as next. In that way, codes with the smallest number of a logic high occur more frequently. Of course, the state with the greatest weight is assigned the code with all bits logic low (μ = 0), so none of the single transition functions includes implicants corresponding to the state.
The number of terms may be reduced after two-level minimization. The main goal of state assignment should be to assign states to codes situated suitably to each other in the Boolean space, so some implicants could be merged after two-level minimization. This gets complicated in FSMs because the input parts of multi-output implicants are connected with the output part. The next state of one transition is the present state of another. Changing one bit of the state code involves changes in both the input and output part of the implicants.
On the other hand, elements of two-level minimization must be included in the state assignment process, in order to take advantage of the number of PAL-cell terms. Primary and secondary merging conditions enable to include elements of two-level minimization in the process of state assignment (Czerwiński and Kania, 2005; Czerwiński, 2006; Czerwiński et al., 2006) .
The Primary Merging Condition (PMC) {S p , S r } Si X for the transition function is a condition formed by two transitions from the states S p and S r to the state S i that corresponds to the same input X.
The primary merging condition {S p , S r } λi X for the output function is a condition formed by two transitions from the states S p and S r , for which the output function λ i is 1, that corresponds to the same input X.
The idea of state assignment is based on assigning to two states S p and S r of PMC binary codes that differ only in one position, ν(S p , S r ) = 1. A fragment of the state transition table with the PMC and the idea of state assignment is presented in Fig. 4 SMCs emerge during the process of state assignment. One step of the state encoding process with the mechanism of SMC arising is shown in Fig. 5 .
The basic difficulty in effective term use, when functions are to be implemented in PAL-based devices, is twolevel minimization. As a rule, it is carried out after the state assignment process, so the effects are unforeseen. The elements of two-level minimization or methods of counting the number of implicants (as the effect of the minimization process) have to be included in the process of state assignment. It is easy to search primary merging conditions, but secondary merging conditions appear only in the state assignment process and come from the distribution of implicants among the single functions.
The Implicants Distribution Algorithm mb (minimization of the number of blocks)
1. Calculate the number K of bits of codes: K = log 2 card(S) , where card(S) is the number of states (card(S) > 1), a is a minimum integer but not less than a.
2. Specify the PMCs of the transition function.
Assign the state with the greater weight η
Si with the zero code (μ = 0). If there is more than one state that satisfies the condition, choose the state S j which can satisfy most PMCs
4. μ := 1.
Choose the state with the largest weight η
Si . If there is more than one state that satisfies the condition, the sort key is as follows:
(a) choose the state S i which can satisfy more primary merging conditions {S i , S r } Sj X , (b) choose the state S i which can satisfy more non-excluding secondary merging conditions
6. If none of the μ-range codes is free, then μ := μ + 1.
7. Assign to the chosen state S i a free code μ-range. If there is more than one possibility, the sort key is as follows:
(a) PAL-cell incrementation is the smallest, (b) the sum of all Δ δi is the smallest.
(PAL-cell incrementation and the sum of all Δ δi are calculated after making allowance for every satisfied merging condition.)
8. Refresh the IDT.
9. Revise the secondary merging conditions.
10. Cancel the satisfied or excluded primary and secondary merging conditions.
11. If not all states have been encoded, then return to the point 5.
12. End. 11---1 3 10111000 00---1 2 11000000 10---1 4 00101000 0-0--2 2 11000000 --1--2 5 00001110 110--2 3 10111000 100--2 4 00101000 10---3 4 00111000 00---3 2 11010000 11---3 3 10111000 01---3 6 00110101 010--4 6 00100101 --1--4 7 00101000 110--4 3 10111000 000--4 2 11000000 100--4 4 00101000 1-10-5 8 10000100 --0--5 2 11000000 --11-5 8 10000100 0-10-5 5 00001110 ----1 6 2 11000001 10--0 6 4 00101001 00--0 6 2 11000001 11--0 6 3 10111001 01--0 6 6 00100101 --0--7 2 11000000 101--7 7 00101000 011--7 6 00100101 111--7 3 10111000 001--7 2 11000000 101--8 7 00101000 --0--8 2 11000000 0-1--8 8 10000100 111--8 3 10111000 Example 2. Consider the example of the automaton ex6 (MCNC, 1991) . The STT is given in Fig. 6 with weights of states and PMCs. The weight η 1 of the state 1 is the biggest, the state is assigned 000. Three rows of the part of the IDT presented in Fig. 7 (a) correspond to the numbers of implicants, which are equal to weights of the states. According to the IDT, the weights of states are written into the column δ i for which there is 1 on the i-th position of the code. The state 3 is assigned 001.
Synthesis of finite state machines for CPLDs
651
The continuation of state assignment is presented in Fig. 7 (b). The state 4 is assigned 010. The PMC {2, 4} 3 110−− and {2, 4} 4 100−− are fulfilled, so −1 is written into the ITD for the column corresponding to the function δ 0 and δ 1 .
Next, the state 6 is assigned 100 and the state 7 -011 (Fig. 7(c) ). It should be noticed that the states 3 and 7 have common logic high on the position corresponding to the function δ 0 . Because there are two transitions from the state 7 for the inputs 101 − − and 111 − − ({7} 3,7 δ0,101−−,111−− is fulfilled), Δ δ0 is also decremented. Encoding results in 26 implicants and implementation uses thirteen 3-AND cells (Fig. 7(d) ).
PAL-oriented multi-level optimization. Two basic stages of PAL-oriented multi-level optimization include
• exchange of codes,
• optimization based on the graph of outputs.
Exchange of codes.
The algorithm of the state assignment presented in section 3.1 is oriented on the PAL-cell minimization. Searching the shared multi-output implicants is ineffective. Exchange of codes can be carried out after the state assignment process to increase the effectiveness of the method based on the graph of output (Section 3.2.2).
First of all, the state S i with a weight exceeding one (η Si > 1) is searched. The state is assigned a code of the first range (μ = 1). Transition to the state is realized thanks to σ Si = (η Si − k)/(k − 1) logic cells. If there exists state S i , then state S j with greatest weight (max(η Sj ) and η Sj > 1) is searched. States S i and S j must have 1 on common position.
As a next step, an IDT is revised. The weight of state S i is changed to 1. The reason is the feedback from common block (shared multi-output implicants) to the interconnect matrix. Every merging condition in an IDT is revised. If after exchanging of codes the total number of logic cells is smaller than before exchanging, then the exchange is fixed. Of course to the number of logic cells after exchanging procedure is added σ Si . The procedure is repeated until there are unchecked states with assigned codes of the 1-range.
Algorithm ec (exchange of codes) 4. Exchange the codes if the realisation requires fewer logic cells than before exchanging.
5. If not all states have been checked, then go to 1.
6. End.
The procedure of exchanging codes is presented in the following example.
Example 3. On the left hand of Fig. 8 there is an IDT of the ex6 automata after state assignment presented in Fig. 7 the state 3 is chosen (as first in the exchange of codes procedure). The code of the state is 001 and the weight of the state is 7. A transition to the state requires three 3-AND cells (k = 3). As next, the state 7 is chosen. The states 3 and 7 have 1 in the common position (δ 0 -code 011) and the weight of the state 7 is greater than 1. The new weight of the state 3 is 1 because feedback from common block uses one term. A PMC {2, 4} (Fig. 9) . The number of PAL-based blocks, which are necessary for the implementation of the multi-output function, can be calculated based on values of the discriminants Δ m o . This number is equal to
and, for most cases, greater than σ 1 f . Nodes of the graph correspond to the number of multi-output implicants. For example, when a node of the μ-th range belongs to the graph and for that node Δ y = k, the implementation of the k implicants constituting common resources of the μ functions is possible within this one block. Selecting the node leads to the transformation of the graph and a corresponding reduction of the Δ m o coefficients (Fig. 10) . As a result, the selection of a certain node introduces feedback loops marked on the graph by means of the dashed line. The feedback loop is shown on the reduced graph in Fig. 10 after implementation of the fourth-range nodes.
Let i Δ y be the discriminants that correspond to the node which is chosen during the i-th step of the algorithm of multi-level optimization of the multi-output function. If then the implementation of the group of implicants which correspond to the selected node i Δ y may lead to the minimization of the number of the employed PAL-based blocks composed of k terms. The selection of the node i Δ y affects the μ(
After having the discriminants re-ordered in such a way that the selected node affects the consecutive i Δ μ( i Δy) j discriminants, the condition for the minimization of PAL-based logic blocks can be shown in the following form:
where
Let r μ( i Δy) j be number calculated from the congruence
where j = 1, 2, . . . , μ( i Δ y ). The essence of the theorem presented in (Kania, 2004) consists in the selection of nodes (multi-output implicants) that can be shared by several single-output functions. The theorem serves as a background to draw up an algorithm for multi-level optimization of multi-output functions for PAL-based logic blocks. As the number of logic blocks σ f is generally greater than the value of σ 1 f , the essence of the proposed algorithm focuses on analyzing the graph nodes and searching for nodes that are associated with possible large groups of common implicants.
Let us assume that the graph of outputs describes multi-output implicants that are accomplished by means of i σ f PAL-based logic blocks with k terms. Selection, at the i-th step of iteration, the i Δ y node of the graph implies the utilization of i γ = ( i Δ y − k)/(k − 1) + 1 PAL-based logic blocks. This leads to the reduction of the graph of outputs. The graph after the reduction describes the implicants that are covered by i+1 σ f PALbased logic blocks. The higher the value of the expression 1 σ f − ( i+1 σ f + i γ), the better the selection of the node in question. The rules for the selection of the node can be deduced directly from the theorem (Kania, 2004) and can be listed as follows 1. Firstly, at the very beginning, one has to choose the i Δ y node, for which μ( i Δ y ) = max.
2. From the nodes of the same range, further selection must be carried out depending on values of discriminants:
(a) if there exist nodes for which i Δ y ≥ k-the node, for which the discriminant i Δ y = max.
(b) if values of all the discriminants are lower than k-the node for which within the set of remainders
there exists a maximum number of remainders r
The above rules are the basis for the algorithm of PAL-oriented multi-level optimization.
Example 4.
Let us consider the example of the automaton ex6 (MCNC, 1991) . Only five functions of the output block will be considered for simplicity. The so min.pla file after classical single-output minimization dedicated for PAL-based implementation (Espresso-Dso) is presented in Fig. 11(a) .
Classical implementation of the so min.pla file (Fig. 11(a) ) requires 15 logic PAL-based blocks which include three terms and contain three logic levels.
Let us consider the multi-output function f : B 8 → B 5 , which, after multi-output minimization (Espresso), can be depicted in the mo min.pla file (Fig. 11(b) ). The reduced graph of outputs, associated with mo min.pla, is shown in Fig. 12 .
Direct realization of implicants with PAL-based logic blocks that contain three terms each (by means of the classical method, after minimization the multi-output function) needs
PAL-based logic blocks (k = 3). The node Δ 01110 does not meet conditions of minimization (Kania, 2004) , hence the realization of the associated implicant by means of a separate PAL-based logic block is not justified (makes no sense). A much better solution consists in the transformation of the minimized function illustrated by the graph by means of the so-called node splitting.
The node Δ 01110 corresponds to the first implicant of the mo min.pla file (Fig. 11(b) ) ----1----000 01110. The implicant can be replaced with other ones by appropriate modification of the output part. The best splitting can be found by analysing the graph of outputs. The output parts should correspond to the output parts of the implicants that are associated with the nodes of lower ranges which are connected with the node altered. Figure 13 illustrates the graph of outputs after splitting the node Δ 01110 .
During the next steps of the proposed algorithm, the implicants associated with the nodes Δ 11000 = 9, Δ 01100 = 3, Δ 00101 = 3 are realized. This step involves six PAL-based logic blocks that contain three products (terms) ( 1 γ = 6) and lead to significant lowering of the number of blocks that are necessary for direct realization of implicants depicted by the reduced graph:
That graph is obtained after removing the nodes Δ 11000 = 9, Δ 01100 = 3, Δ 00101 = 3 and introducing an additional node which is connected with these nodes and represents the feedback loop (Fig. 14) .
The nodes that correspond to the first range (Fig. 14) are implemented at the last stage of the synthesis process. The final circuit representation that uses ten PAL-based logic blocks is shown in Fig. 15. 
Algorithm of FSMs synthesis for PAL-based devices.
The algorithms presented in Section 3.1 make a complex strategy of FSM synthesis. The strategy is presented in the algorithm cb. Espresso is used as the minimization method.
Algorithm cb (common blocks searching)
1. An mb state assignment.
2. Espresso Dso; a pla analysis.
3. Optimization based on the graph of outputs; a pla analysis.
Exchange of codes (ec).
5. If there was a change in the point 4, then: Espresso and optimization based on the graph of outputs; a pla analysis.
6. Choosing the best (of 2, 3, 5) result.
7. End.
Experimental results
The method of implementing an FSM in PAL-based structures presented in the paper was compared with another approach with respect to the number of the logic blocks used and the number of logic levels. The experiments were carried out by means of NOVA (Villa and Sangiovanni-Vincentelli, 1990; Sentovich et al., 1992) and the proposed methods using 40 selected benchmarks (MCNC, 1991) . Experiments by NOVA were run for algorithms: the input and output (dominance) constraints (iohybrid code-ioh) and the input constraints (ihybrid code-ih). A vast majority of contemporary CPLD contains 5-AND cells. Because some terms are used to ensure some extra functions (T flip-flop, product terms expansion, etc.), experiments were run also for 3-, 4-and (6-9)-AND cells. The results of experiments for PAL-based logic blocks with three, four and five terms are presented in Table 2. The results of experiments for (6-9)-AND cells are presented in Table 3 . The numbers (a/b) show the results of synthesis performed on the benchmarks using the mb, the cb, the NOVA-ih, and the NOVA-ioh approach. The first number (a) shows the number of the employed k-product PAL-based blocks of the transition function, while the second number (b) is the number of logic levels of the transition function.
Among all examined benchmarks implemented based on PAL-based logic blocks with three terms, the proposed methods provided 17 solutions (43%) which required a smaller number of logic blocks, and 14 solutions (35%) which demanded a greater number of logic blocks than a better solution from the Nova-ih and the Nova-ioh approach. In all other cases, the numbers of logic blocks obtained for both methods were identical.
In the set of 40 compared cases, the proposed cb algorithm found the best 24 solutions (60%) did not require a greater number of logic blocks with three terms than the better solution from the Nova-ih and Nova-ioh methods. Among them, 16 implementations (67%) demanded the smallest number of logic blocks and only six solutions (25%) required a greater number of logic levels. For certain benchmarks, the reduction of logic block count was significant, e.g., dk27 (18%), keyb (38%), planet (19%), s1488 (18%), s1494 (17%), s386 (13%), styr (19%), tma (23%). Significant differences can be noticed not only for the smallest values of k. The reduction of 4-terms PALbased logic blocks is as follows keyb (32%), planet (20%), tma (17%), sse (17%), s420 (25%), s386 (17%).
Unfortunately, the number of logic levels does not follow the reduction of the number of logic blocks. Among the examined benchmarks implemented based on 3-terms PAL-based logic blocks, five implementations (13%) required a greater number of logic levels with respect to the better result from the NOVA-ih and the NOVA-ioh method, and four solutions (10%) needed a smaller number of logic levels. In all other cases (77%), the numbers of obtained logic levels for both methods were identical.
The analysis of the obtained experimental results is presented in the form of a yield of the logic cells U σ δ and a yield of the logic levels U ξ δ of the transition function. The yield of the logic cells U σ δ is calculated from the
, where σ δ (A) denotes the average of the whole number of transition blocks of the selected benchmarks, while the average is calculated for all tested method; σ δ (M ) denotes the whole number of transition blocks of the selected benchmarks for the selected encoding method.
The yield of the logic levels U ξ δ is calculated analogically to the yield of the logic cells U σ δ . The yield of the logic cells (levels) should be interpreted as the percent of the number of the logic cells (levels) for which the selected method is better (or worse if the yield is negative) than the average.
The graphs in Figs. 16 and 17 present the yield of the logic cells and logic levels of the experimental results. First of all, it should be noticed that the yield of logic cells for the cb algorithm is more than 6% for the smallest logic cells (k = 3). Moreover, the yield of the logic cells is greater than 3% for 4-AND cells and about 2% for 5-AND cells. The mb method gives results comparable with NOVA.
The graphs presented in Figs. 18 and 19 concern the experimental results of "small" automata. As "small" automata, the authors of the paper found automata with the number of terms (in the kiss2 format) less than 60. Those results are especially interesting. Both methods, mb and cb, gave results better than NOVA in relation to the yield of the logic cells and comparable results in relation to the yield of the logic levels. The cb method does not improve significantly the results received after state assignment process carried out by means of the mb algorithm. The heuristic methods of state assignment and PALoriented multi-level optimization (proposed in the paper) can be implemented as quick computer algorithms. PALoriented multi-level optimization ensures searching out a solution which is not worse with respect to the number of blocks than the one generated by synthesis without multilevel optimization. The optimization is carried out at the expense of slightly increased calculation time. Computational complexity of the proposed algorithms is less than that of NOVA algorithms. Example synthesis times for selected benchmarks are presented in Table 1 . Differences are especially noticeable for big benchmarks. Sometimes, synthesis time exceeded one day for the NOVA-ih algorithm. The presented computational complexity comparison is only approximate. The experiments were run for different conditions (different computers and operating systems), so the results should be treated warily.
The obtained results have also been compared to vendor tools (Czerwiński and Kulisz, 2009) . Commercial vendor-independent systems use low level netlist formats to export structures resulting from logical synthesis to vendor systems. This approach is secure, because there is little chance that the low level structure will be interfered with by implementation tools. The method is, however, not universal, because netlist formats are vendor specific. Using this approach requires thus equipping software with procedures or plugins responsible for converting formats and preparing data specific for implementation tools. This is acceptable for commercial companies but difficult for academic research teams, as it requires much "scientifically worthless" extra work. The purpose of the presented approach (Czerwiński and Kulisz, 2009 ) is to use a special style of HDL description as the intermediate format. The proposed format is universal and portable, and it is much more comprehensible to a human than low level netlists. The method was verified for main vendor synthesis systems and CPLD circuits. The experimental results proved that the method is secure, i.e., the investigated implementation tools did not deteriorate the results of logic synthesis. 
Conclusions
The synthesis of finite state machines dedicated for PALbased CPLDs was presented in the paper. The essence of the method lies in incorporating two-level minimization into the synthesis process. All steps of the proposed method are directed to efficient implementation of FSMs into CPLDs with PAL-based logic blocks containing a predefined number of product terms. The synthesis of FSMs consists of PAL-oriented state assignment using primary and secondary merging conditions and PAL oriented multi-level optimization based on the graph of outputs. PAL-oriented multi-level optimization can also be used for the optimization of combinational circuits. Subsequent steps of the synthesis process are adapted to logical resources of PAL-based CPLDs. The elements of two-level minimization are included in the process of state assignment. The procedure of coding word changing and PAL-oriented multi-level optimization make the method of FSM synthesis competitive. Adjustments of state assignment to logical resources characteristic for a PAL-based logic block enables significant improvement of synthesis effectiveness in relation to other approaches. Moreover, it is worth noting that the achieved FSMs are self-correcting. The reason for this is the usage of coding words with all inactive output levels.
The proposed method is an alternative to FSMs classical technology mapping based on classical coding (binary, one-hot, Gray) with elements of two level minimization of individual single-output functions and other academic methods like YEDI, NOVA, etc. The results of experiments presented in the paper prove that the proposed synthesis method is especially attractive for CPLD structures consisting of small PAL-based logic blocks. The results of synthesis of "small" automata are especially interesting. Both the proposed methods gave results better than NOVA with respect to the number of logic levels and the number of PAL-based blocks. For all cases (not only a contrived benchmark), the solutions generated by the proposed method were minimal with respect to the number of the PAL-based blocks used. the number of terms in the kiss2 format is less than 60 ("small" automata); 2 the number of terms in the kiss2 format is greater than 59 
