/* Copyright 2018 0KIMS association. This file is part of circom (Zero Knowledge Circuit Compiler). circom is a free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. circom is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with circom. If not, see . */ /* This component creates a binary substraction. Main Constraint: (in[0][0] * 2^0 + in[0][1] * 2^1 + ..... + in[0][n-1] * 2^(n-1)) + + 2^n - (in[1][0] * 2^0 + in[1][1] * 2^1 + ..... + in[1][n-1] * 2^(n-1)) === out[0] * 2^0 + out[1] * 2^1 + + out[n-1] *2^(n-1) + aux out[0] * (out[0] - 1) === 0 out[1] * (out[0] - 1) === 0 . . . out[n-1] * (out[n-1] - 1) === 0 aux * (aux-1) == 0 */ template BinSub(n) { signal input in[2][n]; signal output out[n]; signal aux; var lin = 2**n; var lout = 0; var i; for (i=0; i> i) & 1; // Ensure out is binary out[i] * (out[i] - 1) === 0; lout = lout + out[i]*(2**i); } aux <-- (lin >> n) & 1; aux*(aux-1) === 0; lout = lout + aux*(2**n); // Ensure the sum; lin === lout; }