//test pragma circom 2.1.9; include "../../circom_circuits/hash/anemoi/anemoi_2_to_1_Jubjub.circom"; include "../../circom_circuits/hash/anemoi/anemoi_4_to_1_Jubjub.circom"; include "../../circom_circuits/hash/anemoi/anemoi_16_to_1_Jubjub.circom"; include "../../circom_circuits/circomlib/circuits/bitify.circom"; include "../../circom_circuits/circomlib/circuits/comparators.circom"; include "../../circom_circuits/Jubjub/escalarmulanyJubjub.circom"; include "../../circom_circuits/Jubjub/jubjub.circom"; template BLSLessThan(n) { assert(n <= 253); signal input in[2]; signal output out; component n2b = Num2Bits(n+1); n2b.in <== in[0]+ (1< n2b.in; for (var i=0; i<255; i++) { n2b.out[i] ==> out[i]; if(i != 0){ n2b.out[i] ==> check_range.in[i-1]; } } check_range.out * (n2b.out[0]) === 0; //must be zero exept if the first bit is 0 => then in is on 254 bits and p-1 on 255 } template check_bits(n){ signal input bits[n]; for(var i=0; i