Cupcake is a powerful Rust library for the additive version of the Fan-Vercauteren homomorphic encryption scheme. It provides robust encryption of vectors, enabling operations such as vector addition, subtraction, and ciphertext rerandomization.
- Requirements
- Installation
- Building from Source
- Examples
- Documentation
- Benchmarks and Tests
- Supported Parameters
- References
- Contributing
- License
Cupcake is compatible with the following platforms:
- Mac OS X
- Linux
Getting started with Cupcake is easy, even if you're new to Rust or Cargo. Follow these clear installation instructions:
1. Install Rust:
If you haven't already, you'll need to install Rust, the programming language Cupcake is built with. You can do this by following the instructions at Rust's official website. Rust's package manager, Cargo, will be installed automatically with Rust.
2. Create a New Rust Project (Optional):
If you're starting a new project, you can create a new Rust project folder. Navigate to your desired project directory and run:
cargo new my_cupcake_project
cd my_cupcake_project
To include Cupcake in your Rust project, simply add the following line to your `Cargo.toml` file:
Cupcake = "0.2.1"
git clone https://github.com/facebookresearch/Cupcake
cd cupcake
cargo build --release
Several examples are included in examples/<name>.rs
, and can be run via
cargo run --example <name>
Documentation on the API can be built from cargo doc
.
To maintain the high standards of reliability and performance, Cupcake includes benchmarking and testing tools. These tools play a crucial role in the development and utilization of the library.
Benchmarks: Benchmarks help gauge the efficiency of Cupcake's operations. By running benchmarks, you can identify which operations are faster and optimize your cryptographic workflows accordingly. Efficient operations are vital in applications that require real-time processing, such as secure data analytics and privacy-preserving machine learning.
Execute benchmarks with:
cargo bench
Tests: Testing ensures the correctness and reliability of Cupcake's functionality. It verifies that cryptographic operations produce accurate results, making Cupcake a trustworthy choice for your encryption needs. Rigorous testing helps uncover and fix potential issues early in the development process, ensuring the security of your applications.
Run the tests with:
cargo test
.
Currently, we provide only one set of secure parameter, namely FV::<Scalar>::default_2048();
. This parameter set has an estimated security level of about 128 bits according
to the homomorphic encryption security standards link. Use other parameters at your own risk! With the default parameter set, the plaintext type is vector of u8
with a fixed length 2048.
While Cupcake offers flexibility to work with other parameter sets, it's important to exercise caution when doing so. Changing parameters can affect the security guarantees and performance characteristics of the encryption scheme. Always assess your specific requirements and consult cryptography experts if you consider using custom parameters.
Understanding the relevance of these parameters is essential for making informed decisions about the security and performance of your applications.
See the CONTRIBUTING file for how to help out.
Cupcake is MIT licensed, as found in the LICENSE file.