Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add CKKS Composite Scaling #910

Open
fdiasmor opened this issue Nov 21, 2024 · 0 comments · Fixed by #928 · May be fixed by #929, #931 or #932
Open

Add CKKS Composite Scaling #910

fdiasmor opened this issue Nov 21, 2024 · 0 comments · Fixed by #928 · May be fixed by #929, #931 or #932
Assignees
Labels
new feature New feature or request
Milestone

Comments

@fdiasmor
Copy link
Collaborator

fdiasmor commented Nov 21, 2024

CKKS Composite Scaling

This issue concerns the implementation of the composite scaling technique for CKKS presented in https://eprint.iacr.org/2023/1462.pdf. It enables high-precision RNS-CKKS when the hardware architecture word size is smaller than the scaling factor.

The enablement of the composite scaling CKKS as a feature into the OpenFHE library:

CKKS composite scaling is designed to achieve high-precision RNS-CKKS encrypted computation with scaling factors greater than the target hardware architecture's register word size. For example, with composite scaling, we can configure the RNS scaling factor to be 58 bits, i.e. choosing prime moduli with 58 bits of precision, and compute on an accelerator whose architecture's register size is 32 bits. This feature is introduced into the OpenFHE API as a new scaling technique. This new scaling technique mode is architected into 4 Pull Requests, each of which entails specific parts of the composite scaling technique enablement, as depicted in the diagram below. This includes generating composite prime moduli, where each level is represented by the product of d primes that fit in XX-bit registers (e.g., 32-bit registers), and d is greater than or equal to 2, known as the composite degree. Our new mode also extends its support to both the conventional bootstrapping algorithm and the most recently proposed Meta-BTS bootstrapping algorithm.

CKKSCompositeScalingIssue

It is introduced as a new scaling technique in OpenFHE. There are two ways to enable CKKS composite scaling:

  • By setting the scaling technique to COMPOSITESCALINGAUTO: This is the most suitable choice for any developer trying out or not familiar with the intricate details of composite scaling.

  • By setting the scaling technique to COMPOSITESCALINGMANUAL: This mode is meant for developers that wish to experiment with untested/unlikely combinations of composite scaling parameters that may only be functional under special circumstances. In those special cases, the program may be more sensitive to runtime errors due to insufficient availability of prime moduli for given certain values for the tuple <register word size, multiplicative depth, ring size>.

Composite Modulus Chain Generation

  • All prime moduli are NTT-friendly (tested up to 2^16).

  • All primes in the modulus chain are distinct from each other.

  • q_i = p_1 x ... x p_ d ~ 2 ^\delta, where \delta is the scaling factor, q_i is the composite coefficient modulus comprised of the prime moduli {p_1, ..., p_d}, and d is the composite degree that characterizes the composite scaling approach.

  • p_i is chosen to be very close 2^( (scalingModSize) / (composite degree) )

Composite Scaling Bootstrapping

  • Current implementation supports single-iteration CKKS bootstrapping.

  • Current implementation supports Meta-BTS (or multiple-iteration) CKKS bootstrapping.

Current Constraints

  • This current CKKS composite scaling implementation only supports single-key CKKS.

  • By design when operating on composite scaling mode (i.e., COMPOSITESCALINGAUTO), the target hardware platform is assumed to have fixed word size smaller than 64 bits. However, in general, it still works under the scenario where scaling factors greater than 64 bits running on hardware architectures having 64-bit register word size (this capability is still under refactoring).

  • Regardless of the target architecture word size, the OpenFHE library needs to be compiled using NATIVEINT=64 compilation flag.

  • COMPOSITESCALING<AUTO/MANUAL> scaling technique mode only works with the CKKS scheme.

  • The secret key distribution needs to be set to UNIFORM_TERNARY.

@fdiasmor fdiasmor added this to the Release 1.3.0 milestone Nov 21, 2024
@fdiasmor fdiasmor self-assigned this Nov 21, 2024
@fdiasmor fdiasmor changed the title Add Composite Scaling CKKS Add CKKS Composite Scaling Nov 21, 2024
@yspolyakov yspolyakov added the new feature New feature or request label Nov 22, 2024
dsuponitskiy pushed a commit that referenced this issue Jan 14, 2025
* Initial commit: adding composite scaling parameters and scaling tech mode.

* Initial commit: adding composite scaling parameters and scaling tech mode.

* Some review changes.

* Update composite scaling unittests and fix unittest runtime issue.

* Move COMPOSITESCALING support error handling.

* Disable composite scaling set methods for non-CKKS schemes.

* Removing additional constructor that accepts composite scaling parameters.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment