// Library = EvoApprox 12x12 // Circuit = mul12x12_013 // Area (45) = 1145 // Delay (45) = 2.640 // Power (45) = 0.83 // MAE = 847.40000 // MSE = 1111890.00000 // MRE = 0.31 % // WCE = 4138 // WCRE = 57500 % // EP = 99.9 % module mul12x12_013(A, B, O); input [11:0] A, B; output [23:0] O; wire n_1192, n_1750, n_1758, n_1612, n_1200, n_1142, n_1817, n_1816, n_1684, n_1685; wire n_894, n_1105, n_1104, n_1295, n_1294, n_156, n_1866, n_1867, n_728, n_231; wire n_230, n_720, n_1206, n_2032, n_2033, n_554, n_126, n_120, n_1033, n_1032; wire n_1402, n_1969, n_1968, n_18, n_19, n_16, n_17, n_14, n_15, n_12; wire n_13, n_10, n_11, n_880, n_888, n_1532, n_1714, n_1084, n_902, n_1337; wire n_1497, n_1496, n_1323, n_1322, n_1916, n_88, n_1910, n_1149, n_1148, n_1662; wire n_1663, n_1262, n_1143, n_1263, n_1394, n_1983, n_1982, n_1822, n_1823, n_562; wire n_953, n_286, n_287, n_301, n_300, n_794, n_795, n_947, n_946, n_1366; wire n_1946, n_45, n_44, n_47, n_46, n_41, n_40, n_43, n_42, n_1040; wire n_866, n_1894, n_996, n_460, n_461, n_997, n_1562, n_468, n_469, n_1446; wire n_1447, n_453, n_1568, n_1626, n_1627, n_1620, n_1621, n_1214, n_1742, n_1693; wire n_1692, n_1134, n_1135, n_1874, n_1511, n_635, n_634, n_2027, n_2026, n_648; wire n_649, n_526, n_642, n_643, n_132, n_133, n_822, n_823, n_983, n_982; wire n_1554, n_452, n_1000, n_1001, n_991, n_736, n_1250, n_1700, n_1706, n_1258; wire n_1991, n_910, n_858, n_1316, n_1317, n_1902, n_1416, n_1598, n_1410, n_1794; wire n_1795, n_1170, n_1171, n_1772, n_1679, n_1678, n_1778, n_1670, n_1388, n_1380; wire n_1831, n_1830, n_1837, n_1836, n_706, n_700, n_380, n_2018, n_2019, n_388; wire n_2010, n_2011, n_778, n_779, n_952, n_1054, n_1358, n_1424, n_408, n_409; wire n_30, n_31, n_32, n_33, n_34, n_35, n_36, n_37, n_38, n_39; wire n_1584, n_817, n_816, n_1048, n_787, n_1510, n_786, n_1952, n_1453, n_1452; wire n_1518, n_1519, n_1635, n_1634, n_1228, n_922, n_1220, n_1736, n_1590, n_1642; wire n_1643, n_1127, n_1126, n_1648, n_1120, n_1844, n_1845, n_626, n_627, n_192; wire n_621, n_1961, n_1960, n_532, n_1121, n_534, n_535, n_1649, n_366, n_446; wire n_1540, n_692, n_2041, n_2040, n_214, n_1301, n_1300, n_1309, n_1308, n_969; wire n_968, n_1068, n_961, n_960, n_1062, n_1938, n_1932, n_61, n_60, n_1460; wire n_1461, n_990, n_1671, n_1468, n_1469, n_1787, n_1786, n_1163, n_1162, n_8; wire n_9, n_4, n_5, n_6, n_7, n_0, n_1, n_2, n_3, n_1764; wire n_1604, n_1800, n_1801, n_1808, n_1809, n_1242, n_548, n_540, n_1491, n_1990; wire n_1112, n_1113, n_1286, n_1287, n_714, n_620, n_193, n_2005, n_2004, n_1345; wire n_1432, n_23, n_22, n_21, n_20, n_27, n_26, n_25, n_24, n_1974; wire n_1975, n_29, n_28, n_1505, n_1504, n_1490, n_329, n_328, n_1236, n_1728; wire n_1482, n_1483, n_1336, n_1720, n_1330, n_1331, n_89, n_1657, n_1656, n_1156; wire n_1157, n_1996, n_1997, n_1859, n_1858, n_1853, n_1852, n_612, n_1344, n_116; wire n_117, n_112, n_295, n_294, n_808, n_809, n_505, n_504, n_277, n_276; wire n_374, n_279, n_278, n_1576, n_800, n_1548, n_801, n_200, n_206, n_1279; wire n_1278, n_1374, n_447, n_1924, n_1888, n_874, n_1076, n_1880, n_974, n_975; wire n_50, n_51, n_475, n_474, n_1475, n_1474; 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_42 | n_40 | n_10); assign n_51 = n_50; assign n_60 = ~(n_42 & n_46 & n_51); assign n_61 = n_60; assign n_88 = ~n_60; assign n_89 = n_88; assign n_112 = n_18 & n_24; assign n_116 = n_61; assign n_117 = n_116; assign n_120 = n_20 & n_28; assign n_126 = n_22 & n_24; assign n_132 = n_89; assign n_133 = n_132; assign n_156 = n_133; assign n_192 = n_16 & n_26; assign n_193 = n_192; assign n_200 = n_18 & n_26; assign n_206 = n_20 & n_26; assign n_214 = n_22 & n_26; assign n_230 = ~n_133; assign n_231 = n_230; assign n_276 = ~n_61; assign n_277 = n_276; FAX1 tmp82(.YS(n_278), .YC(n_279), .A(n_112), .B(n_192), .C(n_193)); FAX1 tmp83(.YS(n_286), .YC(n_287), .A(n_120), .B(n_200), .C(n_193)); FAX1 tmp84(.YS(n_294), .YC(n_295), .A(n_126), .B(n_206), .C(n_287)); HAX1 tmp85(.YS(n_300), .YC(n_301), .A(n_295), .B(n_214)); assign n_328 = n_156; assign n_329 = n_328; assign n_366 = n_16 & n_28; assign n_374 = n_18 & n_28; assign n_380 = n_20 & n_28; assign n_388 = n_22 & n_28; assign n_408 = n_329; assign n_409 = n_408; MUX2X1 tmp94(.Y(n_446), .A(n_278), .B(n_328), .S(n_329)); assign n_447 = n_446; FAX1 tmp96(.YS(n_452), .YC(n_453), .A(n_286), .B(n_366), .C(n_447)); FAX1 tmp97(.YS(n_460), .YC(n_461), .A(n_294), .B(n_374), .C(n_453)); FAX1 tmp98(.YS(n_468), .YC(n_469), .A(n_300), .B(n_380), .C(n_461)); FAX1 tmp99(.YS(n_474), .YC(n_475), .A(n_301), .B(n_388), .C(n_469)); assign n_504 = n_6 & n_30; assign n_505 = n_504; assign n_526 = n_12 & n_30; assign n_532 = n_14 & n_30; assign n_534 = ~n_277; assign n_535 = n_534; assign n_540 = n_16 & n_30; assign n_548 = n_18 & n_30; assign n_554 = n_20 & n_30; assign n_562 = n_22 & n_30; assign n_612 = n_409 | n_526; HAX1 tmp111(.YS(n_620), .YC(n_621), .A(n_452), .B(n_532)); FAX1 tmp112(.YS(n_626), .YC(n_627), .A(n_460), .B(n_540), .C(n_621)); FAX1 tmp113(.YS(n_634), .YC(n_635), .A(n_468), .B(n_548), .C(n_627)); FAX1 tmp114(.YS(n_642), .YC(n_643), .A(n_474), .B(n_554), .C(n_635)); FAX1 tmp115(.YS(n_648), .YC(n_649), .A(n_475), .B(n_562), .C(n_643)); assign n_692 = n_10 & n_32; assign n_700 = n_12 & n_32; assign n_706 = n_14 & n_32; assign n_714 = n_16 & n_32; assign n_720 = n_18 & n_32; assign n_728 = n_20 & n_32; assign n_736 = n_22 & n_32; FAX1 tmp123(.YS(n_778), .YC(n_779), .A(n_612), .B(n_692), .C(n_505)); FAX1 tmp124(.YS(n_786), .YC(n_787), .A(n_620), .B(n_700), .C(n_779)); FAX1 tmp125(.YS(n_794), .YC(n_795), .A(n_626), .B(n_706), .C(n_787)); FAX1 tmp126(.YS(n_800), .YC(n_801), .A(n_634), .B(n_714), .C(n_795)); FAX1 tmp127(.YS(n_808), .YC(n_809), .A(n_642), .B(n_720), .C(n_801)); FAX1 tmp128(.YS(n_816), .YC(n_817), .A(n_648), .B(n_728), .C(n_809)); FAX1 tmp129(.YS(n_822), .YC(n_823), .A(n_649), .B(n_736), .C(n_817)); assign n_858 = n_8 & n_34; assign n_866 = n_10 & n_34; assign n_874 = n_12 & n_34; assign n_880 = n_14 & n_34; assign n_888 = n_16 & n_34; assign n_894 = n_18 & n_34; assign n_902 = n_20 & n_34; assign n_910 = n_22 & n_34; assign n_922 = ~n_535; HAX1 tmp139(.YS(n_946), .YC(n_947), .A(n_231), .B(n_858)); FAX1 tmp140(.YS(n_952), .YC(n_953), .A(n_786), .B(n_866), .C(n_947)); FAX1 tmp141(.YS(n_960), .YC(n_961), .A(n_794), .B(n_874), .C(n_953)); FAX1 tmp142(.YS(n_968), .YC(n_969), .A(n_800), .B(n_880), .C(n_961)); FAX1 tmp143(.YS(n_974), .YC(n_975), .A(n_808), .B(n_888), .C(n_969)); FAX1 tmp144(.YS(n_982), .YC(n_983), .A(n_816), .B(n_894), .C(n_975)); FAX1 tmp145(.YS(n_990), .YC(n_991), .A(n_822), .B(n_902), .C(n_983)); FAX1 tmp146(.YS(n_996), .YC(n_997), .A(n_823), .B(n_910), .C(n_991)); assign n_1000 = ~n_409; assign n_1001 = n_1000; assign n_1032 = n_8 & n_36; assign n_1033 = n_1032; assign n_1040 = n_10 & n_36; assign n_1048 = n_12 & n_36; assign n_1054 = n_14 & n_36; assign n_1062 = n_16 & n_36; assign n_1068 = n_18 & n_36; assign n_1076 = n_20 & n_36; assign n_1084 = n_22 & n_36; assign n_1104 = n_1001; assign n_1105 = n_1104; FAX1 tmp160(.YS(n_1112), .YC(n_1113), .A(n_946), .B(n_1054), .C(n_1105)); FAX1 tmp161(.YS(n_1120), .YC(n_1121), .A(n_952), .B(n_1032), .C(n_1113)); FAX1 tmp162(.YS(n_1126), .YC(n_1127), .A(n_960), .B(n_1040), .C(n_1121)); FAX1 tmp163(.YS(n_1134), .YC(n_1135), .A(n_968), .B(n_1048), .C(n_1127)); FAX1 tmp164(.YS(n_1142), .YC(n_1143), .A(n_974), .B(n_1054), .C(n_1135)); FAX1 tmp165(.YS(n_1148), .YC(n_1149), .A(n_982), .B(n_1062), .C(n_1143)); FAX1 tmp166(.YS(n_1156), .YC(n_1157), .A(n_990), .B(n_1068), .C(n_1149)); FAX1 tmp167(.YS(n_1162), .YC(n_1163), .A(n_996), .B(n_1076), .C(n_1157)); FAX1 tmp168(.YS(n_1170), .YC(n_1171), .A(n_997), .B(n_1084), .C(n_1163)); assign n_1192 = n_4 & n_38; assign n_1200 = n_6 & n_38; assign n_1206 = n_8 & n_38; assign n_1214 = n_10 & n_38; assign n_1220 = n_12 & n_38; assign n_1228 = n_14 & n_38; assign n_1236 = n_16 & n_38; assign n_1242 = n_18 & n_38; assign n_1250 = n_20 & n_38; assign n_1258 = n_22 & n_38; assign n_1262 = ~n_133; assign n_1263 = n_1262; HAX1 tmp181(.YS(n_1278), .YC(n_1279), .A(n_1112), .B(n_1192)); FAX1 tmp182(.YS(n_1286), .YC(n_1287), .A(n_1120), .B(n_1200), .C(n_1279)); FAX1 tmp183(.YS(n_1294), .YC(n_1295), .A(n_1126), .B(n_1206), .C(n_1287)); FAX1 tmp184(.YS(n_1300), .YC(n_1301), .A(n_1134), .B(n_1214), .C(n_1295)); FAX1 tmp185(.YS(n_1308), .YC(n_1309), .A(n_1142), .B(n_1220), .C(n_1301)); FAX1 tmp186(.YS(n_1316), .YC(n_1317), .A(n_1148), .B(n_1228), .C(n_1309)); FAX1 tmp187(.YS(n_1322), .YC(n_1323), .A(n_1156), .B(n_1236), .C(n_1317)); FAX1 tmp188(.YS(n_1330), .YC(n_1331), .A(n_1162), .B(n_1242), .C(n_1323)); FAX1 tmp189(.YS(n_1336), .YC(n_1337), .A(n_1170), .B(n_1250), .C(n_1331)); FAX1 tmp190(.YS(n_1344), .YC(n_1345), .A(n_1171), .B(n_1258), .C(n_1337)); assign n_1358 = n_2 & n_40; assign n_1366 = n_4 & n_40; assign n_1374 = n_6 & n_40; assign n_1380 = n_8 & n_40; assign n_1388 = n_10 & n_40; assign n_1394 = n_12 & n_40; assign n_1402 = n_14 & n_40; assign n_1410 = n_16 & n_40; assign n_1416 = n_18 & n_40; assign n_1424 = n_20 & n_40; assign n_1432 = n_22 & n_40; assign n_1446 = n_1278 & n_1358; assign n_1447 = n_1446; FAX1 tmp204(.YS(n_1452), .YC(n_1453), .A(n_1286), .B(n_1366), .C(n_1447)); FAX1 tmp205(.YS(n_1460), .YC(n_1461), .A(n_1294), .B(n_1374), .C(n_1453)); FAX1 tmp206(.YS(n_1468), .YC(n_1469), .A(n_1300), .B(n_1380), .C(n_1461)); FAX1 tmp207(.YS(n_1474), .YC(n_1475), .A(n_1308), .B(n_1388), .C(n_1469)); FAX1 tmp208(.YS(n_1482), .YC(n_1483), .A(n_1316), .B(n_1394), .C(n_1475)); FAX1 tmp209(.YS(n_1490), .YC(n_1491), .A(n_1322), .B(n_1402), .C(n_1483)); FAX1 tmp210(.YS(n_1496), .YC(n_1497), .A(n_1330), .B(n_1410), .C(n_1491)); FAX1 tmp211(.YS(n_1504), .YC(n_1505), .A(n_1336), .B(n_1416), .C(n_1497)); FAX1 tmp212(.YS(n_1510), .YC(n_1511), .A(n_1344), .B(n_1424), .C(n_1505)); FAX1 tmp213(.YS(n_1518), .YC(n_1519), .A(n_1345), .B(n_1432), .C(n_1511)); assign n_1532 = n_2 & n_42; assign n_1540 = n_4 & n_42; assign n_1548 = n_6 & n_42; assign n_1554 = n_8 & n_42; assign n_1562 = n_10 & n_42; assign n_1568 = n_12 & n_42; assign n_1576 = n_14 & n_42; assign n_1584 = n_16 & n_42; assign n_1590 = n_18 & n_42; assign n_1598 = n_20 & n_42; assign n_1604 = n_22 & n_42; assign n_1612 = n_117; HAX1 tmp226(.YS(n_1620), .YC(n_1621), .A(n_1033), .B(n_1532)); FAX1 tmp227(.YS(n_1626), .YC(n_1627), .A(n_1460), .B(n_1540), .C(n_1621)); FAX1 tmp228(.YS(n_1634), .YC(n_1635), .A(n_1468), .B(n_1548), .C(n_1627)); FAX1 tmp229(.YS(n_1642), .YC(n_1643), .A(n_1474), .B(n_1554), .C(n_1635)); FAX1 tmp230(.YS(n_1648), .YC(n_1649), .A(n_1482), .B(n_1562), .C(n_1643)); FAX1 tmp231(.YS(n_1656), .YC(n_1657), .A(n_1490), .B(n_1568), .C(n_1649)); FAX1 tmp232(.YS(n_1662), .YC(n_1663), .A(n_1496), .B(n_1576), .C(n_1657)); FAX1 tmp233(.YS(n_1670), .YC(n_1671), .A(n_1504), .B(n_1584), .C(n_1663)); FAX1 tmp234(.YS(n_1678), .YC(n_1679), .A(n_1510), .B(n_1590), .C(n_1671)); FAX1 tmp235(.YS(n_1684), .YC(n_1685), .A(n_1518), .B(n_1598), .C(n_1679)); FAX1 tmp236(.YS(n_1692), .YC(n_1693), .A(n_1519), .B(n_1604), .C(n_1685)); assign n_1700 = n_0 & n_44; assign n_1706 = n_2 & n_44; assign n_1714 = n_4 & n_44; assign n_1720 = n_6 & n_44; assign n_1728 = n_8 & n_44; assign n_1736 = n_10 & n_44; assign n_1742 = n_12 & n_44; assign n_1750 = n_14 & n_44; assign n_1758 = n_16 & n_44; assign n_1764 = n_18 & n_44; assign n_1772 = n_20 & n_44; assign n_1778 = n_22 & n_44; HAX1 tmp249(.YS(n_1786), .YC(n_1787), .A(n_1620), .B(n_1700)); FAX1 tmp250(.YS(n_1794), .YC(n_1795), .A(n_1626), .B(n_1706), .C(n_1787)); FAX1 tmp251(.YS(n_1800), .YC(n_1801), .A(n_1634), .B(n_1714), .C(n_1795)); FAX1 tmp252(.YS(n_1808), .YC(n_1809), .A(n_1642), .B(n_1720), .C(n_1801)); FAX1 tmp253(.YS(n_1816), .YC(n_1817), .A(n_1648), .B(n_1728), .C(n_1809)); FAX1 tmp254(.YS(n_1822), .YC(n_1823), .A(n_1656), .B(n_1736), .C(n_1817)); FAX1 tmp255(.YS(n_1830), .YC(n_1831), .A(n_1662), .B(n_1742), .C(n_1823)); FAX1 tmp256(.YS(n_1836), .YC(n_1837), .A(n_1670), .B(n_1750), .C(n_1831)); FAX1 tmp257(.YS(n_1844), .YC(n_1845), .A(n_1678), .B(n_1758), .C(n_1837)); FAX1 tmp258(.YS(n_1852), .YC(n_1853), .A(n_1684), .B(n_1764), .C(n_1845)); FAX1 tmp259(.YS(n_1858), .YC(n_1859), .A(n_1692), .B(n_1772), .C(n_1853)); FAX1 tmp260(.YS(n_1866), .YC(n_1867), .A(n_1693), .B(n_1778), .C(n_1859)); assign n_1874 = n_0 & n_46; assign n_1880 = n_2 & n_46; assign n_1888 = n_4 & n_46; assign n_1894 = n_6 & n_46; assign n_1902 = n_8 & n_46; assign n_1910 = n_10 & n_46; assign n_1916 = n_12 & n_46; assign n_1924 = n_14 & n_46; assign n_1932 = n_16 & n_46; assign n_1938 = n_18 & n_46; assign n_1946 = n_20 & n_46; assign n_1952 = n_22 & n_46; HAX1 tmp273(.YS(n_1960), .YC(n_1961), .A(n_1794), .B(n_1874)); FAX1 tmp274(.YS(n_1968), .YC(n_1969), .A(n_1800), .B(n_1880), .C(n_1961)); FAX1 tmp275(.YS(n_1974), .YC(n_1975), .A(n_1808), .B(n_1888), .C(n_1969)); FAX1 tmp276(.YS(n_1982), .YC(n_1983), .A(n_1816), .B(n_1894), .C(n_1975)); FAX1 tmp277(.YS(n_1990), .YC(n_1991), .A(n_1822), .B(n_1902), .C(n_1983)); FAX1 tmp278(.YS(n_1996), .YC(n_1997), .A(n_1830), .B(n_1910), .C(n_1991)); FAX1 tmp279(.YS(n_2004), .YC(n_2005), .A(n_1836), .B(n_1916), .C(n_1997)); FAX1 tmp280(.YS(n_2010), .YC(n_2011), .A(n_1844), .B(n_1924), .C(n_2005)); FAX1 tmp281(.YS(n_2018), .YC(n_2019), .A(n_1852), .B(n_1932), .C(n_2011)); FAX1 tmp282(.YS(n_2026), .YC(n_2027), .A(n_1858), .B(n_1938), .C(n_2019)); FAX1 tmp283(.YS(n_2032), .YC(n_2033), .A(n_1866), .B(n_1946), .C(n_2027)); FAX1 tmp284(.YS(n_2040), .YC(n_2041), .A(n_1867), .B(n_1952), .C(n_2033)); assign O[0] = n_649; assign O[1] = n_28; assign O[2] = n_475; assign O[3] = n_1416; assign O[4] = n_1621; assign O[5] = n_922; assign O[6] = n_1263; assign O[7] = n_1220; assign O[8] = n_34; assign O[9] = n_1612; assign O[10] = n_1786; assign O[11] = n_1960; assign O[12] = n_1968; assign O[13] = n_1974; assign O[14] = n_1982; assign O[15] = n_1990; assign O[16] = n_1996; assign O[17] = n_2004; assign O[18] = n_2010; assign O[19] = n_2018; assign O[20] = n_2026; assign O[21] = n_2032; assign O[22] = n_2040; assign O[23] = n_2041; endmodule