template MultiMux4(n) { signal input c[n][16]; // Constants signal input s[4]; // Selector signal output out[n]; signal a3210[n]; signal a321[n]; signal a320[n]; signal a310[n]; signal a32[n]; signal a31[n]; signal a30[n]; signal a3[n]; signal a210[n]; signal a21[n]; signal a20[n]; signal a10[n]; signal a2[n]; signal a1[n]; signal a0[n]; signal a[n]; // 4 constrains for the intermediary variables signal s10; s10 <== s[1] * s[0]; signal s20; s20 <== s[2] * s[0]; signal s21; s21 <== s[2] * s[1]; signal s210; s210 <== s21 * s[0]; for (var i=0; i mux.s[i]; } mux.out[0] ==> out; }