You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
2.1 KiB

  1. /*
  2. Copyright 2018 0KIMS association.
  3. This file is part of circom (Zero Knowledge Circuit Compiler).
  4. circom is a free software: you can redistribute it and/or modify it
  5. under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 3 of the License, or
  7. (at your option) any later version.
  8. circom is distributed in the hope that it will be useful, but WITHOUT
  9. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  10. or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
  11. License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with circom. If not, see <https://www.gnu.org/licenses/>.
  14. */
  15. pragma circom 2.0.0;
  16. template MultiMux3(n) {
  17. signal input c[n][8]; // Constants
  18. signal input s[3]; // Selector
  19. signal output out[n];
  20. signal a210[n];
  21. signal a21[n];
  22. signal a20[n];
  23. signal a2[n];
  24. signal a10[n];
  25. signal a1[n];
  26. signal a0[n];
  27. signal a[n];
  28. // 4 constrains for the intermediary variables
  29. signal s10;
  30. s10 <== s[1] * s[0];
  31. for (var i=0; i<n; i++) {
  32. a210[i] <== ( c[i][ 7]-c[i][ 6]-c[i][ 5]+c[i][ 4] - c[i][ 3]+c[i][ 2]+c[i][ 1]-c[i][ 0] ) * s10;
  33. a21[i] <== ( c[i][ 6]-c[i][ 4]-c[i][ 2]+c[i][ 0] ) * s[1];
  34. a20[i] <== ( c[i][ 5]-c[i][ 4]-c[i][ 1]+c[i][ 0] ) * s[0];
  35. a2[i] <== ( c[i][ 4]-c[i][ 0] );
  36. a10[i] <== ( c[i][ 3]-c[i][ 2]-c[i][ 1]+c[i][ 0] ) * s10;
  37. a1[i] <== ( c[i][ 2]-c[i][ 0] ) * s[1];
  38. a0[i] <== ( c[i][ 1]-c[i][ 0] ) * s[0];
  39. a[i] <== ( c[i][ 0] );
  40. out[i] <== ( a210[i] + a21[i] + a20[i] + a2[i] ) * s[2] +
  41. ( a10[i] + a1[i] + a0[i] + a[i] );
  42. }
  43. }
  44. template Mux3() {
  45. var i;
  46. signal input c[8]; // Constants
  47. signal input s[3]; // Selector
  48. signal output out;
  49. component mux = MultiMux3(1);
  50. for (i=0; i<8; i++) {
  51. mux.c[0][i] <== c[i];
  52. }
  53. for (i=0; i<3; i++) {
  54. s[i] ==> mux.s[i];
  55. }
  56. mux.out[0] ==> out;
  57. }