// Library = EvoApprox 12x12 // Circuit = mul12x12_167 // Area (45) = 475 // Delay (45) = 1.160 // Power (45) = 0.25 // MAE = 42682.40000 // MSE = 2678090029.80000 // MRE = 44.95 % // WCE = 166585 // WCRE = 11264700 % // EP = 100.0 % module mul12x12_167(A, B, O); input [11:0] A, B; output [23:0] O; wire n_942, n_1198, n_1199, n_706, n_316, n_1190, n_948, n_45, n_44, n_47; wire n_46, n_41, n_40, n_43, n_42, n_864, n_1204, n_788, n_1895, n_1894; wire n_1286, n_1280, n_1281, n_2016, n_2017, n_1682, n_1683, n_1562, n_1446, n_1440; wire n_1441, n_776, n_2009, n_1626, n_1555, n_954, n_718, n_2008, n_1185, n_1184; wire n_712, n_30, n_31, n_32, n_33, n_34, n_35, n_36, n_37, n_38; wire n_39, n_1191, n_1211, n_1210, n_1295, n_1294, n_1953, n_1275, n_152, n_153; wire n_1888, n_1510, n_1511, n_664, n_665, n_1453, n_494, n_2003, n_1868, n_1869; wire n_1633, n_1632, n_2002, n_1274, n_1435, n_1434, n_1639, n_782, n_724, n_23; wire n_22, n_21, n_20, n_27, n_26, n_25, n_24, n_29, n_28, n_1970; wire n_928, n_1875, n_1874, n_425, n_657, n_656, n_654, n_6, n_7, n_1230; wire n_424, n_634, n_1554, n_936, n_2022, n_1644, n_1645, n_570, n_18, n_19; wire n_16, n_17, n_14, n_15, n_12, n_13, n_10, n_11, n_2023, n_1926; wire n_2029, n_648, n_884, n_136, n_137, n_642, n_135, n_1889, n_1338, n_1901; wire n_1248, n_1249, n_1676, n_1651, n_1650, n_1082, n_1083, n_1659, n_1658, n_2028; wire n_1900, n_1912, n_1913, n_1881, n_1996, n_1997, n_109, n_108, n_730, n_1990; wire n_1991, n_1952, n_1120, n_1638, n_1255, n_1254, n_1574, n_1664, n_852, n_916; wire n_858, n_2034, n_2041, n_2040, n_2035, n_1906, n_70, n_808, n_1798, n_1799; wire n_1778, n_1792, n_500, n_277, n_276, n_1268, n_1269, n_564, n_922, n_279; wire n_278, n_1262, n_1263, n_846, n_847, n_1627, n_1772, n_1773, n_1452, n_960; wire n_800, n_1671, n_1670, n_169, n_66, n_1339, n_752, n_753, n_1460, n_1466; wire n_1467, n_1581, n_1787, n_1786, n_8, n_9, n_578, n_4, n_5, n_303; wire n_302, n_0, n_1, n_2, n_3, n_1927, n_872, n_1767, n_1766, n_1761; wire n_1760, n_1580, n_1920, n_1126, n_878, n_1880, n_134, n_794, n_54, n_55; wire n_1472, n_168, n_1479, n_1478; 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_54 = ~(n_14 | n_36 | n_10); assign n_55 = n_54; assign n_66 = n_55 & n_36; OAI21X1 tmp62(.Y(n_70), .A(n_26), .B(n_24), .C(n_66)); assign n_108 = n_34 & n_66; assign n_109 = n_108; assign n_134 = n_109; assign n_135 = n_134; assign n_136 = ~(n_34 | n_70); assign n_137 = n_136; assign n_152 = ~n_137; assign n_153 = n_152; assign n_168 = ~(n_137 | n_70); assign n_169 = n_168; assign n_276 = ~n_153; assign n_277 = n_276; assign n_278 = n_169; assign n_279 = n_278; assign n_302 = n_169; assign n_303 = n_302; assign n_316 = ~n_109; assign n_424 = n_22 & n_32; assign n_425 = n_424; assign n_494 = n_20 & n_34; assign n_500 = n_22 & n_34; assign n_564 = n_18 & n_36; assign n_570 = n_20 & n_36; assign n_578 = n_22 & n_36; assign n_634 = n_16 & n_38; assign n_642 = n_18 & n_38; assign n_648 = n_20 & n_38; assign n_654 = n_22 & n_38; assign n_656 = ~n_169; assign n_657 = n_656; assign n_664 = ~n_169; assign n_665 = n_664; assign n_706 = n_14 & n_40; assign n_712 = n_16 & n_40; assign n_718 = n_18 & n_40; assign n_724 = n_20 & n_40; assign n_730 = n_22 & n_40; assign n_752 = n_665; assign n_753 = n_752; assign n_776 = n_12 & n_42; assign n_782 = n_14 & n_42; assign n_788 = n_16 & n_42; assign n_794 = n_18 & n_42; assign n_800 = n_20 & n_42; assign n_808 = n_22 & n_42; assign n_846 = n_10 & n_44; assign n_847 = n_846; assign n_852 = n_12 & n_44; assign n_858 = n_14 & n_44; assign n_864 = n_16 & n_44; assign n_872 = n_18 & n_44; assign n_878 = n_20 & n_44; assign n_884 = n_22 & n_44; assign n_916 = n_8 & n_46; assign n_922 = n_10 & n_46; assign n_928 = n_12 & n_46; assign n_936 = n_14 & n_46; assign n_942 = n_16 & n_46; assign n_948 = n_18 & n_46; assign n_954 = n_20 & n_46; assign n_960 = n_22 & n_46; assign n_1082 = ~n_316; assign n_1083 = n_1082; assign n_1120 = n_425 & n_494; assign n_1126 = n_424 | n_494; FAX1 tmp128(.YS(n_1184), .YC(n_1185), .A(n_564), .B(n_634), .C(n_706)); FAX1 tmp129(.YS(n_1190), .YC(n_1191), .A(n_570), .B(n_642), .C(n_712)); FAX1 tmp130(.YS(n_1198), .YC(n_1199), .A(n_578), .B(n_648), .C(n_718)); assign n_1204 = n_654 & n_724; HAX1 tmp132(.YS(n_1210), .YC(n_1211), .A(n_654), .B(n_724)); assign n_1230 = ~n_135; FAX1 tmp134(.YS(n_1248), .YC(n_1249), .A(n_776), .B(n_846), .C(n_916)); FAX1 tmp135(.YS(n_1254), .YC(n_1255), .A(n_782), .B(n_852), .C(n_922)); FAX1 tmp136(.YS(n_1262), .YC(n_1263), .A(n_788), .B(n_858), .C(n_928)); FAX1 tmp137(.YS(n_1268), .YC(n_1269), .A(n_794), .B(n_864), .C(n_936)); FAX1 tmp138(.YS(n_1274), .YC(n_1275), .A(n_800), .B(n_872), .C(n_942)); FAX1 tmp139(.YS(n_1280), .YC(n_1281), .A(n_808), .B(n_878), .C(n_948)); assign n_1286 = n_884 & n_954; HAX1 tmp141(.YS(n_1294), .YC(n_1295), .A(n_884), .B(n_954)); assign n_1338 = ~n_303; assign n_1339 = n_1338; HAX1 tmp144(.YS(n_1434), .YC(n_1435), .A(n_1185), .B(n_1184)); FAX1 tmp145(.YS(n_1440), .YC(n_1441), .A(n_1120), .B(n_1190), .C(n_1185)); assign n_1446 = n_1198 & n_1191; HAX1 tmp147(.YS(n_1452), .YC(n_1453), .A(n_1198), .B(n_1191)); assign n_1460 = n_1210 & n_1199; HAX1 tmp149(.YS(n_1466), .YC(n_1467), .A(n_1210), .B(n_1199)); assign n_1472 = n_153 & n_1204; HAX1 tmp151(.YS(n_1478), .YC(n_1479), .A(n_730), .B(n_1204)); assign n_1510 = n_279; assign n_1511 = n_1510; assign n_1554 = n_135; assign n_1555 = n_1554; assign n_1562 = n_1126 & n_1434; assign n_1574 = n_500 & n_1440; HAX1 tmp158(.YS(n_1580), .YC(n_1581), .A(n_500), .B(n_1574)); HAX1 tmp159(.YS(n_1626), .YC(n_1627), .A(n_847), .B(n_1248)); FAX1 tmp160(.YS(n_1632), .YC(n_1633), .A(n_1435), .B(n_1254), .C(n_1249)); FAX1 tmp161(.YS(n_1638), .YC(n_1639), .A(n_1441), .B(n_1262), .C(n_1255)); FAX1 tmp162(.YS(n_1644), .YC(n_1645), .A(n_1446), .B(n_1268), .C(n_1263)); FAX1 tmp163(.YS(n_1650), .YC(n_1651), .A(n_1460), .B(n_1274), .C(n_1269)); FAX1 tmp164(.YS(n_1658), .YC(n_1659), .A(n_1472), .B(n_1280), .C(n_1275)); assign n_1664 = n_1294 & n_1281; HAX1 tmp166(.YS(n_1670), .YC(n_1671), .A(n_1294), .B(n_1281)); assign n_1676 = n_753 & n_1286; HAX1 tmp168(.YS(n_1682), .YC(n_1683), .A(n_960), .B(n_1286)); FAX1 tmp169(.YS(n_1760), .YC(n_1761), .A(n_1249), .B(n_1555), .C(n_1626)); FAX1 tmp170(.YS(n_1766), .YC(n_1767), .A(n_1580), .B(n_1562), .C(n_1632)); FAX1 tmp171(.YS(n_1772), .YC(n_1773), .A(n_1452), .B(n_1574), .C(n_1638)); assign n_1778 = n_1466 & n_1644; HAX1 tmp173(.YS(n_1786), .YC(n_1787), .A(n_1466), .B(n_1644)); assign n_1792 = n_1478 & n_1650; HAX1 tmp175(.YS(n_1798), .YC(n_1799), .A(n_1478), .B(n_1650)); FAX1 tmp176(.YS(n_1868), .YC(n_1869), .A(n_1760), .B(n_1230), .C(n_1339)); FAX1 tmp177(.YS(n_1874), .YC(n_1875), .A(n_1766), .B(n_1761), .C(n_1627)); FAX1 tmp178(.YS(n_1880), .YC(n_1881), .A(n_1772), .B(n_1767), .C(n_1633)); FAX1 tmp179(.YS(n_1888), .YC(n_1889), .A(n_1786), .B(n_1773), .C(n_1639)); FAX1 tmp180(.YS(n_1894), .YC(n_1895), .A(n_1798), .B(n_1778), .C(n_1645)); FAX1 tmp181(.YS(n_1900), .YC(n_1901), .A(n_1658), .B(n_1792), .C(n_1651)); assign n_1906 = n_1670 & n_1659; HAX1 tmp183(.YS(n_1912), .YC(n_1913), .A(n_1670), .B(n_1659)); assign n_1920 = n_1682 & n_1664; HAX1 tmp185(.YS(n_1926), .YC(n_1927), .A(n_1682), .B(n_1664)); assign n_1952 = ~n_657; assign n_1953 = n_1952; assign n_1970 = n_657; HAX1 tmp189(.YS(n_1990), .YC(n_1991), .A(n_1868), .B(n_664)); FAX1 tmp190(.YS(n_1996), .YC(n_1997), .A(n_1874), .B(n_1869), .C(n_1991)); FAX1 tmp191(.YS(n_2002), .YC(n_2003), .A(n_1880), .B(n_1875), .C(n_1997)); FAX1 tmp192(.YS(n_2008), .YC(n_2009), .A(n_1888), .B(n_1881), .C(n_2003)); FAX1 tmp193(.YS(n_2016), .YC(n_2017), .A(n_1894), .B(n_1889), .C(n_2009)); FAX1 tmp194(.YS(n_2022), .YC(n_2023), .A(n_1900), .B(n_1895), .C(n_2017)); FAX1 tmp195(.YS(n_2028), .YC(n_2029), .A(n_1912), .B(n_1901), .C(n_2023)); FAX1 tmp196(.YS(n_2034), .YC(n_2035), .A(n_1926), .B(n_1906), .C(n_2029)); FAX1 tmp197(.YS(n_2040), .YC(n_2041), .A(n_1676), .B(n_1920), .C(n_2035)); assign O[0] = n_1953; assign O[1] = n_278; assign O[2] = n_1083; assign O[3] = n_0; assign O[4] = n_277; assign O[5] = n_66; assign O[6] = n_135; assign O[7] = n_276; assign O[8] = n_137; assign O[9] = n_1952; assign O[10] = n_6; assign O[11] = n_752; assign O[12] = n_1970; assign O[13] = n_1970; assign O[14] = n_1511; assign O[15] = n_1990; assign O[16] = n_1996; assign O[17] = n_2002; assign O[18] = n_2008; assign O[19] = n_2016; assign O[20] = n_2022; assign O[21] = n_2028; assign O[22] = n_2034; assign O[23] = n_2040; endmodule