// Library = EvoApprox 12x12 // Circuit = mul12x12_081 // Area (45) = 937 // Delay (45) = 2.230 // Power (45) = 0.68 // MAE = 3277.10000 // MSE = 16254469.30000 // MRE = 1.65 % // WCE = 16631 // WCRE = 396800 % // EP = 100.0 % module mul12x12_081(A, B, O); input [11:0] A, B; output [23:0] O; wire n_1196, n_1197, n_1750, n_1756, n_1757, n_1202, n_1614, n_1811, n_1810, n_1819; wire n_1818, n_1682, n_1688, n_1507, n_1506, n_486, n_1102, n_1108, n_1290, n_1864; wire n_1865, n_231, n_230, n_2034, n_1615, n_1203, n_656, n_122, n_344, n_1035; wire n_1034, n_426, n_427, n_1406, n_18, n_19, n_16, n_17, n_14, n_15; wire n_12, n_13, n_10, n_11, n_884, n_885, n_338, n_1242, n_1716, n_1710; wire n_1486, n_1487, n_1080, n_1325, n_1324, n_1088, n_1492, n_85, n_84, n_1918; wire n_1919, n_1912, n_1913, n_1330, n_1952, n_1662, n_1663, n_1668, n_1669, n_1392; wire n_1398, n_1987, n_1986, n_1981, n_1980, n_1824, n_1825, n_569, n_568, n_1055; wire n_1054, n_818, n_169, n_168, n_514, n_1580, n_1588, n_1365, n_1364, n_1946; wire n_419, n_418, n_45, n_44, n_47, n_46, n_41, n_40, n_43, n_42; wire n_1040, n_1041, n_49, n_48, n_1594, n_1560, n_1446, n_1554, n_1568, n_1189; wire n_1188, n_1622, n_1623, n_1628, n_1629, n_1183, n_1182, n_1211, n_1210, n_1696; wire n_1134, n_810, n_1873, n_1872, n_1879, n_1878, n_7, n_2020, n_2026, n_648; wire n_134, n_36, n_824, n_1006, n_980, n_358, n_723, n_736, n_737, n_730; wire n_731, n_722, n_1521, n_1520, n_1526, n_1250, n_1256, n_1318, n_1319, n_1094; wire n_1310, n_1311, n_74, n_1906, n_72, n_73, n_1798, n_1799, n_1790, n_1791; wire n_1418, n_1176, n_1177, n_1702, n_1776, n_1777, n_1770, n_1771, n_1677, n_1676; wire n_1384, n_1839, n_1838, n_1804, n_1831, n_1830, n_574, n_575, n_176, n_177; wire n_2014, n_2015, n_952, n_953, n_1358, n_1359, n_1426, n_1352, n_1353, n_30; wire n_31, n_32, n_33, n_34, n_35, n_790, n_37, n_38, n_39, n_798; wire n_1048, n_1049, n_1898, n_1514, n_1515, n_1452, n_492, n_1635, n_1634, n_1893; wire n_1892, n_1730, n_1736, n_1412, n_1642, n_1643, n_352, n_1128, n_1122, n_1648; wire n_1649, n_1844, n_1845, n_581, n_580, n_196, n_589, n_588, n_1960, n_1967; wire n_1966, n_102, n_105, n_104, n_1548, n_1540, n_2040, n_743, n_742, n_1305; wire n_1304, n_1264, n_960, n_966, n_1938, n_1932, n_61, n_60, n_1460, n_1461; wire n_1466, n_1467, n_1785, n_1784, n_1163, n_1162, n_8, n_9, n_4, n_5; wire n_1169, n_1168, n_0, n_1, n_2, n_3, n_1765, n_1764, n_1608, n_1609; wire n_1602, n_6, n_1805, n_1114, n_1284, n_1742, n_192, n_193, n_2000, n_2007; wire n_2006, n_662, n_663, n_668, n_433, n_432, n_1020, n_1026, n_1027, n_1345; wire n_1344, n_23, n_22, n_21, n_20, n_27, n_26, n_25, n_24, n_29; wire n_28, n_804, n_1973, n_1493, n_1501, n_1500, n_893, n_892, n_321, n_320; wire n_899, n_898, n_480, n_1236, n_1230, n_1480, n_1481, n_1338, n_1339, n_1722; wire n_938, n_1331, n_96, n_97, n_94, n_95, n_1927, n_90, n_1926, n_972; wire n_1657, n_1656, n_1156, n_1157, n_1438, n_1534, n_1992, n_1859, n_1858, n_1853; wire n_1852, n_1432, n_114, n_115, n_506, n_500, n_277, n_276, n_1574, n_202; wire n_1972, n_1270, n_1276, n_873, n_872, n_1884, n_1885, n_879, n_878, n_58; wire n_50, n_56, n_57, n_54, n_55, n_1473, n_1472; 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_28 | n_6); assign n_49 = n_48; assign n_50 = n_6 & n_32; OAI21X1 tmp62(.Y(n_54), .A(n_6), .B(n_44), .C(n_49)); assign n_55 = n_54; assign n_56 = n_44 | n_55; assign n_57 = n_56; assign n_58 = ~n_57; assign n_60 = n_34 & n_38; assign n_61 = n_60; assign n_72 = ~(n_44 ^ n_44); assign n_73 = n_72; assign n_74 = n_55 & n_58; assign n_84 = n_26 & n_50; assign n_85 = n_84; assign n_90 = ~n_57; assign n_94 = n_85 & n_36; assign n_95 = n_94; assign n_96 = ~n_57; assign n_97 = n_96; assign n_102 = n_85 & n_74; assign n_104 = ~(n_97 | n_54); assign n_105 = n_104; assign n_114 = n_95 & n_28; assign n_115 = n_114; assign n_122 = n_34 & n_24; assign n_134 = n_26 & n_122; assign n_168 = ~n_57; assign n_169 = n_168; assign n_176 = n_14 & n_134; assign n_177 = n_176; assign n_192 = ~(n_169 & n_44); assign n_193 = n_192; assign n_196 = n_177; assign n_202 = n_22 & n_26; assign n_230 = ~n_193; assign n_231 = n_230; assign n_276 = n_57 & n_196; assign n_277 = n_276; assign n_320 = ~n_169; assign n_321 = n_320; assign n_338 = n_16 & n_28; assign n_344 = n_18 & n_28; assign n_352 = n_20 & n_28; assign n_358 = n_22 & n_28; HAX1 tmp104(.YS(n_418), .YC(n_419), .A(n_231), .B(n_338)); FAX1 tmp105(.YS(n_426), .YC(n_427), .A(n_22), .B(n_344), .C(n_115)); FAX1 tmp106(.YS(n_432), .YC(n_433), .A(n_202), .B(n_352), .C(n_277)); assign n_480 = n_97 & n_102; assign n_486 = n_14 & n_30; assign n_492 = n_16 & n_30; assign n_500 = n_18 & n_30; assign n_506 = n_20 & n_30; assign n_514 = n_22 & n_30; assign n_568 = n_418 | n_486; assign n_569 = n_568; HAX1 tmp115(.YS(n_574), .YC(n_575), .A(n_426), .B(n_492)); FAX1 tmp116(.YS(n_580), .YC(n_581), .A(n_432), .B(n_500), .C(n_427)); FAX1 tmp117(.YS(n_588), .YC(n_589), .A(n_358), .B(n_506), .C(n_433)); assign n_648 = n_16 & n_32; assign n_656 = n_18 & n_32; assign n_662 = n_20 & n_32; assign n_663 = n_662; assign n_668 = n_22 & n_32; FAX1 tmp123(.YS(n_722), .YC(n_723), .A(n_574), .B(n_96), .C(n_569)); FAX1 tmp124(.YS(n_730), .YC(n_731), .A(n_580), .B(n_648), .C(n_575)); FAX1 tmp125(.YS(n_736), .YC(n_737), .A(n_588), .B(n_656), .C(n_581)); FAX1 tmp126(.YS(n_742), .YC(n_743), .A(n_514), .B(n_662), .C(n_589)); assign n_790 = n_12 & n_34; assign n_798 = n_14 & n_34; 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_872 = n_722 | n_790; assign n_873 = n_872; FAX1 tmp135(.YS(n_878), .YC(n_879), .A(n_730), .B(n_798), .C(n_723)); FAX1 tmp136(.YS(n_884), .YC(n_885), .A(n_736), .B(n_804), .C(n_731)); FAX1 tmp137(.YS(n_892), .YC(n_893), .A(n_742), .B(n_810), .C(n_737)); FAX1 tmp138(.YS(n_898), .YC(n_899), .A(n_668), .B(n_818), .C(n_743)); assign n_938 = n_10 & n_36; assign n_952 = n_14 & n_36; assign n_953 = n_952; 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; assign n_1006 = ~(n_105 & n_40); assign n_1020 = n_169 | n_938; FAX1 tmp148(.YS(n_1026), .YC(n_1027), .A(n_878), .B(n_480), .C(n_873)); FAX1 tmp149(.YS(n_1034), .YC(n_1035), .A(n_884), .B(n_952), .C(n_879)); FAX1 tmp150(.YS(n_1040), .YC(n_1041), .A(n_892), .B(n_960), .C(n_885)); FAX1 tmp151(.YS(n_1048), .YC(n_1049), .A(n_898), .B(n_966), .C(n_893)); FAX1 tmp152(.YS(n_1054), .YC(n_1055), .A(n_824), .B(n_972), .C(n_899)); assign n_1080 = n_953 & n_38; assign n_1088 = n_8 & n_38; assign n_1094 = n_10 & 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_1156 = n_1006; assign n_1157 = n_1156; assign n_1162 = n_61 | n_1080; assign n_1163 = n_1162; HAX1 tmp166(.YS(n_1168), .YC(n_1169), .A(n_1020), .B(n_1088)); HAX1 tmp167(.YS(n_1176), .YC(n_1177), .A(n_1026), .B(n_1094)); FAX1 tmp168(.YS(n_1182), .YC(n_1183), .A(n_1034), .B(n_1102), .C(n_1027)); FAX1 tmp169(.YS(n_1188), .YC(n_1189), .A(n_1040), .B(n_1108), .C(n_1035)); FAX1 tmp170(.YS(n_1196), .YC(n_1197), .A(n_1048), .B(n_1114), .C(n_1041)); FAX1 tmp171(.YS(n_1202), .YC(n_1203), .A(n_1054), .B(n_1122), .C(n_1049)); FAX1 tmp172(.YS(n_1210), .YC(n_1211), .A(n_980), .B(n_1128), .C(n_1055)); assign n_1230 = n_4 & n_952; assign n_1236 = n_6 & n_40; assign n_1242 = n_8 & n_40; 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; assign n_1304 = n_321; assign n_1305 = n_1304; FAX1 tmp185(.YS(n_1310), .YC(n_1311), .A(n_57), .B(n_1230), .C(n_1157)); FAX1 tmp186(.YS(n_1318), .YC(n_1319), .A(n_1168), .B(n_1236), .C(n_1163)); FAX1 tmp187(.YS(n_1324), .YC(n_1325), .A(n_1176), .B(n_1242), .C(n_1169)); FAX1 tmp188(.YS(n_1330), .YC(n_1331), .A(n_1182), .B(n_1250), .C(n_1177)); FAX1 tmp189(.YS(n_1338), .YC(n_1339), .A(n_1188), .B(n_1256), .C(n_1183)); FAX1 tmp190(.YS(n_1344), .YC(n_1345), .A(n_1196), .B(n_1264), .C(n_1189)); FAX1 tmp191(.YS(n_1352), .YC(n_1353), .A(n_1202), .B(n_1270), .C(n_1197)); FAX1 tmp192(.YS(n_1358), .YC(n_1359), .A(n_1210), .B(n_1276), .C(n_1203)); FAX1 tmp193(.YS(n_1364), .YC(n_1365), .A(n_1134), .B(n_1284), .C(n_1211)); assign n_1384 = n_4 & n_42; assign n_1392 = n_6 & n_42; 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_1304; FAX1 tmp205(.YS(n_1460), .YC(n_1461), .A(n_1310), .B(n_90), .C(n_1305)); FAX1 tmp206(.YS(n_1466), .YC(n_1467), .A(n_1318), .B(n_1384), .C(n_1311)); FAX1 tmp207(.YS(n_1472), .YC(n_1473), .A(n_1324), .B(n_1392), .C(n_1319)); FAX1 tmp208(.YS(n_1480), .YC(n_1481), .A(n_1330), .B(n_1398), .C(n_1325)); FAX1 tmp209(.YS(n_1486), .YC(n_1487), .A(n_1338), .B(n_1406), .C(n_1331)); FAX1 tmp210(.YS(n_1492), .YC(n_1493), .A(n_1344), .B(n_1412), .C(n_1339)); FAX1 tmp211(.YS(n_1500), .YC(n_1501), .A(n_1352), .B(n_1418), .C(n_1345)); FAX1 tmp212(.YS(n_1506), .YC(n_1507), .A(n_1358), .B(n_1426), .C(n_1353)); FAX1 tmp213(.YS(n_1514), .YC(n_1515), .A(n_1364), .B(n_1432), .C(n_1359)); FAX1 tmp214(.YS(n_1520), .YC(n_1521), .A(n_1290), .B(n_1438), .C(n_1365)); assign n_1526 = n_1365 & n_44; assign n_1534 = n_2 & n_44; 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_1588 = n_18 & n_44; assign n_1594 = n_20 & n_44; assign n_1602 = n_22 & n_44; HAX1 tmp227(.YS(n_1608), .YC(n_1609), .A(n_1460), .B(n_1526)); FAX1 tmp228(.YS(n_1614), .YC(n_1615), .A(n_73), .B(n_1534), .C(n_1461)); FAX1 tmp229(.YS(n_1622), .YC(n_1623), .A(n_1472), .B(n_1540), .C(n_1467)); FAX1 tmp230(.YS(n_1628), .YC(n_1629), .A(n_1480), .B(n_1548), .C(n_1473)); FAX1 tmp231(.YS(n_1634), .YC(n_1635), .A(n_1486), .B(n_1554), .C(n_1481)); FAX1 tmp232(.YS(n_1642), .YC(n_1643), .A(n_1492), .B(n_1560), .C(n_1487)); FAX1 tmp233(.YS(n_1648), .YC(n_1649), .A(n_1500), .B(n_1568), .C(n_1493)); FAX1 tmp234(.YS(n_1656), .YC(n_1657), .A(n_1506), .B(n_1574), .C(n_1501)); FAX1 tmp235(.YS(n_1662), .YC(n_1663), .A(n_1514), .B(n_1580), .C(n_1507)); FAX1 tmp236(.YS(n_1668), .YC(n_1669), .A(n_1520), .B(n_1588), .C(n_1515)); FAX1 tmp237(.YS(n_1676), .YC(n_1677), .A(n_1446), .B(n_1594), .C(n_1521)); assign n_1682 = n_663 & n_46; assign n_1688 = n_2 & n_46; 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; assign n_1757 = n_1756; FAX1 tmp251(.YS(n_1764), .YC(n_1765), .A(n_1614), .B(n_1682), .C(n_1609)); FAX1 tmp252(.YS(n_1770), .YC(n_1771), .A(n_1622), .B(n_1688), .C(n_1615)); FAX1 tmp253(.YS(n_1776), .YC(n_1777), .A(n_1628), .B(n_1696), .C(n_1623)); FAX1 tmp254(.YS(n_1784), .YC(n_1785), .A(n_1634), .B(n_1702), .C(n_1629)); FAX1 tmp255(.YS(n_1790), .YC(n_1791), .A(n_1642), .B(n_1710), .C(n_1635)); FAX1 tmp256(.YS(n_1798), .YC(n_1799), .A(n_1648), .B(n_1716), .C(n_1643)); FAX1 tmp257(.YS(n_1804), .YC(n_1805), .A(n_1656), .B(n_1722), .C(n_1649)); FAX1 tmp258(.YS(n_1810), .YC(n_1811), .A(n_1662), .B(n_1730), .C(n_1657)); FAX1 tmp259(.YS(n_1818), .YC(n_1819), .A(n_1668), .B(n_1736), .C(n_1663)); FAX1 tmp260(.YS(n_1824), .YC(n_1825), .A(n_1676), .B(n_1742), .C(n_1669)); FAX1 tmp261(.YS(n_1830), .YC(n_1831), .A(n_1602), .B(n_1750), .C(n_1677)); HAX1 tmp262(.YS(n_1838), .YC(n_1839), .A(n_1770), .B(n_1765)); FAX1 tmp263(.YS(n_1844), .YC(n_1845), .A(n_1776), .B(n_1771), .C(n_1839)); FAX1 tmp264(.YS(n_1852), .YC(n_1853), .A(n_1784), .B(n_1777), .C(n_1845)); FAX1 tmp265(.YS(n_1858), .YC(n_1859), .A(n_1790), .B(n_1785), .C(n_1853)); HAX1 tmp266(.YS(n_1864), .YC(n_1865), .A(n_1798), .B(n_1791)); FAX1 tmp267(.YS(n_1872), .YC(n_1873), .A(n_1804), .B(n_1799), .C(n_1865)); FAX1 tmp268(.YS(n_1878), .YC(n_1879), .A(n_1810), .B(n_1805), .C(n_1873)); FAX1 tmp269(.YS(n_1884), .YC(n_1885), .A(n_1818), .B(n_1811), .C(n_1879)); HAX1 tmp270(.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 tmp273(.YS(n_1912), .YC(n_1913), .A(n_1804), .B(n_1799), .C(n_1906)); FAX1 tmp274(.YS(n_1918), .YC(n_1919), .A(n_1810), .B(n_1805), .C(n_1913)); FAX1 tmp275(.YS(n_1926), .YC(n_1927), .A(n_1818), .B(n_1811), .C(n_1919)); MUX2X1 tmp276(.Y(n_1932), .A(n_1864), .B(n_1898), .S(n_1859)); MUX2X1 tmp277(.Y(n_1938), .A(n_1872), .B(n_1912), .S(n_1859)); MUX2X1 tmp278(.Y(n_1946), .A(n_1878), .B(n_1918), .S(n_1859)); MUX2X1 tmp279(.Y(n_1952), .A(n_1884), .B(n_1926), .S(n_1859)); MUX2X1 tmp280(.Y(n_1960), .A(n_1885), .B(n_1927), .S(n_1859)); HAX1 tmp281(.YS(n_1966), .YC(n_1967), .A(n_1824), .B(n_1819)); FAX1 tmp282(.YS(n_1972), .YC(n_1973), .A(n_1830), .B(n_1825), .C(n_1967)); FAX1 tmp283(.YS(n_1980), .YC(n_1981), .A(n_1757), .B(n_1831), .C(n_1973)); HAX1 tmp284(.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 tmp287(.YS(n_2006), .YC(n_2007), .A(n_1830), .B(n_1825), .C(n_2000)); FAX1 tmp288(.YS(n_2014), .YC(n_2015), .A(n_1756), .B(n_1831), .C(n_2007)); MUX2X1 tmp289(.Y(n_2020), .A(n_1966), .B(n_1992), .S(n_1960)); MUX2X1 tmp290(.Y(n_2026), .A(n_1972), .B(n_2006), .S(n_1960)); MUX2X1 tmp291(.Y(n_2034), .A(n_1980), .B(n_2014), .S(n_1960)); MUX2X1 tmp292(.Y(n_2040), .A(n_1981), .B(n_2015), .S(n_1960)); assign O[0] = n_1305; assign O[1] = n_44; assign O[2] = n_1211; assign O[3] = n_656; assign O[4] = n_42; assign O[5] = n_90; assign O[6] = n_95; assign O[7] = n_1452; assign O[8] = n_1305; assign O[9] = n_1452; assign O[10] = n_1608; assign O[11] = n_1764; assign O[12] = n_1838; 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_2020; assign O[21] = n_2026; assign O[22] = n_2034; assign O[23] = n_2040; endmodule