© Û . DOI: 10.15514/ISPRAS-2024-36(4)-10 # **Experimental Comparison of Logic Circuit Synthesis Methods** M.D. Vershkov, ORCID: 0009-0001-5389-6117 <mdvershkov@edu.hse.ru> A.A. Yagzhov, ORCID: 0009-0007-8522-3391 <aayagzhov@edu.hse.ru> N.S. Romanov, ORCID: 0009-0009-7440-1839 <nsromanov\_1@edu.hse.ru> A.A. Fedotova, ORCID: 0009-0001-5613-8696 <aafedotova\_6@edu.hse.ru> E.P. Znatnov, ORCID: 0009-0002-4260-2803 <epznatnov@edu.hse.ru> Institute for System Programming of the Russian Academy of Sciences, 25, Alexander Solzhenitsyn st., Moscow, 109004, Russia. National Research University Higher School of Economics, 20, Myasnitskaya st., Moscow, 101000, Russia. **Abstract.** This paper presents the results of an experimental comparison of methods for the synthesis of combinational logic circuits that implement specified Boolean functions. The following methods were considered: the method of Akers, bi-decomposition, the methods of cascades, Minato-Morreale, Reed-Muller and DSD-decomposition. The comparison was based on an estimate of power, delay and area of synthesized logic circuits. The evaluation was carried out without the process of technology mapping of the circuits. These parameters were chosen because they are the main criteria for technology-independent optimization, where these methods are widely used. Boolean functions with the number of arguments from 4 to 10 were used as input data. They were generated on the basis of information on the frequency of occurrence of various NPN-equivalence classes of Boolean functions of 4 variables. As a result of the study, it was found that the Minato-Morreale method is the most universal in solving technology-independent optimization problems and can be used for different criteria. **Keywords:** Boolean functions, logic optimization, electronic design automation. **For citation:** Vershkov M.D., Yagzhov A.A., Romanov N.S., Fedotova A.A., Znatnov E.P. Experimental Comparison of Logic Circuit Synthesis Methods. *Trudy ISP RAN/Proc. ISP RAS*, vol. 36, issue 4, 2024. pp. 133-142. DOI: 10.15514/ISPRAS-2024-36(4)-10. ## Экспериментальное сравнение методов синтеза логических схем М.Д. Вершков, ORCID: 0009-0001-5389-6117 <mdvershkov@edu.hse.ru> А.А. Ягжов, ORCID: 0009-0007-8522-3391 <aayagzhov@edu.hse.ru> Н.С. Романов, ORCID: 0009-0009-7440-1839 <nsromanov\_1@edu.hse.ru> А.А. Федотова, ORCID: 0009-0001-5613-8696 <aafedotova\_6@edu.hse.ru> Е.П. Знатнов, ORCID: 0009-0002-4260-2803 <epznatnov@edu.hse.ru> Институт системного программирования РАН, Россия, 109004, г. Москва, ул. А. Солженицына, д. 25. Национальный исследовательский университет «Высшая школа экономики», Россия, 101000, г. Москва, ул. Мясницкая, д. 20 Аннотация. В работе описаны результаты экспериментального сравнения методов синтеза комбинационных логических схем, реализующих заданные булевы функции. Рассмотрены следующие методы: Акерса, би-декомпозиции, каскадов, Минато-Морреале, Рида-Маллера и DSD-разложения. Сравнение основывалось на оценке энергопотребления, задержки и площади синтезируемых логических схем. Оценка осуществлялась без процесса технологического отображения схем. Выбор данных параметров обусловлен тем, что они являются основными критериями технологически независимой оптимизации, в которой данные методы находят широкое применение. В качестве исходных данных использовались булевы функции с числом аргументов от 4 до 10, которые были сгенерированы на основе информации о частоте встречаемости различных NPN-классов эквивалентности булевых функций от 4 переменных. В результате исследования было установлено, что метод Минато-Морреале является наиболее универсальным при решении задач технологически независимой оптимизации и может быть использован для различных критериев. **Ключевые слова:** булевы функции, логическая оптимизация, автоматизация проектирования микроэлектронной аппаратуры. Для цитирования: Вершков М.Д., Ягжов А.А., Романов Н.С., Федотова А.А., Знатнов Е.П. Экспериментальное сравнение методов синтеза логических схем. Труды ИСП РАН, том 36, вып. 4, 2024 г., стр. 133–142 (на английском языке). DOI: 10.15514/ISPRAS-2024-36(4)–10. #### 1. Introduction The technology-independent optimization (optimization) of logic circuits is one of the most important steps in the logic synthesis process with a significant impact on the quality of the digital systems being designed. Different methods of synthesis of logic circuits implementing given Boolean functions (synthesis methods) are widely used in logic optimization approaches. For instance, these methods can be used in optimization that is based on the rewriting that is the replacement of subcircuits of the original logic circuit with other subcircuits that more effectively implement the same functions [1]. There are three main criteria for logic optimization (metrics for evaluating these criteria in a logic net are given in parentheses): - 1) power (switching activity); - 2) delay (the longest path from input to output); - 3) area (the number of logic gates). The aim of this study was to perform an experimental comparison of logic circuit synthesis methods and to identify the best one for each optimization criterion. Other published papers also present the results of comparisons between different synthesis methods. In [2], the considered methods are as follows: sum-of-products (SOP) and product-of-sums (POS) two-level expressions, MUX-based expressions, the Quine-McCluskey [3] method and different types of XOR expressions. The comparison was made for all Boolean functions of 3 and 4 variables and for a thousand random generated functions of 5 variables. The comparison was based on estimating the delay and area of synthesized logic circuits without technology mapping. In [4], a new approach to bi-decomposition of Boolean functions is described and compared with the best algorithms in logic synthesis tools such as FBDD [5], SIS [6], ABC [7]. Sixteen circuits from the MCNC [8], ISCAS [9] and IWLS [10] benchmark suites were used for the comparison by power, delay and area after the process of technology mapping. In [11], a comparison was made between the size (number of products in the SOP) of the minimal SOP of a Boolean function and the size of the SOP obtained by Minato-Morreale [12] method. The study was considered for different Boolean functions with the number of variables ranging from 3 to 20. In this article an experimental comparison of methods of synthesis of logic circuits implementing given Boolean functions was carried out. The following methods were considered: the method of Akers [13], bi-decomposition [14], the methods of cascades [15], Minato-Morreale [12], Reed-Muller [16] and DSD-decomposition [17]. The circuits were synthesized in bases of different logic gates without technology mapping processing. Power, delay and area of the circuits were estimated for the comparison. Boolean functions of size from 4 to 10 variables were considered in the experiment. The choice of a benchmark may have a significant impact on the results of experiments. In this study we decided to generate a set of tests based on information about the frequency of occurrence of NPN-equivalence classes of Boolean functions of four variables. This paper is organized as follows: Section 2 provides a brief overview of considered methods. Section 3 describes the methodology of the tests carried out. Section 4 presents the results of this study and Section 5 is a conclusion. ## 2. Method overview Akers method [13] is used to create majority-based circuits. It is the iterative algorithm that implies the manipulations of the table created from the given truth table. The columns of the converting table correspond to gates arguments. At each step of the algorithm, all sets of triples of the columns are iterated and a truth table of a majority gate is evaluated. Received truth tables are compared with each other, after which the best one is selected according to some heuristics. It is inserted into the table as a column. The algorithm terminates after obtaining the truth table that is equal to the given one Bi-decomposition [14] is based on extracting the superposition of two Boolean functions from a single source function: $$f = \varphi(g_1(z_1), g_2(z_2)), \tag{1}$$ where f is a source function, $g_1$ and $g_2$ are Boolean functions with sets of arguments $z_1$ and $z_2$ respectively, $\varphi$ is a given Boolean function of two arguments. Function $\varphi$ is typically represented by logic operations such as OR (NOR), AND (NAND), and XOR. Different constraints can be imposed on the arguments of new functions, such as requiring subfunctions to have disjoint support. Alternatively, these arguments can be given before bidecomposition. In this article the method of heuristic decomposition was considered. This means that the arguments of $g_1$ and $g_2$ are not provided, and there is only one constraint for their arguments: the number of arguments must be less than the number of arguments of the source function. Nevertheless, the probability of existence of decomposition of this kind is law, especially for completely specified functions. If decomposition is impossible, when the source function is broken down into two functions, one or both of them have the same number of variables. The circuit synthesis algorithm using bi-decomposition is recursive. The two Boolean functions obtained at each step of recursion are decomposed in the same manner. The method of cascades [15] is based on the Shannon [18] decomposition, which represents the source function as the sum of two sub-functions: $$f(x_1, x_2, ..., x_n) = x_n \cdot f(x_1, x_2, ..., x_{n-1}, 1)$$ $$\cup \ \bar{x}_n \cdot f(x_1, x_2, ..., x_{n-1}, 0), \tag{2}$$ where f is a source Boolean function, $x_i$ is a i argument of this function. This method is also recursive, and two sub-function are decomposed in the same way. The Minato-Morreale [12] method is a technique for obtaining an irredundant sum-of-product (ISOP) of Boolean function. An ISOP is a sum-of-products (SOP) of Boolean function that cannot have any literal or product removed without losing equivalence to the source function. The study considered two variations of the method: with and without algebraic factoring. Algebraic factoring is an algorithm that transforms SOP, reducing the number of literals and products. This method does not guarantee obtaining the ISOP of a source Boolean function with the minimum number of products [11]. The Reed-Muller method [16] aims to obtain modulo-2 sums of products for a source Boolean function (polynomial). There are only positive or negative literals for each variable in this polynomial. In this article we considered expressions where all literals are positive (Zhegalkin polynomial [19]). DSD-decomposition (Disjoint Support Decomposition) [17] is based on decomposition of a source Boolean function into several subfunctions with a disjoint support: $$f = k(a_1, a_2, ..., a_n),$$ (3) where f is a source Boolean function, $a_1, a_2, ..., a_n$ are subfunctions in decomposition, k is a function that links these subfunctions. In this method the number of subfunctions is equal to or greater than 2 (depends on the source function). AND, OR, XOR or the Prime function (Boolean function of 3 variables or greater that cannot be further decomposed) can be used as k. The method is recursive, new functions are decomposed in the same way. The bases of synthesized circuits for each considered method are presented in Table 1. | | | circuits. | |--|--|-----------| | | | | | Method | Logic gates | | | | |--------------------------------|---------------------|--|--|--| | Akers | MAJ, NOT, 0 | | | | | Bi-decomposition | AND, NOT | | | | | Cascades | AND, NOT, 1, 0 | | | | | Minato-Morreale | AND, NOT | | | | | Minato-Morreale with factoring | AND, NOT | | | | | DSD-decomposition | AND, XOR, NOT, 1, 0 | | | | | Reed-Muller | AND, XOR, 1 | | | | ## 3. Methodology The synthesis methods were implemented in C++. The kitty [20] and STACCATO [21] libraries were used for Minato-Morreale and DSD-decomposition methods, respectively. The comparison of circuits synthesized by the methods was carried out without technology mapping processing. To compare the methods with each other, a set of test cases was written in which a certain number of truth tables of Boolean functions over four to ten arguments were generated with a probability that was calculated based on the information about the frequency of occurrence of NPN-equivalence classes of Boolean functions of four variables. The circuits from the OpenABC-D [22] test set were used for obtaining this statistic. The collection process was organized as follows: all cuts of the size four [1] were iterated at each circuit, then the algorithm identified a NPN-equivalence class of the cut function. As a result, the frequency of occurrence of each class was achieved. To receive a function over more than four arguments a concatenation of the truth tables was used. The truth table over four variables was obtained after generating a function of NPN-equivalence class according to the received probabilities, then four variables swapping, four input flipping and output flipping with a 50 percent probability were made. The number of generated truth tables of Boolean functions over a particular number of arguments was 1000. These truth tables were supplied as input arguments to the synthesis methods, which constructed circuits consisting of logic gates. In the first comparison, the arity of the gates in synthesized circuits was limited to two, therefore the Akers algorithm was not participated. Afterwards, using three-input gates was allowed and all the algorithms took part in the second comparison. The following characteristics were used to compare circuits: the number of function arguments, area, delay, and switching activity. Additionally, the runtime of the methods was also taken into account. The switching activity of a circuit was calculated as the sum of the switching probabilities of all its gates: $$Z = \sum_{i=0}^{n} \frac{s_i}{t'} \tag{4}$$ where Z is the switching activity of the logic circuit, $s_i$ is the number of cell switches (from 1 to 0 and from 0 to 1), i is the cell index of the logic circuit, t is the number of simulations. In the experiment, the number of simulations of each logic circuit was 1024. The implementations of Akers and bi-decomposition methods were tested on truth tables of Boolean functions over four to seven and four to eight arguments, respectively. The reason is the high asymptotic complexity of these methods [23, 14]. ## 4. Results The achieved results of the methods comparison are described in Tables 2 and 3. Table 2 illustrates the information about the runtime of the methods and characteristics of the synthesized circuits composed of two-input gates only, whereas Table 3 shows the same but for circuits that may include three-input gates. The cells of the tables contain the averages of the results obtained. The part of Table 2, which corresponds to the statistics about switching activity of synthesized circuits, reveals that the leader in optimizing this parameter for functions over four variables is DSD-decomposition method, whereas for functions over five and six arguments is Minato-Morreale method with factoring and for functions over seven to ten arguments is the original Minato-Morreale method. Bi-decomposition method comes fourth in terms of power optimization for functions over four and five arguments, comes third for functions over six arguments, for the other functions this method reduces its effectiveness and exhibits the worst results. The method of cascades is the second from the end for optimization of functions over four to eight arguments and the worst one for others. Reed-Muller method takes the last place in optimization of functions over four to six variables but improves its position with an increase in the number of variables and becomes the third by functions over eight arguments. According to Table 2, Minato-Morreale method optimizes the delay of circuits containing from five to ten inputs better than the other methods. This method is followed by Reed-Muller algorithm and then Minato-Morreale algorithm with factoring. DSD-decomposition method is the best for optimizing functions over four arguments but comes fourth in terms of delay optimization for the other number of arguments. Bi-decomposition and cascades methods are the least preferred for optimizing circuit delay. The part of Table 2 Area illustrates that the leader for reducing the number of logic gates for circuits from five to nine inputs is Minato-Morreale method with factoring. DSD-decomposition is the first in terms of this optimization for functions over four and ten arguments, the method only the second and the third for functions over eight and nine arguments and over five and six arguments respectively. Minato-Morreale method without factoring comes second for functions over five and six arguments. Bi-decomposition and Reed-Muller methods are the worst in terms of optimizing circuit area. The fastest algorithm is the method of cascades, while Minato-Morreale methods require a little more time for execution, these algorithms have a comparable runtime. DSD-decomposition and Reed-Muller methods are moderately slower than the leader. The most time consuming method is bi-decomposition. Table 3 demonstrates the similar ranking to Table 2 in terms of switching activity optimization with the exception of Minato-Morreale method without factoring, which works more efficiently using three-input logic gates than a similar one with factoring. Akers method becomes consistently second, shifting the previous rating. The Delay of Table 3 reveals that Akers method is not preferred for delay optimization, despite the fact that it becomes second for functions over five and six arguments. Minato-Morreale method without factoring is the absolute leader for optimization of circuit delay with allowing using tree-input gates. A slightly different result in contrast to Table 2 is achieved in Area optimization. Akers algorithm comes first for functions over five to seven arguments and the original Minato-Morreale becomes second for functions over eight to ten arguments. Otherwise, the results are similar to those obtained in Table 2. The runtime of the algorithms in Table 3 does not reveal any new data except that Akers algorithm is the longest-running method. Table 2. Experiment results for circuits containing two-input gates only. | Arguments number | 4 | 5 | 6 | 7 | 8 | 9 | 10 | | |--------------------------------|------|-------|-------|--------|--------|--------|---------|--| | Switching activity | | | | | | | | | | Bi-decomposition | 4.54 | 8.71 | 17.66 | 35.36 | 70.31 | | | | | Method of cascades | 5.11 | 9.78 | 18.57 | 34.06 | 61.29 | 109.68 | 197.85 | | | Minato-Morreale | 4.35 | 7.52 | 12.88 | 20.89 | 33.11 | 49.41 | 72.61 | | | Minato-Morreale with factoring | 4 | 7.16 | 12.73 | 22.63 | 41.74 | 75.22 | 134.7 | | | DSD-decomposition | 3.69 | 9.18 | 18.25 | 33.57 | 59.8 | 106.14 | 189.89 | | | Reed-Muller | 6.62 | 12.13 | 20.69 | 33.99 | 54.71 | 86.72 | 136.4 | | | Delay | | | | | | | | | | Bi-decomposition | 3.7 | 7.61 | 15.47 | 31.45 | 65.9 | | | | | Method of cascades | 4.89 | 7.7 | 9.96 | 12 | 14 | 16 | 18 | | | Minato-Morreale | 3.11 | 4.87 | 6.51 | 7.76 | 8.89 | 10.16 | 11.92 | | | Minato-Morreale with factoring | 3.11 | 5.64 | 7.97 | 10.4 | 12.84 | 15.27 | 17.73 | | | DSD-decomposition | 2.82 | 6.84 | 9.71 | 11.93 | 14 | 16 | 18 | | | Reed-Muller | 4.38 | 6.11 | 7.77 | 9.03 | 10.06 | 11.26 | 12.96 | | | Area | | | | | | | | | | Bi-decomposition | 5.92 | 16.5 | 42.81 | 102.69 | 237.23 | | | | | Method of cascades | 7.26 | 17.79 | 38.44 | 75.42 | 140.7 | 256.73 | 468.3 | | | Minato-Morreale | 5.97 | 15.52 | 35.91 | 75.78 | 155.87 | 301.82 | 574.24 | | | Minato-Morreale with factoring | 4.23 | 11.26 | 25.37 | 53.92 | 114.1 | 231.55 | 463.79 | | | DSD-decomposition | 3.43 | 15.88 | 36.77 | 77.45 | 134.61 | 244.54 | 444.29 | | | Reed-Muller | 12.8 | 30.26 | 64.77 | 134.16 | 272.82 | 548.99 | 1096.01 | | | Runtime (ms) | | | | | | | | | | Bi-decomposition | 4.07 | 7.41 | 16.39 | 44.22 | 167.53 | | | | | Method of cascades | 2.65 | 2.91 | 3.56 | 5.22 | 9.44 | 21.75 | 62.09 | | | Minato-Morreale | 2.69 | 3.02 | 3.73 | 5.52 | 9.85 | 22.71 | 63.07 | | | Minato-Morreale with factoring | 2.65 | 3.01 | 3.68 | 5.47 | 9.94 | 22.85 | 63.55 | | | DSD-decomposition | 7.2 | 8.06 | 9.04 | 11.26 | 16.39 | 30.69 | 74.56 | | | Reed-Muller | 2.64 | 3.05 | 4.16 | 7.42 | 16.54 | 44.13 | 127.76 | | Table 3. Medical activities of multimodal human-computer interactions. | Arguments number | 4 | 5 | 6 | 7 | 8 | 9 | 10 | | |--------------------------------|------|-----------|----------|-------|--------|--------|--------|--| | | Sw | itching a | ictivity | | | | | | | Akers | 3.81 | 6.2 | 10.41 | 21.07 | | | | | | Bi-decomposition | 4.42 | 8.32 | 15.95 | 28.87 | 58.87 | | | | | Method of cascades | 4.81 | 9.37 | 18.2 | 33.65 | 60.85 | 109.1 | 197.04 | | | Minato-Morreale | 3.57 | 5.23 | 7.83 | 11.98 | 19.3 | 29.96 | 45.14 | | | Minato-Morreale with factoring | 3.81 | 6.64 | 11.65 | 20.04 | 37.53 | 68.05 | 123.81 | | | DSD-decomposition | 3.46 | 9.17 | 18.25 | 33.57 | 59.8 | 106.14 | 189.89 | | | Reed-Muller | 5.43 | 9.39 | 15.56 | 25.5 | 40.87 | 64.69 | 101.25 | | | Delay | | | | | | | | | | Akers | 3.32 | 5.06 | 7.57 | 13.61 | | | | | | Bi-decomposition | 3.6 | 7.44 | 15.36 | 31.35 | 65.79 | | | | | Method of cascades | 4.58 | 7.53 | 9.93 | 12 | 14 | 16 | 18 | | | Minato-Morreale | 2.29 | 3.7 | 4.65 | 5.22 | 6.32 | 7.49 | 8 | | | Minato-Morreale with factoring | 2.89 | 5.34 | 7.72 | 10.1 | 12.54 | 14.98 | 17.44 | | | DSD-decomposition | 2.56 | 6.83 | 9.71 | 11.93 | 14 | 16 | 18 | | | Reed-Muller | 3.26 | 4.57 | 5.57 | 6.28 | 7 | 8.18 | 9 | | | | | Area | | | | | | | | Akers | 4.67 | 9.18 | 17.29 | 38.93 | | | | | | Bi-decomposition | 5.66 | 15.55 | 38.62 | 90.02 | 213.62 | | | | | Method of cascades | 6.57 | 16.77 | 37.56 | 74.41 | 139.63 | 255.25 | 466.14 | | | Minato-Morreale | 4.09 | 9.74 | 22.39 | 48.57 | 102.94 | 206.14 | 409.41 | | | Minato-Morreale with factoring | 3.78 | 10.02 | 22.8 | 48.74 | 104.58 | 215.87 | 441.36 | | | DSD-decomposition | 2.92 | 15.86 | 36.77 | 72.45 | 134.61 | 244.54 | 444.29 | | | Reed-Muller | 9.38 | 21.7 | 46.96 | 98.86 | 201.3 | 405.41 | 808.42 | | | Runtime (ms) | | | | | | | | | | Akers | 3.35 | 6.25 | 14.75 | 82.48 | | | | | | Bi-decomposition | 4 | 7.28 | 16.14 | 43.62 | 165.79 | | | | | Method of cascades | 2.57 | 2.83 | 3.46 | 5.06 | 9.2 | 21.1 | 60.8 | | | Minato-Morreale | 2.6 | 2.9 | 3.55 | 5.2 | 9.28 | 21.49 | 60.59 | | | Minato-Morreale with factoring | 2.58 | 2.94 | 3.6 | 5.29 | 9.62 | 22.19 | 62.21 | | | DSD-decomposition | 7.3 | 7.8 | 8.7 | 10.75 | 15.63 | 29.31 | 71.96 | | | Reed-Muller | 2.55 | 2.92 | 3.96 | 7.05 | 15.92 | 43.48 | 127.38 | | #### 5. Conclusion The results of the work of seven methods for the synthesis of logic circuits implementing specified Boolean functions have been analyzed. The comparison of the obtained circuits has been carried out according to the three main criteria: the number of logic gates (area), depth (delay) and switching activity (power). The analysis of the results has shown that DSD-decomposition (only for functions over four arguments) and the both Minato-Morreale methods are the best choice for power optimization. The similar results have been demonstrated for delay optimization of logic circuits. Area optimization with a restriction on the arity of logic gates equal to two is better to carry out using DSD-decomposition (only for functions over four and ten arguments) and Minato-Morreale method with factoring. Akers algorithm is the leader in optimization of a number of three-input gates in circuits from five to seven inputs and for other circuits, the leader is Minato-Morreale algorithm without factoring. Minato-Morreale and cascades methods have demonstrated a compatible and minimal runtime, whereas Akers and bi-decomposition have shown the worst performance. ### References - [1]. Riener H., Mishchenko A., Soeken M. Exact DAG-aware rewriting. In Proc. of Design, Automation and Test in Europe Conference and Exhibition, 2020, pp. 732–737. - [2]. Ammes G., Lau W., Ribas R. P. (2018) Comparative analysis of different Boolean function synthesis Methods. In Proc. of Microelectronics Students Forum. Available at: https://sbmicro.org.br/eventos/sforum/volume-18, accessed 01.07.2024. - [3]. McCluskey E. J. Minimization of Boolean functions. The Bell System Technical Journal, vol. 35, no. 6, 1956, pp. 1417–1444. - [4]. Choudhury M., Mohanram, K. Bi-decomposition of large Boolean functions using blocking edge graphs. In Proc. of the International Conference on Computer-Aided Design, 2010, pp. 586–591. - [5]. Wu D., Zhu J. FBDD: A folded logic synthesis system. In Proc. of International Conference on ASIC, 2005, pp. 746–751. - [6]. Singh E. M. S. K. J., Murgai L. L. C. M. R., Sangiovanni-Vincentelli R. K. B. A. SIS: A system for sequential circuit synthesis. University of California, Berkeley, vol. 94720, 1992, p. 4. - [7]. ABC. Available at: https://github.com/berkeley-abc/abc, accessed 01.07.2024. - [8]. Yang S. Logic synthesis and optimization benchmarks user guide: version 3.0. Research Triangle Park, NC, USA: Microelectronics Center of North Carolina (MCNC), 1991, pp. 502-508. - [9]. Brglez F., Bryan D., Kozminski K. Combinational Profiles of Sequential Benchmark Circuits. In Proc. of the International Symposium of Circuits and Systems, 1989, pp. 1929–1934. - [10]. Albrecht. C. IWLS 2005 Benchmarks. 2005. Available at: http://iwls.org/iwls2005/benchmarks.html, accessed 01.07.2024. - [11]. Sasao T., Butler J. T. Worst and best irredundant sum-of-products expressions. IEEE Transactions on Computers, vol. 50, no. 9, 2001, pp. 935–948. - [12]. Minato S. Fast generation of prime-irredundant covers from binary decision diagrams. IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, vol. E76-A, no. 6, 1993, pp. 967-973. - [13]. Akers B. Synthesis of combinational logic using three-input majority gates. In Proc. of 3rd Annual Symposium on Switching Circuit Theory and Logical Design, 1962, pp. 149–157. - [14]. Pottosin Y. V. Synthesis of combinational circuits by means of bi-decomposition of Boolean functions. Informatics, vol. 19, no. 1, 2022, pp. 7–18. - [15]. Povarov G. N. A method for synthesis of computing and controlling contact circuits. Automatika i Telemekhanika, vol. 18, no. 2, 1957, pp. 145–162 (in Russian). - [16]. Harking B. Efficient algorithm for canonical Reed-Muller expansions of Boolean functions. IEE Proceedings E (Computers and Digital Techniques), vol. 137, no. 5, 1990, pp. 366–370. - [17]. Bertacco V. Scalable Hardware Verification with Symbolic Simulation. Springer Science & Business Media, 2006. - [18]. Shannon C. E. The synthesis of two-terminal switching circuits. The Bell System Technical Journal, vol. 28, no. 1, 1949, pp. 59–98. - [19]. Zhegalkin I. I. On the technique of calculating propositions in symbolic logic. Matematicheskii Sbornik, vol. 34, no. 1, 1927, pp. 9-28 (in Russian and French). - [20]. kitty. Available at: https://github.com/msoeken/kitty, accessed 01.07.2024. - [21]. STACCATO. Available at: https://web.eecs.umich.edu/staccato/, accessed 01.07.2024. - [22]. OpenABC-D. Available at: https://github.com/NYU-MLDA/OpenABC, accessed 01.07.2024. - [23]. Lee S.-Y., Riener H., De Micheli G. Logic resynthesis of majoritybased circuits by top-down decomposition. In Proc. of 24th International Symposium on Design and Diagnostics of Electronic Circuits & Systems, 2021, pp. 105–110. ## Информация об авторах / Information about authors Максим Дмитриевич ВЕРШКОВ – студент 5-го курса Московского института электроники и математики им. А.Н. Тихонова Национального исследовательского университета «Высшая школа экономики». Сфера научных интересов: оптимизация цифровых СБИС. Maxim Dmitrievich VERSHKOV is a 5th year student of the A.N. Tikhonov Moscow Institute of Electronics and Mathematics of the National Research University Higher School of Economics. Research interests: optimization of digital VLSI. Алексей Александрович ЯГЖОВ — студент 4-го курса Московского института электроники и математики им. А.Н. Тихонова Национального исследовательского университета «Высшая школа экономики». Сфера научных интересов: оптимизация цифровых СБИС. Alexey Aleksandrovich YAGZHOV is a 4th year student of the A.N. Tikhonov Moscow Institute of Electronics and Mathematics of the National Research University Higher School of Economics. Research interests: optimization of digital VLSI. Никита Сергеевич РОМАНОВ – студент 5-го курса Московского института электроники и математики им. А.Н. Тихонова Национального исследовательского университета «Высшая школа экономики». Сфера научных интересов: оптимизация цифровых СБИС. Nikita Sergeevitch ROMANOV is a 5th year student of the A.N. Tikhonov Moscow Institute of Electronics and Mathematics of the National Research University Higher School of Economics. Research interests: optimization of digital VLSI. Анна Алексеевна ФЕДОТОВА – студентка 3 курса Факультета компьютерных наук Национального исследовательского университета «Высшая школа экономики». Сфера научных интересов: оптимизация цифровых СБИС. Anna Alekseevna FEDOTOVA – is a 3th year student of the Faculty of Computer Science of the National Research University Higher School of Economics. Research interests: optimization of digital VLSI. Егор Павлович ЗНАТНОВ – студент 3 курса Факультета компьютерных наук Национального исследовательского университета «Высшая школа экономики». Сфера научных интересов: оптимизация цифровых СБИС. Egor Pavlovich ZNATNOV – is a 3th year student of the Faculty of Computer Science of the National Research University Higher School of Economics. Research interests: optimization of digital VLSI.LSI.