Skip to content

Latest commit

 

History

History
276 lines (193 loc) · 9.39 KB

README.md

File metadata and controls

276 lines (193 loc) · 9.39 KB

ICICLE

ICICLE is a high-performance cryptographic acceleration library designed to optimize cryptographic computations across various hardware platforms, including CPUs, GPUs, and other accelerators.


ICICLE



Chat with us on Discord Follow us on LinkedIn Follow us on Twitter

Background

Zero Knowledge Proofs (ZKPs) are considered one of the greatest achievements of modern cryptography. Accordingly, ZKPs are expected to disrupt a number of industries and will usher in an era of trustless and privacy preserving services and infrastructure.

We believe that ICICLE will be a cornerstone in the acceleration of ZKPs:

  • Versatility: Supports multiple hardware platforms, making it adaptable to various computational environments.
  • Efficiency: Designed to leverage the parallel nature of ZK computations, whether on GPUs, CPUs, or other accelerators.
  • Scalability: Provides an easy-to-use and scalable solution for developers, allowing them to optimize cryptographic operations with minimal effort.

Getting Started

This is a version of ICICLE specifically meant for integration with the Gnark codebase.

Note

Developers: We highly recommend reading our documentation for a comprehensive explanation of ICICLE’s capabilities.

Prerequisites

  • Any compatible hardware: ICICLE supports various hardware, including CPUs, Nvidia GPUs, and other accelerators.
  • CMake, Version 3.18 or above. Latest version recommended. Required only if building from source.
  • CUDA Toolkit, Required only if using NVIDIA GPUs (version 12.0 or newer).

Note

For older GPUs that only support CUDA 11, ICICLE may still function, but official support is for CUDA 12 onwards.

Accessing Hardware

If you don't have access to an Nvidia GPU we have some options for you.

Google Colab offers a free T4 GPU instance and ICICLE can be used with it, reference this guide for setting up your Google Colab workplace.

If you require more compute and have an interesting research project, we have bounty and grant programs.

Building ICICLE from source

ICICLE provides build systems for C++ and Go. Each build system incorporates the core ICICLE library, which contains the essential cryptographic primitives. Refer to the Getting started page for full details about building and using ICICLE.

Warning

Ensure ICICLE libraries are installed correctly when building or installing a library/application that depends on ICICLE so that they can be located at runtime.

Go

There are two ways to build from source in Go:

  1. Clone the repo, update your go.mod to point to the local clone, and build ICICLE within the clone
git clone https://github.com/ingonyama-zk/icicle-gnark.git

Add ICICLE v3 to your go.mod file:

require github.com/ingonyama-zk/icicle-gnark/v3 v3.0.0

replace github.com/ingonyama-zk/icicle-gnark/v3 => ../path/to/cloned/icicle

Navigate to the cloned repo's golang bindings and build the library using the supplied build script

cd icicle/wrappers/golang
chmod +x build.sh
./build.sh -curve=bn254
  1. Update your go.mod to include ICICLE as a dependency, navigate to the dependency in your GOMODCACHE and build ICICLE there
go get github.com/ingonyama-zk/icicle-gnark/v3
cd $(go env GOMODCACHE)/github.com/ingonyama-zk/icicle-gnark/v3@<version>/wrappers/golang
chmod +x build.sh
./build.sh -curve=bn254

Note

To specify the field, use the flag -field=, where can be one of the following: babybear, stark252, m31. To specify a curve, use the flag -curve=, where can be one of the following: bn254, bls12_377, bls12_381, bw6_761, grumpkin.

Once ICICLE has been built, you can add specific packages when you need them in your application:

import (
  runtime "github.com/ingonyama-zk/icicle-gnark/v3/wrappers/golang/runtime"
  core "github.com/ingonyama-zk/icicle-gnark/v3/wrappers/golang/core"
  bn254 "github.com/ingonyama-zk/icicle-gnark/v3/wrappers/golang/curves/bn254"
  bn254MSM "github.com/ingonyama-zk/icicle-gnark/v3/wrappers/golang/curves/bn254/msm"
)

C++

ICICLE can be built and tested in C++ using CMake. The build process is straightforward, but there are several flags you can use to customize the build for your needs.

Clone the ICICLE repository:

git clone https://github.com/ingonyama-zk/icicle-gnark.git
cd icicle

Configure the build:

mkdir -p build && rm -rf build/*
cmake -S icicle -B build -DFIELD=babybear

Note

To specify the field, use the flag -DFIELD=field, where field can be one of the following: babybear, stark252, m31. To specify a curve, use the flag -DCURVE=curve, where curve can be one of the following: bn254, bls12_377, bls12_381, bw6_761, grumpkin.

Build the project:

cmake --build build -j # -j is for multi-core compilation

Link your application (or library) to ICICLE:

target_link_libraries(yourApp PRIVATE icicle_field_babybear icicle_device)

Install (optional):

To install the libs, specify the install prefix -DCMAKE_INSTALL_PREFIX=/install/dir/. Then after building, use cmake to install the libraries:

cmake -S icicle -B build -DCMAKE_INSTALL_PREFIX=/path/to/install/dir/
cmake --build build -j # build
cmake --install build # install icicle to /path/to/install/dir/

Run tests (optional):

Caution

Most tests assume a CUDA backend exists and will fail otherwise, if a CUDA device is not found.

Add -DBUILD_TESTS=ON to the cmake command, build and execute tests:

cmake -S icicle -B build -DBUILD_TESTS=ON
cmake --build build -j
cd build/tests
ctest

or choose the test-suite

./build/tests/test_field_api # or another test suite
# can specify tests using regex. For example for tests with ntt in the name:
./build/tests/test_field_api --gtest_filter="*ntt*"

Build Flags:

You can customize your ICICLE build with the following flags:

  • -DCMAKE_INSTALL_PREFIX=/install/dir: Specify install directory. default=/usr/local.
  • -DBUILD_TESTS=ON/OFF: Enable or disable tests. default=OFF.
  • -DBUILD_BENCHMARKS=ON/OFF: Enable or disable benchmarks. default=OFF.

Install CUDA backend

The backend is automatically built when compiling the library.

Go:

import(
  "github.com/ingonyama-zk/icicle-gnark/v3/wrappers/golang/runtime"
)

result := runtime.LoadBackendFromEnvOrDefault()
// Select CUDA device
device := runtime.CreateDevice("CUDA", 0) // or other
result := runtime.SetDevice(device)

// Any call will now execute on GPU-0

C++:

#include "icicle/runtime.h"

// Load the installed backend
eIcicleError result = icicle_load_backend_from_env_or_default();
// or load it programmatically
eIcicleError result = icicle_load_backend("/path/to/backend/installdir", true);

// Select CUDA device
icicle::Device device = {"CUDA", 0 /*gpu-id*/};
eIcicleError result = icicle_set_device(device);

// Any call will now execute on GPU-0

Full details can be found in our getting started docs

Contributions

Join our Discord Server and find us on the ICICLE channel. We will be happy to work together to support your use case, and talk features, bugs and design.

Development Contributions

Please see the main ICICLE repo for contributing.

Help & Support

For help and support talk to our devs in our discord channel #ICICLE or contact us at [email protected].

License

This version of ICICLE is distributed under the terms of the MIT License.

See LICENSE-MIT for details.