open Netlist_ast
include Netlist_proc
type t = calc ref
let main_0_1 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_0_2 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_0_3 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_0_4 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_0_5 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4,o_5 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_0_6 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_0_7 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_0_8 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_0_9 circuit =
let eqs = [] in
let vars = Idm.empty in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_1_1 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_1_2 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_1_3 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_1_4 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_1_5 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_1_6 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_1_7 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_1_8 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_1_9 circuit t_1 =
let i_1 = id "" in
let eqs = [] in
let vars = Idm.add i_1 t_1 (Idm.empty) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_2_1 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_2_2 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_2_3 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_2_4 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_2_5 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_2_6 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_2_7 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_2_8 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_2_9 circuit t_1 t_2 =
let i_1 = id "" in
let i_2 = id "" in
let eqs = [] in
let vars = Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_3_1 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_3_2 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_3_3 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_3_4 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_3_5 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_3_6 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_3_7 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_3_8 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_3_9 circuit t_1 t_2 t_3 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let eqs = [] in
let vars = Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_4_1 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_4_2 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_4_3 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_4_4 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_4_5 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_4_6 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_4_7 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_4_8 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_4_9 circuit t_1 t_2 t_3 t_4 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let eqs = [] in
let vars = Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_5_1 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_5_2 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_5_3 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_5_4 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_5_5 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_5_6 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_5_7 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_5_8 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_5_9 circuit t_1 t_2 t_3 t_4 t_5 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let eqs = [] in
let vars = Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_6_1 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_6_2 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_6_3 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_6_4 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_6_5 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_6_6 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_6_7 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_6_8 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_6_9 circuit t_1 t_2 t_3 t_4 t_5 t_6 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let eqs = [] in
let vars = Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_7_1 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_7_2 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_7_3 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_7_4 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_7_5 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_7_6 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_7_7 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_7_8 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_7_9 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let eqs = [] in
let vars = Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_8_1 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_8_2 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_8_3 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_8_4 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_8_5 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_8_6 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_8_7 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_8_8 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_8_9 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let eqs = [] in
let vars = Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty)))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"
let main_9_1 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
match arg_1 with
| Avar id_1 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1] }
| _ -> failwith "constant output"
let main_9_2 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
match arg_1,arg_2 with
| Avar id_1,Avar id_2 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2] }
| _ -> failwith "constant output"
let main_9_3 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
match arg_1,arg_2,arg_3 with
| Avar id_1,Avar id_2,Avar id_3 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3] }
| _ -> failwith "constant output"
let main_9_4 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
match arg_1,arg_2,arg_3,arg_4 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4] }
| _ -> failwith "constant output"
let main_9_5 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4,o_5 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
match arg_1,arg_2,arg_3,arg_4,arg_5 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4;id_5] }
| _ -> failwith "constant output"
let main_9_6 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6] }
| _ -> failwith "constant output"
let main_9_7 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7] }
| _ -> failwith "constant output"
let main_9_8 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8] }
| _ -> failwith "constant output"
let main_9_9 circuit t_1 t_2 t_3 t_4 t_5 t_6 t_7 t_8 t_9 =
let i_1 = id "" in
let i_2 = id "" in
let i_3 = id "" in
let i_4 = id "" in
let i_5 = id "" in
let i_6 = id "" in
let i_7 = id "" in
let i_8 = id "" in
let i_9 = id "" in
let eqs = [] in
let vars = Idm.add i_9 t_9 (Idm.add i_8 t_8 (Idm.add i_7 t_7 (Idm.add i_6 t_6 (Idm.add i_5 t_5 (Idm.add i_4 t_4 (Idm.add i_3 t_3 (Idm.add i_2 t_2 (Idm.add i_1 t_1 (Idm.empty))))))))) in
let o_1,o_2,o_3,o_4,o_5,o_6,o_7,o_8,o_9 = circuit (ref (Id (i_1,t_1))) (ref (Id (i_2,t_2))) (ref (Id (i_3,t_3))) (ref (Id (i_4,t_4))) (ref (Id (i_5,t_5))) (ref (Id (i_6,t_6))) (ref (Id (i_7,t_7))) (ref (Id (i_8,t_8))) (ref (Id (i_9,t_9))) in
let arg_1,_,eqs,vars = calc eqs vars o_1 in
let arg_2,_,eqs,vars = calc eqs vars o_2 in
let arg_3,_,eqs,vars = calc eqs vars o_3 in
let arg_4,_,eqs,vars = calc eqs vars o_4 in
let arg_5,_,eqs,vars = calc eqs vars o_5 in
let arg_6,_,eqs,vars = calc eqs vars o_6 in
let arg_7,_,eqs,vars = calc eqs vars o_7 in
let arg_8,_,eqs,vars = calc eqs vars o_8 in
let arg_9,_,eqs,vars = calc eqs vars o_9 in
match arg_1,arg_2,arg_3,arg_4,arg_5,arg_6,arg_7,arg_8,arg_9 with
| Avar id_1,Avar id_2,Avar id_3,Avar id_4,Avar id_5,Avar id_6,Avar id_7,Avar id_8,Avar id_9 -> {
p_eqs = eqs;
p_vars = vars;
p_inputs = [i_1;i_2;i_3;i_4;i_5;i_6;i_7;i_8;i_9];
p_outputs = [id_1;id_2;id_3;id_4;id_5;id_6;id_7;id_8;id_9] }
| _ -> failwith "constant output"