|
@ -570,7 +570,7 @@ mod test_recursive { |
|
|
|
|
|
|
|
|
use super::*;
|
|
|
use super::*;
|
|
|
use algebra::{
|
|
|
use algebra::{
|
|
|
fields::FpParameters,
|
|
|
|
|
|
|
|
|
fields::{FftParameters, FpParameters},
|
|
|
mnt4_298::{Fq as MNT4Fq, FqParameters as MNT4FqParameters, Fr as MNT4Fr, MNT4_298},
|
|
|
mnt4_298::{Fq as MNT4Fq, FqParameters as MNT4FqParameters, Fr as MNT4Fr, MNT4_298},
|
|
|
mnt6_298::{Fq as MNT6Fq, FqParameters as MNT6FqParameters, Fr as MNT6Fr, MNT6_298},
|
|
|
mnt6_298::{Fq as MNT6Fq, FqParameters as MNT6FqParameters, Fr as MNT6Fr, MNT6_298},
|
|
|
test_rng, BigInteger, PrimeField,
|
|
|
test_rng, BigInteger, PrimeField,
|
|
@ -678,7 +678,7 @@ mod test_recursive { |
|
|
// Allocate this byte array as input packed into field elements.
|
|
|
// Allocate this byte array as input packed into field elements.
|
|
|
let input_bytes = UInt8::alloc_input_vec(cs.ns(|| "Input"), &input_bytes[..])?;
|
|
|
let input_bytes = UInt8::alloc_input_vec(cs.ns(|| "Input"), &input_bytes[..])?;
|
|
|
// 40 byte
|
|
|
// 40 byte
|
|
|
let element_size = <MNT4FqParameters as FpParameters>::BigInt::NUM_LIMBS * 8;
|
|
|
|
|
|
|
|
|
let element_size = <MNT4FqParameters as FftParameters>::BigInt::NUM_LIMBS * 8;
|
|
|
input_gadgets = input_bytes
|
|
|
input_gadgets = input_bytes
|
|
|
.chunks(element_size)
|
|
|
.chunks(element_size)
|
|
|
.map(|chunk| {
|
|
|
.map(|chunk| {
|
|
@ -705,7 +705,7 @@ mod test_recursive { |
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn groth16_recursive_verifier_test() {
|
|
|
fn groth16_recursive_verifier_test() {
|
|
|
let num_inputs = 100;
|
|
|
|
|
|
|
|
|
let num_inputs = 5;
|
|
|
let num_constraints = num_inputs;
|
|
|
let num_constraints = num_inputs;
|
|
|
let rng = &mut test_rng();
|
|
|
let rng = &mut test_rng();
|
|
|
let mut inputs: Vec<Option<MNT4Fq>> = Vec::with_capacity(num_inputs);
|
|
|
let mut inputs: Vec<Option<MNT4Fq>> = Vec::with_capacity(num_inputs);
|
|
@ -764,7 +764,7 @@ mod test_recursive { |
|
|
let mut input_gadgets = Vec::new();
|
|
|
let mut input_gadgets = Vec::new();
|
|
|
|
|
|
|
|
|
{
|
|
|
{
|
|
|
let bigint_size = <MNT4FqParameters as FpParameters>::BigInt::NUM_LIMBS * 64;
|
|
|
|
|
|
|
|
|
let bigint_size = <MNT4FqParameters as FftParameters>::BigInt::NUM_LIMBS * 64;
|
|
|
let mut input_bits = Vec::new();
|
|
|
let mut input_bits = Vec::new();
|
|
|
let mut cs = cs.ns(|| "Allocate Input");
|
|
|
let mut cs = cs.ns(|| "Allocate Input");
|
|
|
for (i, input) in inputs.into_iter().enumerate() {
|
|
|
for (i, input) in inputs.into_iter().enumerate() {
|
|
@ -790,7 +790,7 @@ mod test_recursive { |
|
|
// Pack input bits into field elements of the underlying circuit.
|
|
|
// Pack input bits into field elements of the underlying circuit.
|
|
|
let max_size = 8 * (<MNT6FqParameters as FpParameters>::CAPACITY / 8) as usize;
|
|
|
let max_size = 8 * (<MNT6FqParameters as FpParameters>::CAPACITY / 8) as usize;
|
|
|
let max_size = max_size as usize;
|
|
|
let max_size = max_size as usize;
|
|
|
let bigint_size = <MNT6FqParameters as FpParameters>::BigInt::NUM_LIMBS * 64;
|
|
|
|
|
|
|
|
|
let bigint_size = <MNT6FqParameters as FftParameters>::BigInt::NUM_LIMBS * 64;
|
|
|
for chunk in input_bits.chunks(max_size) {
|
|
|
for chunk in input_bits.chunks(max_size) {
|
|
|
let mut chunk = chunk.to_vec();
|
|
|
let mut chunk = chunk.to_vec();
|
|
|
let len = chunk.len();
|
|
|
let len = chunk.len();
|
|
|