Skip to content

nulltea/hyper-greco

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Hyper-Greco: Verifiable FHE with GKR

GKR prover for BFV Secret Key Encryption based on Greco scheme.

Warning

This is a research project and hasn't been audited. Don't use it production.

Approach

  • This implementation uses linear-time GKR (Libra) prove system.
  • FHE input uni polys generated via circuit_sk.py are converted to multilinear polys on a boolean domain.
  • Polynomial multiplication in the circuit is computed as evaluation (FFT) -> dot product -> interpolation (IFFT)
  • Range checks for all input polys are batched and proved via a single Lasso node.
  • No intermediate commitments; prover can commit to private inputs according to application needs outside this scheme.

Lasso vs LogUp-GKR

LogUp was a first choice for range checks. It works really well for smaller tables (e.g. S_BOUND and E_BOUND) but cannot be naively applied for larger ones. Notably, the R2_BOUNDS table is too large, 2**55+, to be materialized. The halo2-lib range chip approach could've been used to remedy this (decomposition and lookup combination), but then Lasso is arguably a better realization of this technique.

Another downside of using LogUp is committing to lookup tables and multiplicities. Lasso avoids this when lookup tables are structured, which is the case for range checks.

Finally, while multiple lookup input columns can be batched for a single lookup table in LogUp, batching multiple lookup types (range bounds in this case) is impossible with LogUp, afaik. On the contrary, one can batch many lookup types and verify them via a single primary (collation) sum check and two grand product argument GKRs. The approach is inspired by Jolt's instructions lookups.

I should note that since S_BOUND and E_BOUND are small and each only requires a single subtable/dimension, when batching together with other larger-table lookups (which require multiple dimensions per suitable) -- there is a somewhat redundant overhead compared to, say running S_BOUND and E_BOUND as LogUp nodes. However, when accounting for witness generation and commitment/opening time also needed for LogUp batched, Lasso is still more practical. One approach that has not yet been explored is to have two Lasso nodes: one for small tables and one for large ones.

Version with LogUp checks and LogUP IOP can be found in this commit.

Results

Benchmarks run on M1 Macbook Pro with 10 cores and 32GB of RAM.

The parameters have been chosen targeting 128-bit security level for different values of n. For more information on parameters choise, please check Homomorphic Encryption Standard.

Field/extension field: Goldilocks, GoldilocksExt2

$n$ $\log q_i$ $k$ Witness Gen Proof Gen Proof Verify
1024 27 1 7.23 ms 103 ms 10.9ms
2048 52 1 11.9 ms 159 ms 9.84ms
4096 55 2 24.73 ms 265 ms 10.8ms
8192 55 4 81.5 ms 588 ms 20.9ms
16384 54 8 310 ms 1.51 s 84.9ms
32768 59 16 1.04s 5.06 s 107.9ms

Field/extension field: BN254, BN254

$n$ $\log q_i$ $k$ Witness Gen Proof Gen Proof Verify
1024 27 1 39.0 ms 236 ms 22.0 ms
2048 52 1 77.8 ms 308 ms 10.1 ms
4096 55 2 232.2 ms 575 ms 16.3 ms
8192 55 4 845 ms 1.65 s 36.0ms
16384 54 8 3.55 s 4.87 s 166 ms
32768 59 16 12.2 s 28.8 s 529 ms

For comparison, see original Greco benchmarks (proved via Halo2 on M2 Macbook Pro with 12 cores and 32GB of RAM)

Run yourself

cargo test -r test_sk_enc_valid  -- --nocapture

Profiling charts

%%{
  init: {
    'theme': 'dark',
    'themeVariables': {
      'primaryColor': '#FFEC3D',
      'primaryTextColor': '#fff',
      'pie1': '#F5004F',
      'pie2': '#FFEC3D',
      'pie3': '#88D66C'
    }
  }
}%%
pie showData title GKR Prove (Goldilocks) - 1.88s 
    "Lasso" : 1.430
    "Poly mult (FFT/IFFT)" : 0.291
    "Other operations" : 0.128
Loading
%%{
  init: {
    'theme': 'dark',
    'themeVariables': {
      'primaryColor': '#FFEC3D',
      'primaryTextColor': '#fff',
      'pie1': '#F5004F',
      'pie2': '#FFEC3D',
      'pie3': '#88D66C'
    }
  }
}%%
pie showData title GKR Verify (Goldilocks) - 79.7ms
    "Lasso" : 39.5
    "Poly mult (FFT/IFFT)" : 5.1
    "Other operations" : 35.1
Loading

Known issues & limitations

  • GKR library used is not zero knowledge, thus may leak some sensitive information
  • Memory checking in Lasso uses challenge values sampled from the base field (not the extension field), which isn't secure enough when proving over the Goldilocks field
  • Number of ciphertexts ($k$) must be a power of two

Acknowledgements

Releases

No releases published

Packages

No packages published