// Library = EvoApprox 12x12 // Circuit = mul12x12_203 // Area (45) = 451 // Delay (45) = 0.980 // Power (45) = 0.23 // MAE = 85161.90000 // MSE = 10787809223.10000 // MRE = 49.94 % // WCE = 334514 // WCRE = 7094900 % // EP = 100.0 % module mul12x12_203(A, B, O); input [11:0] A, B; output [23:0] O; wire n_1103, n_704, n_1102, n_45, n_44, n_47, n_46, n_41, n_40, n_43; wire n_42, n_1893, n_1892, n_1042, n_1043, n_1118, n_1462, n_1284, n_1285, n_826; wire n_1280, n_1463, n_2014, n_1108, n_1567, n_1566, n_1899, n_1561, n_676, n_770; wire n_1440, n_1441, n_2008, n_1628, n_1053, n_1052, n_1428, n_1429, n_716, n_1422; wire n_1423, n_30, n_31, n_32, n_33, n_34, n_35, n_36, n_37, n_38; wire n_39, n_1109, n_814, n_1629, n_2009, n_1048, n_152, n_153, n_1114, n_1661; wire n_1115, n_1860, n_494, n_1451, n_1450, n_1457, n_1456, n_1633, n_1632, n_2002; wire n_1954, n_1024, n_1025, n_1435, n_1434, n_1639, n_1638, n_838, n_23, n_22; wire n_21, n_20, n_27, n_26, n_25, n_24, n_29, n_28, n_1970, n_1958; wire n_804, n_832, n_2030, n_326, n_129, n_128, n_1981, n_1980, n_1031, n_1030; wire n_638, n_1037, n_1036, n_0, n_349, n_348, n_633, n_632, n_1644, n_1645; wire n_1275, n_18, n_19, n_16, n_17, n_14, n_15, n_12, n_13, n_10; wire n_11, n_92, n_93, n_2020, n_1538, n_1419, n_1534, n_1535, n_1418, n_820; wire n_1246, n_1247, n_628, n_1556, n_2024, n_622, n_1550, n_1551, n_1654, n_1086; wire n_1087, n_1651, n_1650, n_1948, n_2015, n_1125, n_1124, n_1529, n_1528, n_1992; wire n_1965, n_1964, n_1998, n_842, n_1252, n_1256, n_1544, n_440, n_1560, n_1093; wire n_1092, n_1097, n_1096, n_1666, n_694, n_698, n_78, n_1976, n_2036, n_72; wire n_73, n_1987, n_1986, n_213, n_212, n_506, n_501, n_500, n_1898, n_376; wire n_1253, n_1262, n_1263, n_688, n_843, n_1673, n_1672, n_682, n_748, n_1977; wire n_2003, n_65, n_64, n_62, n_1936, n_1971, n_200, n_201, n_754, n_1539; wire n_1372, n_8, n_9, n_4, n_5, n_6, n_7, n_572, n_1, n_2; wire n_3, n_1886, n_1887, n_1882, n_1660, n_1368, n_1444, n_52, n_53, n_1274; wire n_766, n_760; 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_52 = ~(n_34 & n_12 & n_14); assign n_53 = n_52; assign n_62 = ~(n_14 | n_52); assign n_64 = n_62; assign n_65 = n_64; assign n_72 = n_65; assign n_73 = n_72; assign n_78 = ~n_65; assign n_92 = ~n_78; assign n_93 = n_92; assign n_128 = ~n_65; assign n_129 = n_128; assign n_152 = ~n_65; assign n_153 = n_152; assign n_200 = ~n_153; assign n_201 = n_200; assign n_212 = n_73; assign n_213 = n_212; assign n_326 = ~n_53; assign n_348 = ~n_201; assign n_349 = n_348; assign n_376 = ~n_129; assign n_440 = n_22 & n_34; assign n_494 = n_18 & n_36; assign n_500 = n_213; assign n_501 = n_500; assign n_506 = n_22 & n_36; assign n_572 = n_22 & n_38; assign n_622 = n_16 & n_40; assign n_628 = n_18 & n_40; assign n_632 = n_20 & n_40; assign n_633 = n_632; assign n_638 = n_22 & n_40; assign n_676 = n_12 & n_42; assign n_682 = n_14 & n_42; assign n_688 = n_16 & n_42; assign n_694 = n_18 & n_42; assign n_698 = n_20 & n_42; assign n_704 = n_22 & n_42; assign n_716 = n_501; assign n_748 = n_14 & n_44; assign n_754 = n_16 & n_44; assign n_760 = n_18 & n_44; assign n_766 = n_20 & n_44; assign n_770 = n_22 & n_44; assign n_804 = n_10 & n_46; assign n_814 = n_14 & n_46; assign n_820 = n_16 & n_46; assign n_826 = n_18 & n_46; assign n_832 = n_20 & n_46; assign n_838 = n_22 & n_46; assign n_842 = ~n_73; assign n_843 = n_842; assign n_1024 = n_633 & n_326; assign n_1025 = n_1024; assign n_1030 = n_494; assign n_1031 = n_1030; FAX1 tmp116(.YS(n_1036), .YC(n_1037), .A(n_213), .B(n_1030), .C(n_622)); FAX1 tmp117(.YS(n_1042), .YC(n_1043), .A(n_506), .B(n_20), .C(n_628)); assign n_1048 = n_572 & n_632; HAX1 tmp119(.YS(n_1052), .YC(n_1053), .A(n_572), .B(n_632)); HAX1 tmp120(.YS(n_1086), .YC(n_1087), .A(n_676), .B(n_8)); FAX1 tmp121(.YS(n_1092), .YC(n_1093), .A(n_682), .B(n_12), .C(n_804)); FAX1 tmp122(.YS(n_1096), .YC(n_1097), .A(n_688), .B(n_748), .C(n_38)); FAX1 tmp123(.YS(n_1102), .YC(n_1103), .A(n_694), .B(n_754), .C(n_814)); FAX1 tmp124(.YS(n_1108), .YC(n_1109), .A(n_698), .B(n_760), .C(n_820)); FAX1 tmp125(.YS(n_1114), .YC(n_1115), .A(n_704), .B(n_766), .C(n_826)); assign n_1118 = n_770 & n_832; HAX1 tmp127(.YS(n_1124), .YC(n_1125), .A(n_770), .B(n_832)); MUX2X1 tmp128(.Y(n_1246), .A(n_213), .B(n_804), .S(n_1025)); assign n_1247 = n_1246; FAX1 tmp130(.YS(n_1252), .YC(n_1253), .A(n_93), .B(n_1036), .C(n_1031)); assign n_1256 = n_1042 & n_1037; HAX1 tmp132(.YS(n_1262), .YC(n_1263), .A(n_1042), .B(n_1037)); HAX1 tmp133(.YS(n_1274), .YC(n_1275), .A(n_1052), .B(n_1043)); assign n_1280 = n_153 & n_1048; HAX1 tmp135(.YS(n_1284), .YC(n_1285), .A(n_638), .B(n_1048)); assign n_1368 = n_440 & n_1252; assign n_1372 = n_440 | n_1252; FAX1 tmp138(.YS(n_1418), .YC(n_1419), .A(n_1247), .B(n_1092), .C(n_1087)); FAX1 tmp139(.YS(n_1422), .YC(n_1423), .A(n_1253), .B(n_1096), .C(n_1093)); FAX1 tmp140(.YS(n_1428), .YC(n_1429), .A(n_1256), .B(n_1102), .C(n_1097)); FAX1 tmp141(.YS(n_1434), .YC(n_1435), .A(n_1275), .B(n_1108), .C(n_1103)); FAX1 tmp142(.YS(n_1440), .YC(n_1441), .A(n_1280), .B(n_1114), .C(n_1109)); assign n_1444 = n_1124 & n_1115; HAX1 tmp144(.YS(n_1450), .YC(n_1451), .A(n_1124), .B(n_1115)); assign n_1456 = n_153 & n_1118; assign n_1457 = n_1456; HAX1 tmp147(.YS(n_1462), .YC(n_1463), .A(n_838), .B(n_1118)); assign n_1528 = ~n_65; assign n_1529 = n_1528; FAX1 tmp150(.YS(n_1534), .YC(n_1535), .A(n_1372), .B(n_770), .C(n_1418)); FAX1 tmp151(.YS(n_1538), .YC(n_1539), .A(n_1262), .B(n_1368), .C(n_1422)); assign n_1544 = n_1274 & n_1428; HAX1 tmp153(.YS(n_1550), .YC(n_1551), .A(n_1274), .B(n_1428)); assign n_1556 = n_1284 & n_1434; HAX1 tmp155(.YS(n_1560), .YC(n_1561), .A(n_1284), .B(n_1434)); assign n_1566 = ~n_129; assign n_1567 = n_1566; HAX1 tmp158(.YS(n_1628), .YC(n_1629), .A(n_1534), .B(n_1529)); FAX1 tmp159(.YS(n_1632), .YC(n_1633), .A(n_1538), .B(n_1535), .C(n_1419)); FAX1 tmp160(.YS(n_1638), .YC(n_1639), .A(n_1550), .B(n_1539), .C(n_1423)); FAX1 tmp161(.YS(n_1644), .YC(n_1645), .A(n_1560), .B(n_1544), .C(n_1429)); FAX1 tmp162(.YS(n_1650), .YC(n_1651), .A(n_1440), .B(n_1556), .C(n_1435)); assign n_1654 = n_1450 & n_1441; HAX1 tmp164(.YS(n_1660), .YC(n_1661), .A(n_1450), .B(n_1441)); assign n_1666 = n_1462 & n_1444; HAX1 tmp166(.YS(n_1672), .YC(n_1673), .A(n_1462), .B(n_1444)); assign n_1860 = ~n_349; assign n_1882 = n_1628; HAX1 tmp169(.YS(n_1886), .YC(n_1887), .A(n_1632), .B(n_1629)); FAX1 tmp170(.YS(n_1892), .YC(n_1893), .A(n_1638), .B(n_1633), .C(n_1887)); FAX1 tmp171(.YS(n_1898), .YC(n_1899), .A(n_1644), .B(n_1639), .C(n_1893)); assign n_1936 = n_1882; assign n_1948 = n_1892; assign n_1954 = n_1898; assign n_1958 = n_1899; HAX1 tmp176(.YS(n_1964), .YC(n_1965), .A(n_1650), .B(n_1645)); FAX1 tmp177(.YS(n_1970), .YC(n_1971), .A(n_1660), .B(n_1651), .C(n_1965)); FAX1 tmp178(.YS(n_1976), .YC(n_1977), .A(n_1672), .B(n_1654), .C(n_1971)); FAX1 tmp179(.YS(n_1980), .YC(n_1981), .A(n_1457), .B(n_1666), .C(n_1977)); HAX1 tmp180(.YS(n_1986), .YC(n_1987), .A(n_1650), .B(n_1645)); assign n_1992 = ~n_1986; assign n_1998 = n_1965 | n_1986; FAX1 tmp183(.YS(n_2002), .YC(n_2003), .A(n_1660), .B(n_1651), .C(n_1998)); FAX1 tmp184(.YS(n_2008), .YC(n_2009), .A(n_1672), .B(n_1654), .C(n_2003)); FAX1 tmp185(.YS(n_2014), .YC(n_2015), .A(n_1456), .B(n_1666), .C(n_2009)); MUX2X1 tmp186(.Y(n_2020), .A(n_1964), .B(n_1992), .S(n_1958)); MUX2X1 tmp187(.Y(n_2024), .A(n_1970), .B(n_2002), .S(n_1958)); MUX2X1 tmp188(.Y(n_2030), .A(n_1976), .B(n_2008), .S(n_1958)); MUX2X1 tmp189(.Y(n_2036), .A(n_1980), .B(n_2014), .S(n_1958)); assign O[0] = n_34; assign O[1] = n_842; assign O[2] = n_843; assign O[3] = n_16; assign O[4] = n_10; assign O[5] = n_842; assign O[6] = n_1567; assign O[7] = n_40; assign O[8] = n_129; assign O[9] = n_44; assign O[10] = n_843; assign O[11] = n_376; assign O[12] = n_349; assign O[13] = n_1860; assign O[14] = n_2015; assign O[15] = n_716; assign O[16] = n_1936; assign O[17] = n_1886; assign O[18] = n_1948; assign O[19] = n_1954; assign O[20] = n_2020; assign O[21] = n_2024; assign O[22] = n_2030; assign O[23] = n_2036; endmodule