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.

51 lines
1.3 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  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. function pointAdd(x1,y1,x2,y2) {
  16. var a = 168700;
  17. var d = 168696;
  18. var res[2];
  19. res[0] = (x1*y2 + y1*x2) / (1 + d*x1*x2*y1*y2);
  20. res[1] = (y1*y2 - a*x1*x2) / (1 - d*x1*x2*y1*y2);
  21. return res;
  22. }
  23. function EscalarMulW4Table(base, k) {
  24. var out[16][2];
  25. var i;
  26. var p[2];
  27. var dbl[2] = base;
  28. for (i=0; i<k*4; i++) {
  29. dbl = pointAdd(dbl[0], dbl[1], dbl[0], dbl[1]);
  30. }
  31. out[0][0] = 0;
  32. out[0][1] = 1;
  33. for (i=1; i<16; i++) {
  34. p = pointAdd(out[i-1][0], out[i-1][1], dbl[0], dbl[1]);
  35. out[i][0] = p[0];
  36. out[i][1] = p[1];
  37. }
  38. return out;
  39. }