// Library = EvoApprox 12x12 // Circuit = mul12x12_120 // Area (45) = 806 // Delay (45) = 1.140 // Power (45) = 0.49 // MAE = 9642.00000 // MSE = 132105026.50000 // MRE = 10.27 % // WCE = 33472 // WCRE = 2700700 % // EP = 100.0 % module mul12x12_120(A, B, O); input [11:0] A, B; output [23:0] O; wire n_1190, n_1191, n_1611, n_1610, n_1617, n_1616, n_1682, n_704, n_1103, n_1102; wire n_1109, n_1108, n_1864, n_1860, n_722, n_726, n_2036, n_2030, n_556, n_550; wire n_1031, n_1030, n_428, n_832, n_1037, n_1036, n_1400, n_1401, n_422, n_1407; wire n_18, n_19, n_16, n_17, n_14, n_15, n_12, n_13, n_10, n_11; wire n_882, n_883, n_1538, n_1539, n_1534, n_1535, n_1240, n_1241, n_1246, n_1247; wire n_1086, n_1087, n_1080, n_1081, n_905, n_904, n_908, n_83, n_82, n_1914; wire n_1660, n_1661, n_1666, n_1987, n_1986, n_1981, n_1980, n_566, n_560, n_1350; wire n_302, n_306, n_606, n_1942, n_600, n_601, n_1931, n_34, n_608, n_609; wire n_760, n_356, n_1363, n_1362, n_36, n_1368, n_45, n_44, n_47, n_46; wire n_41, n_40, n_43, n_42, n_1893, n_1892, n_1042, n_1043, n_788, n_464; wire n_465, n_1560, n_1444, n_1440, n_1441, n_1622, n_1623, n_1186, n_1628, n_1629; wire n_810, n_1876, n_1870, n_638, n_224, n_632, n_2020, n_2024, n_640, n_641; wire n_134, n_820, n_826, n_1556, n_981, n_980, n_1550, n_1551, n_1529, n_1528; wire n_732, n_1523, n_1522, n_738, n_1253, n_1252, n_1256, n_1093, n_1092, n_1097; wire n_1096, n_39, n_1908, n_1905, n_1904, n_1413, n_1412, n_1419, n_1418, n_1776; wire n_1777, n_1673, n_1672, n_1839, n_1838, n_572, n_766, n_174, n_1351, n_312; wire n_313, n_2014, n_2015, n_672, n_676, n_770, n_406, n_407, n_1053, n_1052; wire n_1428, n_1429, n_958, n_959, n_1356, n_1422, n_1423, n_30, n_31, n_32; wire n_33, n_792, n_35, n_790, n_37, n_38, n_1948, n_814, n_798, n_1048; wire n_1899, n_1512, n_1513, n_1898, n_1516, n_1517, n_494, n_1451, n_1450, n_1456; wire n_1633, n_1632, n_783, n_1639, n_782, n_1732, n_1958, n_1644, n_1645, n_1406; wire n_1125, n_838, n_1842, n_1843, n_1792, n_1848, n_1849, n_628, n_196, n_622; wire n_1124, n_1954, n_1965, n_1964, n_362, n_1544, n_440, n_368, n_1015, n_1014; wire n_694, n_698, n_744, n_748, n_1268, n_1262, n_1263, n_965, n_964, n_1930; wire n_66, n_65, n_64, n_1936, n_1937, n_1462, n_1463, n_1788, n_8, n_9; wire n_4, n_5, n_6, n_7, n_0, n_1, n_2, n_3, n_1600, n_1606; wire n_1607, n_544, n_1114, n_1115, n_1118, n_1284, n_1280, n_240, n_241, n_2009; wire n_2008, n_2003, n_2002, n_660, n_666, n_433, n_432, n_1020, n_1021, n_1024; wire n_434, n_1435, n_1434, n_1341, n_1340, n_1347, n_1346, n_23, n_22, n_21; wire n_20, n_27, n_26, n_25, n_24, n_29, n_28, n_1970, n_1971, n_804; wire n_488, n_1506, n_484, n_1235, n_1234, n_932, n_92, n_93, n_1654, n_1651; wire n_1650, n_1886, n_971, n_976, n_1025, n_1992, n_1854, n_1998, n_594, n_595; wire n_610, n_616, n_296, n_506, n_500, n_372, n_688, n_1976, n_682, n_1977; wire n_752, n_753, n_1638, n_754, n_208, n_209, n_1372, n_1373, n_1275, n_1274; wire n_1927, n_1926, n_1921, n_1920, n_1075, n_1074, n_970, n_1887, n_1071, n_1070; wire n_1882, n_1883, n_56, n_57, n_1473, n_1472, n_478; assign n_0 = A[0]; assign n_1 = A[0]; assign n_2 = A[1]; assign n_3 = A[1]; assign n_4 = A[2]; assign n_5 = A[2]; assign n_6 = A[3]; assign n_7 = A[3]; assign n_8 = A[4]; assign n_9 = A[4]; assign n_10 = A[5]; assign n_11 = A[5]; assign n_12 = A[6]; assign n_13 = A[6]; assign n_14 = A[7]; assign n_15 = A[7]; assign n_16 = A[8]; assign n_17 = A[8]; assign n_18 = A[9]; assign n_19 = A[9]; assign n_20 = A[10]; assign n_21 = A[10]; assign n_22 = A[11]; assign n_23 = A[11]; assign n_24 = B[0]; assign n_25 = B[0]; assign n_26 = B[1]; assign n_27 = B[1]; assign n_28 = B[2]; assign n_29 = B[2]; assign n_30 = B[3]; assign n_31 = B[3]; assign n_32 = B[4]; assign n_33 = B[4]; assign n_34 = B[5]; assign n_35 = B[5]; assign n_36 = B[6]; assign n_37 = B[6]; assign n_38 = B[7]; assign n_39 = B[7]; assign n_40 = B[8]; assign n_41 = B[8]; assign n_42 = B[9]; assign n_43 = B[9]; assign n_44 = B[10]; assign n_45 = B[10]; assign n_46 = B[11]; assign n_47 = B[11]; assign n_56 = ~(n_44 | n_12 | n_6); assign n_57 = n_56; assign n_64 = n_57 & n_44; assign n_65 = n_64; assign n_66 = n_22 & n_28; assign n_82 = n_65; assign n_83 = n_82; assign n_92 = n_65; assign n_93 = n_92; assign n_134 = n_93; assign n_174 = n_22 & n_26; assign n_196 = ~n_65; assign n_208 = n_18 & n_134; assign n_209 = n_208; assign n_224 = n_209; assign n_240 = n_22 & n_28; assign n_241 = n_240; assign n_296 = n_18 & n_44; assign n_302 = n_20 & n_30; assign n_306 = n_22 & n_30; assign n_312 = n_209; assign n_313 = n_312; assign n_356 = n_16 & n_32; assign n_362 = n_18 & n_32; assign n_368 = n_20 & n_32; assign n_372 = n_22 & n_32; assign n_406 = n_313 & n_224; assign n_407 = n_406; assign n_422 = n_16 & n_34; assign n_428 = n_18 & n_34; assign n_432 = ~n_313; assign n_433 = n_432; assign n_434 = n_20 & n_34; assign n_440 = n_22 & n_34; assign n_464 = ~n_433; assign n_465 = n_464; assign n_478 = n_12 & n_36; assign n_484 = n_14 & n_36; assign n_488 = n_16 & n_36; assign n_494 = n_18 & n_36; assign n_500 = n_20 & n_36; assign n_506 = n_22 & n_36; assign n_544 = n_12 & n_38; assign n_550 = n_14 & n_38; assign n_556 = n_16 & n_38; assign n_560 = n_18 & n_38; assign n_566 = n_20 & n_38; assign n_572 = n_22 & n_38; assign n_594 = ~(n_65 & n_208); assign n_595 = n_594; assign n_600 = n_8 & n_40; assign n_601 = n_600; assign n_606 = n_10 & n_40; assign n_608 = n_65; assign n_609 = n_608; assign n_610 = n_12 & n_40; assign n_616 = n_14 & n_40; assign n_622 = n_16 & n_40; assign n_628 = n_18 & n_40; assign n_632 = n_20 & n_40; assign n_638 = n_22 & n_40; assign n_640 = ~n_313; assign n_641 = n_640; assign n_660 = n_6 & n_42; assign n_666 = n_8 & n_42; assign n_672 = n_10 & n_42; assign n_676 = n_12 & n_42; assign n_682 = n_14 & n_42; assign n_688 = n_16 & n_42; assign n_694 = n_18 & n_42; assign n_698 = n_20 & n_42; assign n_704 = n_22 & n_42; assign n_722 = n_38 & n_302; assign n_726 = n_6 & n_44; assign n_732 = n_8 & n_44; assign n_738 = n_10 & n_44; assign n_744 = n_12 & n_44; assign n_748 = n_14 & n_44; assign n_752 = ~n_465; assign n_753 = n_752; assign n_754 = n_16 & n_44; assign n_760 = n_18 & n_44; assign n_766 = n_20 & n_44; assign n_770 = n_22 & n_44; assign n_782 = n_2 & n_46; assign n_783 = n_782; assign n_788 = n_4 & n_46; assign n_790 = n_407; assign n_792 = n_6 & n_46; assign n_798 = n_8 & n_46; assign n_804 = n_10 & n_46; assign n_810 = n_12 & n_46; assign n_814 = n_14 & n_46; assign n_820 = n_16 & n_46; assign n_826 = n_18 & n_46; assign n_832 = n_20 & n_46; assign n_838 = n_22 & n_46; assign n_882 = n_92; assign n_883 = n_882; assign n_904 = n_609; assign n_905 = n_904; assign n_908 = n_174; assign n_932 = ~n_641; assign n_958 = n_296 & n_356; assign n_959 = n_958; FAX1 tmp164(.YS(n_964), .YC(n_965), .A(n_302), .B(n_362), .C(n_422)); FAX1 tmp165(.YS(n_970), .YC(n_971), .A(n_306), .B(n_368), .C(n_428)); assign n_976 = n_372 & n_434; HAX1 tmp167(.YS(n_980), .YC(n_981), .A(n_372), .B(n_434)); FAX1 tmp168(.YS(n_1014), .YC(n_1015), .A(n_478), .B(n_882), .C(n_601)); FAX1 tmp169(.YS(n_1020), .YC(n_1021), .A(n_484), .B(n_544), .C(n_606)); FAX1 tmp170(.YS(n_1024), .YC(n_1025), .A(n_488), .B(n_550), .C(n_610)); FAX1 tmp171(.YS(n_1030), .YC(n_1031), .A(n_494), .B(n_556), .C(n_616)); FAX1 tmp172(.YS(n_1036), .YC(n_1037), .A(n_500), .B(n_560), .C(n_622)); FAX1 tmp173(.YS(n_1042), .YC(n_1043), .A(n_506), .B(n_566), .C(n_628)); assign n_1048 = n_572 & n_632; HAX1 tmp175(.YS(n_1052), .YC(n_1053), .A(n_572), .B(n_632)); FAX1 tmp176(.YS(n_1070), .YC(n_1071), .A(n_660), .B(n_722), .C(n_783)); FAX1 tmp177(.YS(n_1074), .YC(n_1075), .A(n_666), .B(n_726), .C(n_788)); FAX1 tmp178(.YS(n_1080), .YC(n_1081), .A(n_672), .B(n_732), .C(n_792)); FAX1 tmp179(.YS(n_1086), .YC(n_1087), .A(n_676), .B(n_738), .C(n_798)); FAX1 tmp180(.YS(n_1092), .YC(n_1093), .A(n_682), .B(n_744), .C(n_804)); FAX1 tmp181(.YS(n_1096), .YC(n_1097), .A(n_688), .B(n_748), .C(n_810)); FAX1 tmp182(.YS(n_1102), .YC(n_1103), .A(n_694), .B(n_754), .C(n_814)); FAX1 tmp183(.YS(n_1108), .YC(n_1109), .A(n_698), .B(n_760), .C(n_820)); FAX1 tmp184(.YS(n_1114), .YC(n_1115), .A(n_704), .B(n_766), .C(n_826)); assign n_1118 = n_770 & n_832; HAX1 tmp186(.YS(n_1124), .YC(n_1125), .A(n_770), .B(n_832)); assign n_1186 = n_908; FAX1 tmp188(.YS(n_1190), .YC(n_1191), .A(n_241), .B(n_82), .C(n_964)); FAX1 tmp189(.YS(n_1234), .YC(n_1235), .A(n_959), .B(n_1020), .C(n_1015)); FAX1 tmp190(.YS(n_1240), .YC(n_1241), .A(n_965), .B(n_1024), .C(n_1021)); FAX1 tmp191(.YS(n_1246), .YC(n_1247), .A(n_971), .B(n_1030), .C(n_1025)); FAX1 tmp192(.YS(n_1252), .YC(n_1253), .A(n_976), .B(n_1036), .C(n_1031)); assign n_1256 = n_1042 & n_1037; HAX1 tmp194(.YS(n_1262), .YC(n_1263), .A(n_1042), .B(n_1037)); assign n_1268 = n_1052 & n_1043; HAX1 tmp196(.YS(n_1274), .YC(n_1275), .A(n_1052), .B(n_1043)); assign n_1280 = n_433 & n_1048; assign n_1284 = n_638 ^ n_1048; FAX1 tmp199(.YS(n_1340), .YC(n_1341), .A(n_1186), .B(n_66), .C(n_595)); FAX1 tmp200(.YS(n_1346), .YC(n_1347), .A(n_1190), .B(n_224), .C(n_1234)); FAX1 tmp201(.YS(n_1350), .YC(n_1351), .A(n_970), .B(n_1191), .C(n_1240)); assign n_1356 = n_980 & n_1246; HAX1 tmp203(.YS(n_1362), .YC(n_1363), .A(n_980), .B(n_1246)); assign n_1368 = n_440 & n_1252; HAX1 tmp205(.YS(n_1372), .YC(n_1373), .A(n_440), .B(n_1252)); FAX1 tmp206(.YS(n_1400), .YC(n_1401), .A(n_905), .B(n_1074), .C(n_1071)); FAX1 tmp207(.YS(n_1406), .YC(n_1407), .A(n_1235), .B(n_1080), .C(n_1075)); FAX1 tmp208(.YS(n_1412), .YC(n_1413), .A(n_1241), .B(n_1086), .C(n_1081)); FAX1 tmp209(.YS(n_1418), .YC(n_1419), .A(n_1247), .B(n_1092), .C(n_1087)); FAX1 tmp210(.YS(n_1422), .YC(n_1423), .A(n_1253), .B(n_1096), .C(n_1093)); FAX1 tmp211(.YS(n_1428), .YC(n_1429), .A(n_1256), .B(n_1102), .C(n_1097)); FAX1 tmp212(.YS(n_1434), .YC(n_1435), .A(n_1268), .B(n_1108), .C(n_1103)); FAX1 tmp213(.YS(n_1440), .YC(n_1441), .A(n_1280), .B(n_1114), .C(n_1109)); assign n_1444 = n_1124 & n_1115; HAX1 tmp215(.YS(n_1450), .YC(n_1451), .A(n_1124), .B(n_1115)); assign n_1456 = n_838 & n_1118; HAX1 tmp217(.YS(n_1462), .YC(n_1463), .A(n_838), .B(n_1118)); assign n_1472 = ~n_753; assign n_1473 = n_1472; assign n_1506 = ~n_753; assign n_1512 = n_1340 | n_790; assign n_1513 = n_1512; FAX1 tmp223(.YS(n_1516), .YC(n_1517), .A(n_1346), .B(n_1341), .C(n_1400)); FAX1 tmp224(.YS(n_1522), .YC(n_1523), .A(n_1350), .B(n_1347), .C(n_1406)); FAX1 tmp225(.YS(n_1528), .YC(n_1529), .A(n_1362), .B(n_1351), .C(n_1412)); FAX1 tmp226(.YS(n_1534), .YC(n_1535), .A(n_1372), .B(n_1356), .C(n_1418)); FAX1 tmp227(.YS(n_1538), .YC(n_1539), .A(n_1262), .B(n_1368), .C(n_1422)); assign n_1544 = n_1274 & n_1428; HAX1 tmp229(.YS(n_1550), .YC(n_1551), .A(n_1274), .B(n_1428)); assign n_1556 = n_1284 & n_1434; assign n_1560 = n_1284 ^ n_1434; assign n_1600 = n_1506; assign n_1606 = ~(n_18 & n_932); assign n_1607 = n_1606; HAX1 tmp235(.YS(n_1610), .YC(n_1611), .A(n_1516), .B(n_1513)); FAX1 tmp236(.YS(n_1616), .YC(n_1617), .A(n_1522), .B(n_1517), .C(n_1401)); FAX1 tmp237(.YS(n_1622), .YC(n_1623), .A(n_1528), .B(n_1523), .C(n_1407)); FAX1 tmp238(.YS(n_1628), .YC(n_1629), .A(n_1534), .B(n_1529), .C(n_1413)); FAX1 tmp239(.YS(n_1632), .YC(n_1633), .A(n_1538), .B(n_1535), .C(n_1419)); FAX1 tmp240(.YS(n_1638), .YC(n_1639), .A(n_1550), .B(n_1539), .C(n_1423)); FAX1 tmp241(.YS(n_1644), .YC(n_1645), .A(n_1560), .B(n_1544), .C(n_1429)); FAX1 tmp242(.YS(n_1650), .YC(n_1651), .A(n_1440), .B(n_1556), .C(n_1435)); assign n_1654 = n_1450 & n_1441; HAX1 tmp244(.YS(n_1660), .YC(n_1661), .A(n_1450), .B(n_1441)); assign n_1666 = n_1462 & n_1444; HAX1 tmp246(.YS(n_1672), .YC(n_1673), .A(n_1462), .B(n_1444)); assign n_1682 = n_465; assign n_1732 = ~n_1600; assign n_1776 = ~n_465; assign n_1777 = n_1776; assign n_1788 = n_1732; assign n_1792 = ~n_65; FAX1 tmp253(.YS(n_1838), .YC(n_1839), .A(n_1610), .B(n_1607), .C(n_641)); FAX1 tmp254(.YS(n_1842), .YC(n_1843), .A(n_1616), .B(n_1611), .C(n_1839)); FAX1 tmp255(.YS(n_1848), .YC(n_1849), .A(n_1622), .B(n_1617), .C(n_1843)); assign n_1854 = ~n_1777; assign n_1860 = n_313 | n_1838; assign n_1864 = n_753 & n_1842; assign n_1870 = n_1473 | n_1848; MUX2X1 tmp260(.Y(n_1876), .A(n_313), .B(n_1849), .S(n_1792)); HAX1 tmp261(.YS(n_1882), .YC(n_1883), .A(n_1628), .B(n_1623)); FAX1 tmp262(.YS(n_1886), .YC(n_1887), .A(n_1632), .B(n_1629), .C(n_1883)); FAX1 tmp263(.YS(n_1892), .YC(n_1893), .A(n_1638), .B(n_1633), .C(n_1887)); FAX1 tmp264(.YS(n_1898), .YC(n_1899), .A(n_1644), .B(n_1639), .C(n_1893)); HAX1 tmp265(.YS(n_1904), .YC(n_1905), .A(n_1628), .B(n_1623)); assign n_1908 = ~n_1904; assign n_1914 = n_1905 | n_1904; FAX1 tmp268(.YS(n_1920), .YC(n_1921), .A(n_1632), .B(n_1629), .C(n_1914)); FAX1 tmp269(.YS(n_1926), .YC(n_1927), .A(n_1638), .B(n_1633), .C(n_1921)); FAX1 tmp270(.YS(n_1930), .YC(n_1931), .A(n_1644), .B(n_1639), .C(n_1927)); MUX2X1 tmp271(.Y(n_1936), .A(n_1882), .B(n_1908), .S(n_1876)); assign n_1937 = n_1936; MUX2X1 tmp273(.Y(n_1942), .A(n_1886), .B(n_1920), .S(n_1876)); MUX2X1 tmp274(.Y(n_1948), .A(n_1892), .B(n_1926), .S(n_1876)); MUX2X1 tmp275(.Y(n_1954), .A(n_1898), .B(n_1930), .S(n_1876)); MUX2X1 tmp276(.Y(n_1958), .A(n_1899), .B(n_1931), .S(n_1876)); HAX1 tmp277(.YS(n_1964), .YC(n_1965), .A(n_1650), .B(n_1645)); FAX1 tmp278(.YS(n_1970), .YC(n_1971), .A(n_1660), .B(n_1651), .C(n_1965)); FAX1 tmp279(.YS(n_1976), .YC(n_1977), .A(n_1672), .B(n_1654), .C(n_1971)); FAX1 tmp280(.YS(n_1980), .YC(n_1981), .A(n_1456), .B(n_1666), .C(n_1977)); HAX1 tmp281(.YS(n_1986), .YC(n_1987), .A(n_1650), .B(n_1645)); assign n_1992 = ~n_1986; assign n_1998 = n_1987 | n_1986; FAX1 tmp284(.YS(n_2002), .YC(n_2003), .A(n_1660), .B(n_1651), .C(n_1998)); FAX1 tmp285(.YS(n_2008), .YC(n_2009), .A(n_1672), .B(n_1654), .C(n_2003)); FAX1 tmp286(.YS(n_2014), .YC(n_2015), .A(n_1456), .B(n_1666), .C(n_2009)); MUX2X1 tmp287(.Y(n_2020), .A(n_1964), .B(n_1992), .S(n_1958)); MUX2X1 tmp288(.Y(n_2024), .A(n_1970), .B(n_2002), .S(n_1958)); MUX2X1 tmp289(.Y(n_2030), .A(n_1976), .B(n_2008), .S(n_1958)); MUX2X1 tmp290(.Y(n_2036), .A(n_1980), .B(n_2014), .S(n_1958)); assign O[0] = n_2; assign O[1] = n_406; assign O[2] = n_883; assign O[3] = n_224; assign O[4] = n_26; assign O[5] = n_1682; assign O[6] = n_2015; assign O[7] = n_196; assign O[8] = n_753; assign O[9] = n_12; assign O[10] = n_83; assign O[11] = n_1788; assign O[12] = n_1854; assign O[13] = n_1860; assign O[14] = n_1864; assign O[15] = n_1870; assign O[16] = n_1937; assign O[17] = n_1942; assign O[18] = n_1948; assign O[19] = n_1954; assign O[20] = n_2020; assign O[21] = n_2024; assign O[22] = n_2030; assign O[23] = n_2036; endmodule