Skip to content

lazer-crypto/lazer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

lazer

A library for lattice-based zero-knowledge proofs.

Dependencies

The following hardware and software is required to build and run lazer:

  • Linux amd64 / x86-64 system
  • kernel version >= 4.18
  • avx512 and aes instruction set extensions
  • gcc compiler >= 13.2
  • make >= 4.2, cmake >= 3.26
  • sagemath >= 10.2
  • python3 >= 3.10, its development package and the cffi package

The following software is required to build the documentation:

  • sphinx >= 5.3 and the sphinxcontrib-bibtex package

The package was tested on Ubuntu 20.04 LTS and RHEL 8.10 with an 11th Gen Intel Core i7-11850H @ 2.50GHz and with the dependencies' versions equal to the listed above. We assume that it works with greater versions as well, as long as they are backward compatible. It may work with lesser versions as well. Note that during compilation, the cpu_features package will be cloned from GitHub, so also git and an internet connection are required.

Building the library

To reproduce the results from the paper "The LaZer Library: Lattice-Based Zero Knowledge and Succinct Proofs for Quantum-Safe Privacy", check out commit 10eafeca4cd53ff4fc54193dce904dbd0026fefd.

To reproduce the results from the paper "A Toolkit for Succinct Lattice-Based Zero Knowledge Proofs", check out commit 59a52f74ca39584edf77b4b8b7437dbd48f9ad94.

To build the lazer C library, from the base directory, run:

git submodule update --init --recursive

to clone Labrador's repository and

make all

To build lazer's python module, change to the python subdirectory and run:

make

(If this step fails, check that the python development package is installed.)

Now continue with the section corresponding to the commit you chose in the beginning.

The LaZer Library: Lattice-Based Zero Knowledge and Succinct Proofs for Quantum-Safe Privacy

Building and viewing the documentation

To build the html documentation, change to the docs subdirectory and run:

make html

(If you have multiple python versions installed, make sure sphinx uses the same version that was used to build the python module.)

To view the documentation open build/html/index.html in a browser e.g.:

firefox build/html/index.html

Building the C demos

The demos subdirectory has the C demos:

  • a blind signature implementation in blindsig
  • a PoK of Kyber1024 secrets (paper section 3.2,3.3) in kyber1024

To build a demo, go to the corresponding subdirectory and run:

make

This creates an executable called <name>-demo. Run the demo via:

./<name>-demo

Building and running the python demos for linear relations with norms

In the python subdirectory are all the python demos mentioned in the paper:

  • an anonymous credentials (paper section 6.2) in anon_cred
  • a blind signature implementation in blindsig
  • a PoK of Kyber1024 secrets (paper section 6.1) in kyber1024
  • the proof required in the Swoosh NIKE in swoosh
  • a proof for the general lattice relation As=t in demo

To build a demo, go to the corresponding subdirectory and run:

make

Each demo is implemented in a python script with the same name as its directory i.e., <demo>.py. To run a demo, go to the corresponding subdirectory <demo> and run:

python3 <demo>.py

Running the python demo for LaBRADOR

An aggregate signature (paper section 6.3) implementation is in the python subdirectory.

Run it via:

python3 agg_sig.py

Generating the demos' proof parameters from a specification

A demo's proof parameters are specified in files named *params.py in the demo's subdirectory. For convenience, the code gererated from those specifications is included in the package (the *params.h header files) such that make only runs the code generator when the specification is changed (or when the header file was deleted). Since the code generator is a sagemath script (scripts/lin-codegen.sage) that calls the lattice-estimator multiple times, the code generation process may take multiple minutes, especially for large parameter set, like for Swoosh.

The code generator can be used from the scripts subdirectory via:

sage lin-codegen.sage <specification> > <headerfile>

Instructions for artifact evaluation and result reproduction

  1. Set up a system that meets lazer's requirements decribed above.
  2. Obtain and build the library and demos as described above.
  3. The code for kyber proof in C from sections 3.2, 3.3 was extended by a main function and sample inpts and is available as a runnable demo in demos/kyber1024/kyber1024-demo.
  4. The code for kyber proof in python from section 6.1 is available as a runnable demo in python/kyber1024/kyber1024.py.
  5. The code for the anonymous credentials from section 6.2 is avalable as a runnable demo in python/anon_cred/anon_cred.py.
  6. The code for the aggregate signature from section 6.3 is available as a runnable demo in python/agg_sig.py.
  7. Detailed descriptions of the demos are in the documentation.
  8. If you want to do anything beyond verifying the paper's results, check out the documentation of the python module's interface.

A Toolkit for Succinct Lattice-Based Zero Knowledge Proofs

Building the benchmarks

To build the benchmarks, change to the python/succinct_zkp subdirectory and run make:

cd python/succinct_zkp

make

Instructions for artifact evaluation and result reproduction

  1. Set up a system that meets the dependencies decribed above.
  2. Download and build the library as described above.
  3. Build the benchmarks as described above.
  4. Run the following benchmarks from the python/succinct_zkp subdirectory:
    • python3 benchmark_expansion.py (corresponds to Table 1)
    • python3 benchmark_compression.py (corresponds to Table 2)
    • python3 benchmark_membership_proof.py (corresponds to Table 3)
    • python3 benchmark_blind_sign.py (corresponds to Table 4)

The timings reported in the paper correspond to the medians printed when running the above benchmarks on a single core of an Intel Tiger Lake-H CPU.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors