// Library = EvoApprox 12x12 // Circuit = mul12x12_036 // Area (45) = 1152 // Delay (45) = 2.160 // Power (45) = 0.84 // MAE = 832.10000 // MSE = 1084459.20000 // MRE = 0.24 % // WCE = 4190 // WCRE = 13700 % // EP = 100.0 % module mul12x12_036(A, B, O); input [11:0] A, B; output [23:0] O; wire n_1196, n_1197, n_1750, n_1756, n_1202, n_1614, n_1811, n_1810, n_1819, n_1818; wire n_1682, n_1688, n_486, n_1102, n_1108, n_1290, n_1299, n_1298, n_1864, n_1865; wire n_723, n_722, n_2034, n_1615, n_1203, n_656, n_122, n_344, n_1035, n_1034; wire n_426, n_427, n_1406, n_18, n_19, n_16, n_17, n_14, n_15, n_12; wire n_13, n_10, n_11, n_884, n_885, n_338, n_339, n_1242, n_1716, n_1710; wire n_1486, n_1339, n_1080, n_1325, n_1324, n_1088, n_1492, n_1918, n_1919, n_89; wire n_88, n_1912, n_1913, n_1330, n_1952, n_560, n_1148, n_1662, n_1663, n_1668; wire n_1669, n_1392, n_1398, n_1987, n_1986, n_1981, n_1980, n_1824, n_1825, n_569; wire n_568, n_561, n_1055, n_818, n_514, n_1580, n_1588, n_946, n_1365, n_1364; wire n_1946, n_419, n_418, n_45, n_44, n_47, n_46, n_41, n_40, n_43; wire n_42, n_864, n_1041, n_49, n_48, n_1594, n_1560, n_1446, n_1554, n_1568; wire n_980, n_1189, n_1188, n_1622, n_1623, n_1628, n_1629, n_1183, n_1182, n_1211; wire n_1210, n_1696, n_1134, n_810, n_1873, n_1872, n_1879, n_1878, n_7, n_185; wire n_184, n_634, n_188, n_2020, n_2026, n_648, n_642, n_36, n_824, n_1006; wire n_1007, n_1000, n_358, n_736, n_737, n_730, n_731, n_1521, n_1520, n_1526; wire n_1250, n_1256, n_1318, n_1319, n_1095, n_1094, n_1310, n_1311, n_1906, n_70; wire n_72, n_73, n_1798, n_1799, n_1790, n_1791, n_1418, n_1176, n_1177, n_1702; wire n_1776, n_1777, n_1770, n_1771, n_1677, n_1676, n_1730, n_1384, n_1839, n_1838; wire n_1804, n_1831, n_1830, n_574, n_575, n_2014, n_2015, n_776, n_777, n_952; wire n_1054, n_1358, n_1359, n_1426, n_1352, n_1353, n_30, n_31, n_32, n_33; wire n_34, n_35, n_790, n_37, n_38, n_39, n_798, n_1048, n_784, n_1898; wire n_1514, n_1515, n_1453, n_1452, n_492, n_1635, n_1634, n_1040, n_926, n_865; wire n_1222, n_1736, n_1412, n_1642, n_1643, n_352, n_1128, n_1123, n_1122, n_1648; wire n_1649, n_1893, n_1844, n_1845, n_1892, n_581, n_580, n_196, n_589, n_588; wire n_1960, n_1967, n_1966, n_1548, n_1540, n_1015, n_1014, n_2040, n_743, n_742; wire n_210, n_1305, n_1304, n_1264, n_960, n_966, n_1938, n_1932, n_60, n_1460; wire n_1461, n_1466, n_1467, n_1785, n_1784, n_1163, n_1162, n_8, n_9, n_4; wire n_5, n_1169, n_1168, n_0, n_1, n_2, n_3, n_1765, n_1764, n_1608; wire n_1609, n_1602, n_6, n_1805, n_1114, n_1284, n_1742, n_716, n_717, n_2000; wire n_2007, n_2006, n_662, n_668, n_433, n_432, n_1020, n_1021, n_1026, n_1027; wire n_1345, n_1432, n_23, n_22, n_21, n_20, n_27, n_26, n_25, n_24; wire n_29, n_28, n_804, n_1973, n_1493, n_1501, n_1500, n_893, n_892, n_1507; wire n_1506, n_899, n_898, n_480, n_1236, n_1230, n_1480, n_1481, n_932, n_1338; wire n_1487, n_1722, n_938, n_1331, n_1927, n_1926, n_972, n_1657, n_1656, n_1534; wire n_1438, n_1992, n_1859, n_1858, n_1853, n_1852, n_1049, n_1344, n_114, n_506; wire n_500, n_277, n_276, n_271, n_270, n_1574, n_202, n_1972, n_1372, n_1378; wire n_1270, n_1276, n_873, n_872, n_1884, n_1885, n_879, n_878, 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_18 & n_24; assign n_49 = n_48; assign n_60 = ~(n_28 | n_20); assign n_70 = ~(n_18 | n_20 | n_10); assign n_72 = n_18 & n_70; assign n_73 = n_72; assign n_88 = n_73; assign n_89 = n_88; assign n_114 = n_20 & n_24; assign n_122 = n_22 & n_24; assign n_184 = ~n_89; assign n_185 = n_184; assign n_188 = n_18 & n_26; assign n_196 = n_20 & n_26; assign n_202 = n_22 & n_26; assign n_210 = ~n_89; HAX1 tmp75(.YS(n_270), .YC(n_271), .A(n_114), .B(n_188)); HAX1 tmp76(.YS(n_276), .YC(n_277), .A(n_122), .B(n_196)); assign n_338 = n_16 & n_28; assign n_339 = n_338; assign n_344 = n_18 & n_28; assign n_352 = n_20 & n_28; assign n_358 = n_22 & n_28; HAX1 tmp82(.YS(n_418), .YC(n_419), .A(n_270), .B(n_338)); FAX1 tmp83(.YS(n_426), .YC(n_427), .A(n_276), .B(n_344), .C(n_271)); FAX1 tmp84(.YS(n_432), .YC(n_433), .A(n_202), .B(n_352), .C(n_277)); assign n_480 = n_12 & n_30; 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_560 = n_89 | n_480; assign n_561 = n_560; FAX1 tmp93(.YS(n_568), .YC(n_569), .A(n_418), .B(n_486), .C(n_339)); FAX1 tmp94(.YS(n_574), .YC(n_575), .A(n_426), .B(n_492), .C(n_419)); FAX1 tmp95(.YS(n_580), .YC(n_581), .A(n_432), .B(n_500), .C(n_427)); FAX1 tmp96(.YS(n_588), .YC(n_589), .A(n_358), .B(n_506), .C(n_433)); assign n_634 = n_12 & n_32; assign n_642 = n_14 & n_32; 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; FAX1 tmp103(.YS(n_716), .YC(n_717), .A(n_568), .B(n_634), .C(n_561)); FAX1 tmp104(.YS(n_722), .YC(n_723), .A(n_574), .B(n_642), .C(n_569)); FAX1 tmp105(.YS(n_730), .YC(n_731), .A(n_580), .B(n_648), .C(n_575)); FAX1 tmp106(.YS(n_736), .YC(n_737), .A(n_588), .B(n_656), .C(n_581)); FAX1 tmp107(.YS(n_742), .YC(n_743), .A(n_514), .B(n_662), .C(n_589)); assign n_776 = n_8 & n_34; assign n_777 = n_776; assign n_784 = n_10 & n_34; 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_864 = n_716 | n_784; assign n_865 = n_864; FAX1 tmp119(.YS(n_872), .YC(n_873), .A(n_722), .B(n_790), .C(n_717)); FAX1 tmp120(.YS(n_878), .YC(n_879), .A(n_730), .B(n_798), .C(n_723)); FAX1 tmp121(.YS(n_884), .YC(n_885), .A(n_736), .B(n_804), .C(n_731)); FAX1 tmp122(.YS(n_892), .YC(n_893), .A(n_742), .B(n_810), .C(n_737)); FAX1 tmp123(.YS(n_898), .YC(n_899), .A(n_668), .B(n_818), .C(n_743)); assign n_926 = n_6 & n_36; assign n_932 = n_8 & n_36; assign n_938 = n_10 & n_36; 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; assign n_1000 = n_89; assign n_1006 = n_185 & n_926; assign n_1007 = n_1006; HAX1 tmp136(.YS(n_1014), .YC(n_1015), .A(n_433), .B(n_932)); FAX1 tmp137(.YS(n_1020), .YC(n_1021), .A(n_872), .B(n_938), .C(n_865)); FAX1 tmp138(.YS(n_1026), .YC(n_1027), .A(n_878), .B(n_946), .C(n_873)); FAX1 tmp139(.YS(n_1034), .YC(n_1035), .A(n_884), .B(n_952), .C(n_879)); FAX1 tmp140(.YS(n_1040), .YC(n_1041), .A(n_892), .B(n_960), .C(n_885)); FAX1 tmp141(.YS(n_1048), .YC(n_1049), .A(n_898), .B(n_966), .C(n_893)); FAX1 tmp142(.YS(n_1054), .YC(n_1055), .A(n_824), .B(n_972), .C(n_899)); assign n_1080 = n_6 & n_38; assign n_1088 = n_8 & n_38; assign n_1094 = n_10 & n_38; assign n_1095 = n_1094; 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_1123 = n_1122; assign n_1128 = n_20 & n_38; assign n_1134 = n_22 & n_38; assign n_1148 = ~n_1000; FAX1 tmp155(.YS(n_1162), .YC(n_1163), .A(n_1014), .B(n_1080), .C(n_1007)); FAX1 tmp156(.YS(n_1168), .YC(n_1169), .A(n_1020), .B(n_1088), .C(n_1015)); FAX1 tmp157(.YS(n_1176), .YC(n_1177), .A(n_1026), .B(n_1094), .C(n_1021)); FAX1 tmp158(.YS(n_1182), .YC(n_1183), .A(n_1034), .B(n_1102), .C(n_1027)); FAX1 tmp159(.YS(n_1188), .YC(n_1189), .A(n_1040), .B(n_1108), .C(n_1035)); FAX1 tmp160(.YS(n_1196), .YC(n_1197), .A(n_1048), .B(n_1114), .C(n_1041)); FAX1 tmp161(.YS(n_1202), .YC(n_1203), .A(n_1054), .B(n_1122), .C(n_1049)); FAX1 tmp162(.YS(n_1210), .YC(n_1211), .A(n_980), .B(n_1128), .C(n_1055)); assign n_1222 = n_2 & n_40; assign n_1230 = n_4 & n_40; 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_1298 = ~n_1148; assign n_1299 = n_1298; HAX1 tmp176(.YS(n_1304), .YC(n_1305), .A(n_49), .B(n_1222)); FAX1 tmp177(.YS(n_1310), .YC(n_1311), .A(n_1162), .B(n_1230), .C(n_1095)); FAX1 tmp178(.YS(n_1318), .YC(n_1319), .A(n_1168), .B(n_1236), .C(n_1163)); FAX1 tmp179(.YS(n_1324), .YC(n_1325), .A(n_1176), .B(n_1242), .C(n_1169)); FAX1 tmp180(.YS(n_1330), .YC(n_1331), .A(n_1182), .B(n_1250), .C(n_1177)); FAX1 tmp181(.YS(n_1338), .YC(n_1339), .A(n_1188), .B(n_1256), .C(n_1183)); FAX1 tmp182(.YS(n_1344), .YC(n_1345), .A(n_1196), .B(n_1264), .C(n_1189)); FAX1 tmp183(.YS(n_1352), .YC(n_1353), .A(n_1202), .B(n_1270), .C(n_1197)); FAX1 tmp184(.YS(n_1358), .YC(n_1359), .A(n_1210), .B(n_1276), .C(n_1203)); FAX1 tmp185(.YS(n_1364), .YC(n_1365), .A(n_1134), .B(n_1284), .C(n_1211)); assign n_1372 = n_777 & n_42; assign n_1378 = n_2 & n_42; 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; FAX1 tmp198(.YS(n_1452), .YC(n_1453), .A(n_1304), .B(n_1372), .C(n_1299)); FAX1 tmp199(.YS(n_1460), .YC(n_1461), .A(n_1310), .B(n_1378), .C(n_1305)); FAX1 tmp200(.YS(n_1466), .YC(n_1467), .A(n_1318), .B(n_1384), .C(n_1311)); FAX1 tmp201(.YS(n_1472), .YC(n_1473), .A(n_1324), .B(n_1392), .C(n_1319)); FAX1 tmp202(.YS(n_1480), .YC(n_1481), .A(n_1330), .B(n_1398), .C(n_1325)); FAX1 tmp203(.YS(n_1486), .YC(n_1487), .A(n_1338), .B(n_1406), .C(n_1331)); FAX1 tmp204(.YS(n_1492), .YC(n_1493), .A(n_1344), .B(n_1412), .C(n_1339)); FAX1 tmp205(.YS(n_1500), .YC(n_1501), .A(n_1352), .B(n_1418), .C(n_1345)); FAX1 tmp206(.YS(n_1506), .YC(n_1507), .A(n_1358), .B(n_1426), .C(n_1353)); FAX1 tmp207(.YS(n_1514), .YC(n_1515), .A(n_1364), .B(n_1432), .C(n_1359)); FAX1 tmp208(.YS(n_1520), .YC(n_1521), .A(n_1290), .B(n_1438), .C(n_1365)); assign n_1526 = n_0 & 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; FAX1 tmp221(.YS(n_1608), .YC(n_1609), .A(n_1460), .B(n_1526), .C(n_1453)); FAX1 tmp222(.YS(n_1614), .YC(n_1615), .A(n_1466), .B(n_1534), .C(n_1461)); FAX1 tmp223(.YS(n_1622), .YC(n_1623), .A(n_1472), .B(n_1540), .C(n_1467)); FAX1 tmp224(.YS(n_1628), .YC(n_1629), .A(n_1480), .B(n_1548), .C(n_1473)); FAX1 tmp225(.YS(n_1634), .YC(n_1635), .A(n_1486), .B(n_1554), .C(n_1481)); FAX1 tmp226(.YS(n_1642), .YC(n_1643), .A(n_1492), .B(n_1560), .C(n_1487)); FAX1 tmp227(.YS(n_1648), .YC(n_1649), .A(n_1500), .B(n_1568), .C(n_1493)); FAX1 tmp228(.YS(n_1656), .YC(n_1657), .A(n_1506), .B(n_1574), .C(n_1501)); FAX1 tmp229(.YS(n_1662), .YC(n_1663), .A(n_1514), .B(n_1580), .C(n_1507)); FAX1 tmp230(.YS(n_1668), .YC(n_1669), .A(n_1520), .B(n_1588), .C(n_1515)); FAX1 tmp231(.YS(n_1676), .YC(n_1677), .A(n_1446), .B(n_1594), .C(n_1521)); assign n_1682 = n_0 & 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; FAX1 tmp244(.YS(n_1764), .YC(n_1765), .A(n_1614), .B(n_1682), .C(n_1609)); FAX1 tmp245(.YS(n_1770), .YC(n_1771), .A(n_1622), .B(n_1688), .C(n_1615)); FAX1 tmp246(.YS(n_1776), .YC(n_1777), .A(n_1628), .B(n_1696), .C(n_1623)); FAX1 tmp247(.YS(n_1784), .YC(n_1785), .A(n_1634), .B(n_1702), .C(n_1629)); FAX1 tmp248(.YS(n_1790), .YC(n_1791), .A(n_1642), .B(n_1710), .C(n_1635)); FAX1 tmp249(.YS(n_1798), .YC(n_1799), .A(n_1648), .B(n_1716), .C(n_1643)); FAX1 tmp250(.YS(n_1804), .YC(n_1805), .A(n_1656), .B(n_1722), .C(n_1649)); FAX1 tmp251(.YS(n_1810), .YC(n_1811), .A(n_1662), .B(n_1730), .C(n_1657)); FAX1 tmp252(.YS(n_1818), .YC(n_1819), .A(n_1668), .B(n_1736), .C(n_1663)); FAX1 tmp253(.YS(n_1824), .YC(n_1825), .A(n_1676), .B(n_1742), .C(n_1669)); FAX1 tmp254(.YS(n_1830), .YC(n_1831), .A(n_1602), .B(n_1750), .C(n_1677)); HAX1 tmp255(.YS(n_1838), .YC(n_1839), .A(n_1770), .B(n_1765)); FAX1 tmp256(.YS(n_1844), .YC(n_1845), .A(n_1776), .B(n_1771), .C(n_1839)); FAX1 tmp257(.YS(n_1852), .YC(n_1853), .A(n_1784), .B(n_1777), .C(n_1845)); FAX1 tmp258(.YS(n_1858), .YC(n_1859), .A(n_1790), .B(n_1785), .C(n_1853)); HAX1 tmp259(.YS(n_1864), .YC(n_1865), .A(n_1798), .B(n_1791)); FAX1 tmp260(.YS(n_1872), .YC(n_1873), .A(n_1804), .B(n_1799), .C(n_1865)); FAX1 tmp261(.YS(n_1878), .YC(n_1879), .A(n_1810), .B(n_1805), .C(n_1873)); FAX1 tmp262(.YS(n_1884), .YC(n_1885), .A(n_1818), .B(n_1811), .C(n_1879)); HAX1 tmp263(.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 tmp266(.YS(n_1912), .YC(n_1913), .A(n_1804), .B(n_1799), .C(n_1906)); FAX1 tmp267(.YS(n_1918), .YC(n_1919), .A(n_1810), .B(n_1805), .C(n_1913)); FAX1 tmp268(.YS(n_1926), .YC(n_1927), .A(n_1818), .B(n_1811), .C(n_1919)); MUX2X1 tmp269(.Y(n_1932), .A(n_1864), .B(n_1898), .S(n_1859)); MUX2X1 tmp270(.Y(n_1938), .A(n_1872), .B(n_1912), .S(n_1859)); MUX2X1 tmp271(.Y(n_1946), .A(n_1878), .B(n_1918), .S(n_1859)); MUX2X1 tmp272(.Y(n_1952), .A(n_1884), .B(n_1926), .S(n_1859)); MUX2X1 tmp273(.Y(n_1960), .A(n_1885), .B(n_1927), .S(n_1859)); HAX1 tmp274(.YS(n_1966), .YC(n_1967), .A(n_1824), .B(n_1819)); FAX1 tmp275(.YS(n_1972), .YC(n_1973), .A(n_1830), .B(n_1825), .C(n_1967)); FAX1 tmp276(.YS(n_1980), .YC(n_1981), .A(n_1756), .B(n_1831), .C(n_1973)); HAX1 tmp277(.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 tmp280(.YS(n_2006), .YC(n_2007), .A(n_1830), .B(n_1825), .C(n_2000)); FAX1 tmp281(.YS(n_2014), .YC(n_2015), .A(n_1756), .B(n_1831), .C(n_2007)); MUX2X1 tmp282(.Y(n_2020), .A(n_1966), .B(n_1992), .S(n_1960)); MUX2X1 tmp283(.Y(n_2026), .A(n_1972), .B(n_2006), .S(n_1960)); MUX2X1 tmp284(.Y(n_2034), .A(n_1980), .B(n_2014), .S(n_1960)); MUX2X1 tmp285(.Y(n_2040), .A(n_1981), .B(n_2015), .S(n_1960)); assign O[0] = n_34; assign O[1] = n_210; assign O[2] = n_1123; assign O[3] = n_0; assign O[4] = n_42; assign O[5] = n_36; assign O[6] = n_1879; assign O[7] = n_60; assign O[8] = n_1298; 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