// Library = EvoApprox 12x12 // Circuit = mul12x12_169 // Area (45) = 522 // Delay (45) = 1.470 // Power (45) = 0.30 // MAE = 31963.50000 // MSE = 1612559256.20000 // MRE = 11.03 % // WCE = 166719 // WCRE = 1811300 % // EP = 100.0 % module mul12x12_169(A, B, O); input [11:0] A, B; output [23:0] O; wire n_251, n_250, n_1365, n_1364, n_1196, n_1197, n_1946, n_45, n_44, n_47; wire n_46, n_41, n_40, n_43, n_42, n_1040, n_1041, n_49, n_48, n_1594; wire n_1966, n_1284, n_1810, n_389, n_388, n_1819, n_1818, n_2014, n_1742, n_1899; wire n_1560, n_1446, n_2006, n_1568, n_1055, n_1054, n_1189, n_1188, n_1426, n_1872; wire n_240, n_241, n_1352, n_1353, n_30, n_31, n_32, n_33, n_34, n_35; wire n_36, n_37, n_38, n_39, n_1756, n_1211, n_1210, n_2040, n_1048, n_1290; wire n_1049, n_2000, n_1114, n_2007, n_1873, n_662, n_1864, n_1865, n_1514, n_1515; wire n_668, n_1438, n_231, n_230, n_1345, n_1344, n_23, n_22, n_21, n_20; wire n_27, n_26, n_25, n_24, n_29, n_28, n_1736, n_1750, n_1972, n_1973; wire n_1202, n_1987, n_1203, n_1501, n_1500, n_893, n_892, n_1507, n_1506, n_899; wire n_898, n_1358, n_1879, n_1878, n_1799, n_1270, n_1811, n_1276, n_2020, n_1642; wire n_1643, n_18, n_19, n_16, n_17, n_14, n_15, n_12, n_13, n_10; wire n_11, n_96, n_97, n_1927, n_1918, n_1588, n_1919, n_1960, n_1825, n_1359; wire n_2026, n_587, n_586, n_1716, n_1710, n_1338, n_980, n_1649, n_1602, n_1657; wire n_1656, n_2015, n_1493, n_1492, n_81, n_80, n_1722, n_87, n_86, n_1967; wire n_1912, n_1913, n_1122, n_810, n_736, n_737, n_1992, n_1648, n_1859, n_1858; wire n_538, n_1520, n_105, n_104, n_1702, n_1986, n_1662, n_1663, n_1884, n_1668; wire n_1669, n_1432, n_1521, n_2034, n_110, n_111, n_1981, n_72, n_73, n_743; wire n_742, n_1798, n_1412, n_1134, n_1487, n_1790, n_1824, n_1418, n_1898, n_1952; wire n_1980, n_1264, n_1574, n_1486, n_1676, n_1677, n_960, n_1730, n_1128, n_966; wire n_1938, n_165, n_164, n_69, n_68, n_67, n_66, n_1932, n_1339, n_206; wire n_1831, n_1830, n_514, n_1785, n_1784, n_8, n_9, n_4, n_5, n_6; wire n_7, n_0, n_1, n_2, n_3, n_1892, n_1926, n_1580, n_972, n_1885; wire n_1804, n_1805, n_176, n_177, n_818, n_54, n_55, n_600, n_601; 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_48 = n_44 ^ n_44; assign n_49 = n_48; assign n_54 = n_14 & n_49; assign n_55 = n_54; assign n_66 = ~n_55; assign n_67 = n_66; FAX1 tmp65(.YS(n_68), .YC(n_69), .A(n_34), .B(n_54), .C(n_22)); assign n_72 = ~(n_49 & n_44); assign n_73 = n_72; assign n_80 = ~n_49; assign n_81 = n_80; assign n_86 = ~(n_55 & n_40); assign n_87 = n_86; assign n_96 = ~n_73; assign n_97 = n_96; assign n_104 = ~n_54; assign n_105 = n_104; assign n_110 = n_87 & n_40; assign n_111 = n_110; assign n_164 = ~n_81; assign n_165 = n_164; assign n_176 = ~n_105; assign n_177 = n_176; assign n_206 = ~n_49; assign n_230 = ~n_165; assign n_231 = n_230; assign n_240 = ~n_105; assign n_241 = n_240; assign n_250 = ~n_177; assign n_251 = n_250; assign n_388 = ~(n_165 & n_4); assign n_389 = n_388; MUX2X1 tmp91(.Y(n_514), .A(n_97), .B(n_30), .S(n_111)); assign n_538 = ~n_251; assign n_586 = ~(n_97 | n_176); assign n_587 = n_586; assign n_600 = ~n_105; assign n_601 = n_600; assign n_662 = n_389; assign n_668 = n_22 & n_32; assign n_736 = ~n_177; assign n_737 = n_736; HAX1 tmp101(.YS(n_742), .YC(n_743), .A(n_514), .B(n_662)); assign n_810 = n_18 & n_34; assign n_818 = n_20 & n_34; FAX1 tmp104(.YS(n_892), .YC(n_893), .A(n_742), .B(n_810), .C(n_737)); FAX1 tmp105(.YS(n_898), .YC(n_899), .A(n_668), .B(n_818), .C(n_743)); assign n_960 = n_16 & n_36; assign n_966 = n_18 & n_36; assign n_972 = n_20 & n_36; assign n_980 = n_22 & n_36; HAX1 tmp110(.YS(n_1040), .YC(n_1041), .A(n_892), .B(n_960)); FAX1 tmp111(.YS(n_1048), .YC(n_1049), .A(n_898), .B(n_966), .C(n_893)); FAX1 tmp112(.YS(n_1054), .YC(n_1055), .A(n_165), .B(n_972), .C(n_899)); assign n_1114 = n_16 & n_38; assign n_1122 = n_18 & n_38; assign n_1128 = n_20 & n_38; assign n_1134 = n_22 & n_38; assign n_1188 = n_1040 | n_810; assign n_1189 = n_1188; FAX1 tmp119(.YS(n_1196), .YC(n_1197), .A(n_1048), .B(n_1114), .C(n_1041)); FAX1 tmp120(.YS(n_1202), .YC(n_1203), .A(n_1054), .B(n_1122), .C(n_1049)); FAX1 tmp121(.YS(n_1210), .YC(n_1211), .A(n_980), .B(n_1128), .C(n_1055)); assign n_1264 = n_14 & n_40; assign n_1270 = n_16 & n_40; assign n_1276 = n_18 & n_40; assign n_1284 = n_20 & n_40; assign n_1290 = n_22 & n_40; assign n_1338 = n_69; assign n_1339 = n_1338; FAX1 tmp129(.YS(n_1344), .YC(n_1345), .A(n_1196), .B(n_1264), .C(n_1189)); FAX1 tmp130(.YS(n_1352), .YC(n_1353), .A(n_1202), .B(n_1270), .C(n_1197)); FAX1 tmp131(.YS(n_1358), .YC(n_1359), .A(n_1210), .B(n_1276), .C(n_1203)); FAX1 tmp132(.YS(n_1364), .YC(n_1365), .A(n_1134), .B(n_1284), .C(n_1211)); assign n_1412 = n_12 & n_42; assign n_1418 = n_14 & n_42; assign n_1426 = n_16 & n_42; assign n_1432 = n_18 & n_42; assign n_1438 = n_20 & n_42; assign n_1446 = n_22 & n_42; assign n_1486 = n_1338; assign n_1487 = n_1486; FAX1 tmp141(.YS(n_1492), .YC(n_1493), .A(n_1344), .B(n_1412), .C(n_1339)); FAX1 tmp142(.YS(n_1500), .YC(n_1501), .A(n_1352), .B(n_1418), .C(n_1345)); FAX1 tmp143(.YS(n_1506), .YC(n_1507), .A(n_1358), .B(n_1426), .C(n_1353)); FAX1 tmp144(.YS(n_1514), .YC(n_1515), .A(n_1364), .B(n_1432), .C(n_1359)); FAX1 tmp145(.YS(n_1520), .YC(n_1521), .A(n_1290), .B(n_1438), .C(n_1365)); assign n_1560 = n_10 & n_44; assign n_1568 = n_12 & n_44; assign n_1574 = n_14 & n_44; assign n_1580 = n_16 & n_44; assign n_1588 = n_18 & n_44; assign n_1594 = n_20 & n_44; assign n_1602 = n_22 & n_44; FAX1 tmp153(.YS(n_1642), .YC(n_1643), .A(n_1492), .B(n_1560), .C(n_1487)); FAX1 tmp154(.YS(n_1648), .YC(n_1649), .A(n_1500), .B(n_1568), .C(n_1493)); FAX1 tmp155(.YS(n_1656), .YC(n_1657), .A(n_1506), .B(n_1574), .C(n_1501)); FAX1 tmp156(.YS(n_1662), .YC(n_1663), .A(n_1514), .B(n_1580), .C(n_1507)); FAX1 tmp157(.YS(n_1668), .YC(n_1669), .A(n_1520), .B(n_1588), .C(n_1515)); FAX1 tmp158(.YS(n_1676), .YC(n_1677), .A(n_1446), .B(n_1594), .C(n_1521)); assign n_1702 = n_6 & n_46; assign n_1710 = n_8 & n_46; assign n_1716 = n_10 & n_46; assign n_1722 = n_12 & n_46; assign n_1730 = n_14 & n_46; assign n_1736 = n_16 & n_46; assign n_1742 = n_18 & n_46; assign n_1750 = n_20 & n_46; assign n_1756 = n_22 & n_46; assign n_1784 = n_601 | n_1702; assign n_1785 = n_1784; assign n_1790 = n_1642 & n_1710; FAX1 tmp171(.YS(n_1798), .YC(n_1799), .A(n_1648), .B(n_1716), .C(n_1643)); FAX1 tmp172(.YS(n_1804), .YC(n_1805), .A(n_1656), .B(n_1722), .C(n_1649)); FAX1 tmp173(.YS(n_1810), .YC(n_1811), .A(n_1662), .B(n_1730), .C(n_1657)); FAX1 tmp174(.YS(n_1818), .YC(n_1819), .A(n_1668), .B(n_1736), .C(n_1663)); FAX1 tmp175(.YS(n_1824), .YC(n_1825), .A(n_1676), .B(n_1742), .C(n_1669)); FAX1 tmp176(.YS(n_1830), .YC(n_1831), .A(n_1602), .B(n_1750), .C(n_1677)); HAX1 tmp177(.YS(n_1858), .YC(n_1859), .A(n_1790), .B(n_1785)); HAX1 tmp178(.YS(n_1864), .YC(n_1865), .A(n_1798), .B(n_1446)); FAX1 tmp179(.YS(n_1872), .YC(n_1873), .A(n_1804), .B(n_1799), .C(n_1865)); FAX1 tmp180(.YS(n_1878), .YC(n_1879), .A(n_1810), .B(n_1805), .C(n_1873)); FAX1 tmp181(.YS(n_1884), .YC(n_1885), .A(n_1818), .B(n_1811), .C(n_1879)); assign n_1892 = ~n_241; assign n_1898 = ~n_1892; assign n_1899 = n_1898; FAX1 tmp185(.YS(n_1912), .YC(n_1913), .A(n_1804), .B(n_1799), .C(n_67)); FAX1 tmp186(.YS(n_1918), .YC(n_1919), .A(n_1810), .B(n_1805), .C(n_1913)); FAX1 tmp187(.YS(n_1926), .YC(n_1927), .A(n_1818), .B(n_1811), .C(n_1919)); MUX2X1 tmp188(.Y(n_1932), .A(n_1864), .B(n_1898), .S(n_1859)); MUX2X1 tmp189(.Y(n_1938), .A(n_1872), .B(n_1912), .S(n_1859)); MUX2X1 tmp190(.Y(n_1946), .A(n_1878), .B(n_1918), .S(n_1859)); MUX2X1 tmp191(.Y(n_1952), .A(n_1884), .B(n_1926), .S(n_1859)); MUX2X1 tmp192(.Y(n_1960), .A(n_1885), .B(n_1927), .S(n_1859)); HAX1 tmp193(.YS(n_1966), .YC(n_1967), .A(n_1824), .B(n_1819)); FAX1 tmp194(.YS(n_1972), .YC(n_1973), .A(n_1830), .B(n_1825), .C(n_1967)); FAX1 tmp195(.YS(n_1980), .YC(n_1981), .A(n_1756), .B(n_1831), .C(n_1973)); HAX1 tmp196(.YS(n_1986), .YC(n_1987), .A(n_1824), .B(n_1819)); assign n_1992 = ~n_1986; assign n_2000 = n_1987 | n_1986; FAX1 tmp199(.YS(n_2006), .YC(n_2007), .A(n_1830), .B(n_1825), .C(n_2000)); FAX1 tmp200(.YS(n_2014), .YC(n_2015), .A(n_1756), .B(n_1831), .C(n_2007)); MUX2X1 tmp201(.Y(n_2020), .A(n_1966), .B(n_1992), .S(n_1960)); MUX2X1 tmp202(.Y(n_2026), .A(n_1972), .B(n_2006), .S(n_1960)); MUX2X1 tmp203(.Y(n_2034), .A(n_1980), .B(n_2014), .S(n_1960)); MUX2X1 tmp204(.Y(n_2040), .A(n_1981), .B(n_2015), .S(n_1960)); assign O[0] = n_18; assign O[1] = n_662; assign O[2] = n_1899; assign O[3] = n_600; assign O[4] = n_26; assign O[5] = n_538; assign O[6] = n_231; assign O[7] = n_1892; assign O[8] = n_177; assign O[9] = n_206; assign O[10] = n_587; assign O[11] = n_32; assign O[12] = n_10; assign O[13] = n_36; assign O[14] = n_231; assign O[15] = n_1858; assign O[16] = n_1932; assign O[17] = n_1938; assign O[18] = n_1946; assign O[19] = n_1952; assign O[20] = n_2020; assign O[21] = n_2026; assign O[22] = n_2034; assign O[23] = n_2040; endmodule