// Library = EvoApprox 12x12 // Circuit = mul12x12_099 // Area (45) = 687 // Delay (45) = 1.960 // Power (45) = 0.48 // MAE = 7819.60000 // MSE = 92112567.20000 // MRE = 8.36 % // WCE = 32742 // WCRE = 2336000 % // EP = 100.0 % module mul12x12_099(A, B, O); input [11:0] A, B; output [23:0] O; wire n_946, n_1418, n_1365, n_1364, n_1196, n_1197, n_1102, n_1540, n_1270, n_45; wire n_44, n_47, n_46, n_41, n_40, n_43, n_42, n_1040, n_824, n_1202; wire n_1203, n_1594, n_1966, n_1284, n_1810, n_1353, n_1818, n_2014, n_1210, n_1825; wire n_1560, n_1134, n_1446, n_2006, n_1554, n_1568, n_1628, n_952, n_1054, n_1041; wire n_1188, n_1622, n_1623, n_1426, n_1506, n_712, n_713, n_1183, n_1182, n_30; wire n_31, n_32, n_33, n_34, n_35, n_36, n_37, n_38, n_39, n_1756; wire n_1211, n_1108, n_589, n_1048, n_2034, n_1290, n_1049, n_898, n_1114, n_2007; wire n_1873, n_662, n_1864, n_1656, n_1799, n_1514, n_1515, n_1453, n_1452, n_668; wire n_1784, n_433, n_432, n_1776, n_1865, n_1026, n_1027, n_1635, n_1634, n_293; wire n_1872, n_1345, n_1344, n_23, n_22, n_21, n_20, n_27, n_26, n_25; wire n_24, n_29, n_28, n_1736, n_804, n_1973, n_1987, n_1501, n_1500, n_893; wire n_892, n_128, n_552, n_553, n_899, n_656, n_1878, n_1879, n_6, n_1742; wire n_122, n_1629, n_7, n_1035, n_1034, n_1696, n_1811, n_1406, n_1276, n_1189; wire n_1481, n_2021, n_2020, n_1642, n_1643, n_18, n_19, n_16, n_17, n_14; wire n_15, n_12, n_13, n_10, n_11, n_1358, n_1480, n_1980, n_1927, n_1893; wire n_648, n_1844, n_1845, n_884, n_526, n_134, n_135, n_1819, n_1359, n_2026; wire n_1716, n_352, n_1338, n_581, n_580, n_196, n_980, n_1176, n_358, n_588; wire n_1602, n_1657, n_1177, n_1981, n_2015, n_1493, n_1492, n_1438, n_1722, n_1918; wire n_1919, n_89, n_88, n_1912, n_1913, n_1122, n_810, n_736, n_737, n_730; wire n_731, n_1859, n_1858, n_1952, n_1521, n_1331, n_1853, n_1852, n_105, n_104; wire n_1884, n_1250, n_1548, n_1256, n_1946, n_70, n_1986, n_617, n_616, n_1649; wire n_1507, n_1662, n_1663, n_697, n_696, n_1094, n_1668, n_1669, n_1432, n_1960; wire n_114, n_115, n_1520, n_2040, n_1398, n_1648, n_1906, n_118, n_292, n_743; wire n_742, n_1798, n_1412, n_211, n_210, n_506, n_1487, n_1790, n_1791, n_1824; wire n_500, n_1898, n_277, n_276, n_2000, n_1702, n_1264, n_1967, n_1574, n_1055; wire n_1486, n_1777, n_1710, n_1676, n_1677, n_960, n_1730, n_1128, n_966, n_1938; wire n_1750, n_65, n_64, n_1339, n_60, n_202, n_1972, n_1831, n_1830, n_514; wire n_1785, n_885, n_8, n_9, n_4, n_5, n_303, n_302, n_0, n_1; wire n_2, n_3, n_1892, n_1926, n_1352, n_1580, n_1992, n_972, n_1885, n_879; wire n_878, n_1804, n_1805, n_174, n_818, n_52, n_53, n_50, n_54, n_55; wire n_1330, n_1932; 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_50 = ~(n_2 | n_28); assign n_52 = ~(n_2 & n_50); assign n_53 = n_52; assign n_54 = ~n_53; assign n_55 = n_54; assign n_60 = n_2 & n_28; assign n_64 = n_2 & n_54; assign n_65 = n_64; assign n_70 = ~(n_10 | n_52); assign n_88 = ~n_65; assign n_89 = n_88; assign n_104 = ~(n_70 | n_54); assign n_105 = n_104; assign n_114 = ~n_105; assign n_115 = n_114; assign n_118 = n_44 & n_18; assign n_122 = n_22 & n_60; assign n_128 = ~n_65; assign n_134 = ~(n_55 | n_128); assign n_135 = n_134; assign n_174 = n_42; assign n_196 = n_18 & n_26; assign n_202 = n_22 & n_26; assign n_210 = ~n_53; assign n_211 = n_210; assign n_276 = n_122 & n_196; assign n_277 = n_276; assign n_292 = n_10; assign n_293 = n_292; assign n_302 = n_293 & n_174; assign n_303 = n_302; assign n_352 = n_20 & n_28; assign n_358 = n_22 & n_28; FAX1 tmp92(.YS(n_432), .YC(n_433), .A(n_202), .B(n_352), .C(n_277)); assign n_500 = n_18 & n_30; assign n_506 = n_20 & n_30; assign n_514 = n_22 & n_30; assign n_526 = ~n_135; assign n_552 = n_105; assign n_553 = n_552; assign n_580 = n_432 & n_500; assign n_581 = n_580; FAX1 tmp101(.YS(n_588), .YC(n_589), .A(n_358), .B(n_506), .C(n_433)); assign n_616 = ~(n_553 & n_526); assign n_617 = n_616; assign n_648 = n_16 & n_32; assign n_656 = n_18 & n_32; assign n_662 = n_20 & n_32; assign n_668 = n_22 & n_32; assign n_696 = n_34; assign n_697 = n_696; assign n_712 = n_89; assign n_713 = n_712; assign n_730 = n_211 | n_648; assign n_731 = n_730; FAX1 tmp114(.YS(n_736), .YC(n_737), .A(n_588), .B(n_656), .C(n_581)); FAX1 tmp115(.YS(n_742), .YC(n_743), .A(n_514), .B(n_662), .C(n_589)); assign n_804 = n_16 & n_34; assign n_810 = n_18 & n_34; assign n_818 = n_20 & n_34; assign n_824 = n_22 & n_34; assign n_878 = ~n_617; assign n_879 = n_878; FAX1 tmp122(.YS(n_884), .YC(n_885), .A(n_736), .B(n_804), .C(n_731)); FAX1 tmp123(.YS(n_892), .YC(n_893), .A(n_742), .B(n_810), .C(n_737)); FAX1 tmp124(.YS(n_898), .YC(n_899), .A(n_668), .B(n_818), .C(n_743)); assign n_946 = n_12 & n_36; assign n_952 = n_14 & n_36; 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; MUX2X1 tmp131(.Y(n_1026), .A(n_55), .B(n_946), .S(n_697)); assign n_1027 = n_1026; FAX1 tmp133(.YS(n_1034), .YC(n_1035), .A(n_884), .B(n_952), .C(n_879)); FAX1 tmp134(.YS(n_1040), .YC(n_1041), .A(n_892), .B(n_960), .C(n_885)); FAX1 tmp135(.YS(n_1048), .YC(n_1049), .A(n_898), .B(n_966), .C(n_893)); FAX1 tmp136(.YS(n_1054), .YC(n_1055), .A(n_824), .B(n_972), .C(n_899)); assign n_1094 = n_303 & n_38; assign n_1102 = n_12 & n_38; assign n_1108 = n_14 & n_38; 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_1176 = n_553 & n_1094; assign n_1177 = n_1176; FAX1 tmp146(.YS(n_1182), .YC(n_1183), .A(n_1034), .B(n_1102), .C(n_1027)); FAX1 tmp147(.YS(n_1188), .YC(n_1189), .A(n_1040), .B(n_1108), .C(n_1035)); FAX1 tmp148(.YS(n_1196), .YC(n_1197), .A(n_1048), .B(n_1114), .C(n_1041)); FAX1 tmp149(.YS(n_1202), .YC(n_1203), .A(n_1054), .B(n_1122), .C(n_1049)); FAX1 tmp150(.YS(n_1210), .YC(n_1211), .A(n_980), .B(n_1128), .C(n_1055)); assign n_1250 = n_10 & n_40; assign n_1256 = n_12 & n_40; 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; FAX1 tmp158(.YS(n_1330), .YC(n_1331), .A(n_1182), .B(n_1250), .C(n_1177)); FAX1 tmp159(.YS(n_1338), .YC(n_1339), .A(n_1188), .B(n_1256), .C(n_1183)); FAX1 tmp160(.YS(n_1344), .YC(n_1345), .A(n_1196), .B(n_1264), .C(n_1189)); FAX1 tmp161(.YS(n_1352), .YC(n_1353), .A(n_1202), .B(n_1270), .C(n_1197)); FAX1 tmp162(.YS(n_1358), .YC(n_1359), .A(n_1210), .B(n_1276), .C(n_1203)); FAX1 tmp163(.YS(n_1364), .YC(n_1365), .A(n_1134), .B(n_1284), .C(n_1211)); assign n_1398 = n_8 & n_42; assign n_1406 = n_10 & n_42; 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_1452 = ~n_617; assign n_1453 = n_1452; HAX1 tmp174(.YS(n_1480), .YC(n_1481), .A(n_1330), .B(n_1398)); FAX1 tmp175(.YS(n_1486), .YC(n_1487), .A(n_1338), .B(n_1406), .C(n_1331)); FAX1 tmp176(.YS(n_1492), .YC(n_1493), .A(n_1344), .B(n_1412), .C(n_1339)); FAX1 tmp177(.YS(n_1500), .YC(n_1501), .A(n_1352), .B(n_1418), .C(n_1345)); FAX1 tmp178(.YS(n_1506), .YC(n_1507), .A(n_1358), .B(n_1426), .C(n_1353)); FAX1 tmp179(.YS(n_1514), .YC(n_1515), .A(n_1364), .B(n_1432), .C(n_1359)); FAX1 tmp180(.YS(n_1520), .YC(n_1521), .A(n_1290), .B(n_1438), .C(n_1365)); assign n_1540 = n_4 & n_44; assign n_1548 = n_6 & n_44; assign n_1554 = n_8 & n_44; 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_1594 = n_20 & n_44; assign n_1602 = n_22 & n_44; assign n_1622 = n_105 & n_1540; assign n_1623 = n_1622; FAX1 tmp192(.YS(n_1628), .YC(n_1629), .A(n_1480), .B(n_1548), .C(n_879)); FAX1 tmp193(.YS(n_1634), .YC(n_1635), .A(n_1486), .B(n_1554), .C(n_1481)); FAX1 tmp194(.YS(n_1642), .YC(n_1643), .A(n_1492), .B(n_1560), .C(n_1487)); FAX1 tmp195(.YS(n_1648), .YC(n_1649), .A(n_1500), .B(n_1568), .C(n_1493)); FAX1 tmp196(.YS(n_1656), .YC(n_1657), .A(n_1506), .B(n_1574), .C(n_1501)); FAX1 tmp197(.YS(n_1662), .YC(n_1663), .A(n_1514), .B(n_1580), .C(n_1507)); FAX1 tmp198(.YS(n_1668), .YC(n_1669), .A(n_1520), .B(n_118), .C(n_1515)); FAX1 tmp199(.YS(n_1676), .YC(n_1677), .A(n_1446), .B(n_1594), .C(n_1521)); assign n_1696 = n_4 & n_46; 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; FAX1 tmp210(.YS(n_1776), .YC(n_1777), .A(n_1628), .B(n_1696), .C(n_1623)); FAX1 tmp211(.YS(n_1784), .YC(n_1785), .A(n_1634), .B(n_1702), .C(n_1629)); FAX1 tmp212(.YS(n_1790), .YC(n_1791), .A(n_1642), .B(n_1710), .C(n_1635)); FAX1 tmp213(.YS(n_1798), .YC(n_1799), .A(n_1648), .B(n_1716), .C(n_1643)); FAX1 tmp214(.YS(n_1804), .YC(n_1805), .A(n_1656), .B(n_1722), .C(n_1649)); FAX1 tmp215(.YS(n_1810), .YC(n_1811), .A(n_1662), .B(n_1730), .C(n_1657)); FAX1 tmp216(.YS(n_1818), .YC(n_1819), .A(n_1668), .B(n_1736), .C(n_1663)); FAX1 tmp217(.YS(n_1824), .YC(n_1825), .A(n_1676), .B(n_1742), .C(n_1669)); FAX1 tmp218(.YS(n_1830), .YC(n_1831), .A(n_1602), .B(n_1750), .C(n_1677)); assign n_1844 = ~n_713; assign n_1845 = n_1844; HAX1 tmp221(.YS(n_1852), .YC(n_1853), .A(n_1784), .B(n_1777)); FAX1 tmp222(.YS(n_1858), .YC(n_1859), .A(n_1790), .B(n_1785), .C(n_1853)); HAX1 tmp223(.YS(n_1864), .YC(n_1865), .A(n_1798), .B(n_1791)); FAX1 tmp224(.YS(n_1872), .YC(n_1873), .A(n_1804), .B(n_1799), .C(n_1865)); FAX1 tmp225(.YS(n_1878), .YC(n_1879), .A(n_1810), .B(n_1805), .C(n_1873)); FAX1 tmp226(.YS(n_1884), .YC(n_1885), .A(n_1818), .B(n_1811), .C(n_1879)); HAX1 tmp227(.YS(n_1892), .YC(n_1893), .A(n_1798), .B(n_1791)); assign n_1898 = ~n_1892; assign n_1906 = n_1893 | n_1892; FAX1 tmp230(.YS(n_1912), .YC(n_1913), .A(n_1804), .B(n_1799), .C(n_1906)); FAX1 tmp231(.YS(n_1918), .YC(n_1919), .A(n_1810), .B(n_1805), .C(n_1913)); FAX1 tmp232(.YS(n_1926), .YC(n_1927), .A(n_1818), .B(n_1811), .C(n_1919)); MUX2X1 tmp233(.Y(n_1932), .A(n_1864), .B(n_1898), .S(n_1859)); MUX2X1 tmp234(.Y(n_1938), .A(n_1872), .B(n_1912), .S(n_1859)); MUX2X1 tmp235(.Y(n_1946), .A(n_1878), .B(n_1918), .S(n_1859)); MUX2X1 tmp236(.Y(n_1952), .A(n_1884), .B(n_1926), .S(n_1859)); MUX2X1 tmp237(.Y(n_1960), .A(n_1885), .B(n_1927), .S(n_1859)); HAX1 tmp238(.YS(n_1966), .YC(n_1967), .A(n_1824), .B(n_1819)); FAX1 tmp239(.YS(n_1972), .YC(n_1973), .A(n_1830), .B(n_1825), .C(n_1967)); FAX1 tmp240(.YS(n_1980), .YC(n_1981), .A(n_1756), .B(n_1831), .C(n_1973)); HAX1 tmp241(.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 tmp244(.YS(n_2006), .YC(n_2007), .A(n_1830), .B(n_1825), .C(n_2000)); FAX1 tmp245(.YS(n_2014), .YC(n_2015), .A(n_1756), .B(n_1831), .C(n_2007)); MUX2X1 tmp246(.Y(n_2020), .A(n_1966), .B(n_1992), .S(n_1960)); assign n_2021 = n_2020; MUX2X1 tmp248(.Y(n_2026), .A(n_1972), .B(n_2006), .S(n_1960)); MUX2X1 tmp249(.Y(n_2034), .A(n_1980), .B(n_2014), .S(n_1960)); MUX2X1 tmp250(.Y(n_2040), .A(n_1981), .B(n_2015), .S(n_1960)); assign O[0] = n_105; assign O[1] = n_44; assign O[2] = n_6; assign O[3] = n_616; assign O[4] = n_1845; assign O[5] = n_36; assign O[6] = n_879; assign O[7] = n_8; assign O[8] = n_713; assign O[9] = n_1452; assign O[10] = n_115; assign O[11] = n_712; assign O[12] = n_1453; assign O[13] = n_1844; assign O[14] = n_1852; 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_2021; assign O[21] = n_2026; assign O[22] = n_2034; assign O[23] = n_2040; endmodule