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

Floating point mathematics for TFHE-rs #92

Closed
Lcressot opened this issue Dec 31, 2023 · 4 comments
Closed

Floating point mathematics for TFHE-rs #92

Lcressot opened this issue Dec 31, 2023 · 4 comments
Assignees
Labels
📄 Grant application This project is currently being reviewed by the Zama team ❌ Not selected Proposition or submission not selected 📁 TFHE-rs library targeted: TFHE-rs

Comments

@Lcressot
Copy link

Zama Bounty Program: Proposition

  • Library targeted:
    TFHE-rs
  • Overview:
    I propose to implement a class to represent signed float numbers in tfhe-rs (using a quantized representation) along with elementary math functions for these numbers. This will make the computation of basic statistics (such as mean and variance) possible for encrypted numbers.
  • Description:
  1. Signed quantized floats:
    The numbers will be represented as arrays of 1 block integer ciphertexts, with chosen maximum value and float precision.
    Elementary operators will be coded: equality, gt,ge,lt,le, addition, subtraction, multiplication, division.
    Clear conversion from and toward rust float will be provided.

Note: This part will be a rust adaptation of quantized floating point numbers developed for concrete (see QFloat class in matrix inversion bounty). It will be faster because it will use maximaly massive parallelization with rayon. While a lot of the code will be reused, rust adaptation is not straightforward and is expected to need more code than the concrete python version because concrete python does a lot of operations internally.

  1. Math operations:
    i. sum, mean, scalar product of vectors of encrypted floats
    ii. Integer exponentiation: pow(x: encryptedFloat, y: int) where x is an encrypted float and y a clear integer.
    iii. Cos, sin, tan for encrypted floats
    iv. Variance, median for arrays of encrypted floats

  2. Square root (with newton-raphson method) + standard deviation of encrypted floats

  3. A main with tests for 1., 2. and 3.

  • Reward (split by milestones):
  1. 4k $ (~2-3 full weeks)
  2. 2k $ (~5-7 days)
  3. 1k $ (~2-3 days)
  4. 0$ (included)
@zama-bot
Copy link

Hello Lcressot,

Thank you for your bounty proposition! Our team will review and add comments in your issue! In the meantime:

  1. Join the FHE.org discord server for any questions (you’ll find a dedicated #zama-bounty-program channel).
  2. Ask questions privately: [email protected].

Talk soon,

@aquint-zama
Copy link
Collaborator

aquint-zama commented Jan 8, 2024

Hello @Lcressot,

Thank you for this proposition. We are currently reviewing the regular bounties but we will get back to you
soon.

@zaccherinij zaccherinij moved this from Accepted grants to Grant applications in Zama Bounty and Grant Program Overview Feb 9, 2024
@zaccherinij zaccherinij added the 📄 Grant application This project is currently being reviewed by the Zama team label Feb 9, 2024
@aquint-zama
Copy link
Collaborator

Hello @Lcressot,

Thank you for your suggestion. While the idea looks interesting, it's still an open area of research internally and we are yet not sure about the proper approach for supporting decimal numbers.

Also we are encouraging grants that are actually applications using tfhe-rs, rather than contribution to the code, which can be harder to integrate and maintain over time on our side.

For these reasons we won't go further with this suggestion.

Cheers,

@github-project-automation github-project-automation bot moved this from Grants application to Awarded Contributions in Zama Bounty and Grant Program Overview Feb 9, 2024
@aquint-zama aquint-zama added the ❌ Not selected Proposition or submission not selected label Feb 9, 2024
@Lcressot
Copy link
Author

Lcressot commented Feb 9, 2024 via email

@zaccherinij zaccherinij added the 📁 TFHE-rs library targeted: TFHE-rs label May 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
📄 Grant application This project is currently being reviewed by the Zama team ❌ Not selected Proposition or submission not selected 📁 TFHE-rs library targeted: TFHE-rs
Projects
Development

No branches or pull requests

4 participants