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

chore(gpu): port fix to compression encoding #1903

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

pdroalves
Copy link
Contributor

  • Modifies the generation of the LUT used in decompression so that the delta is calculated with a different precision, as in the CPU implementation

closes: https://github.com/zama-ai/tfhe-rs-internal/issues/845

PR content/description

Check-list:

  • Tests for the changes have been added (for bug fixes / features)
  • Docs have been added / updated (for bug fixes / features)
  • Relevant issues are marked as resolved/closed, related issues are linked in the description
  • Check for breaking changes (including serialization changes) and add them to commit message following the conventional commit specification

@cla-bot cla-bot bot added the cla-signed label Dec 20, 2024
Copy link

⚠️ This PR contains unsigned commits. To get your PR merged, please sign those commits (git rebase --exec 'git commit -S --amend --no-edit -n' @{upstream}) and force push them to this branch (git push --force-with-lease).

If you're new to commit signing, there are different ways to set it up:

Sign commits with gpg

Follow the steps below to set up commit signing with gpg:

  1. Generate a GPG key
  2. Add the GPG key to your GitHub account
  3. Configure git to use your GPG key for commit signing
Sign commits with ssh-agent

Follow the steps below to set up commit signing with ssh-agent:

  1. Generate an SSH key and add it to ssh-agent
  2. Add the SSH key to your GitHub account
  3. Configure git to use your SSH key for commit signing
Sign commits with 1Password

You can also sign commits using 1Password, which lets you sign commits with biometrics without the signing key leaving the local 1Password process.

Learn how to use 1Password to sign your commits.

Watch the demo

- Modifies the generation of the LUT used in decompression so that the delta is calculated with a different precision, as in the CPU implementation
Copy link
Contributor

@tmontaigu tmontaigu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks ok to me

@pdroalves pdroalves added 4090_test Launch test on our CI 4090 desktop 4090_bench Launch integer bench on our CI 4090 desktop labels Dec 23, 2024
@github-actions github-actions bot removed 4090_bench Launch integer bench on our CI 4090 desktop 4090_test Launch test on our CI 4090 desktop labels Dec 23, 2024
uint32_t input_modulus_sup = input_message_modulus * input_carry_modulus;
uint32_t output_modulus_sup = output_message_modulus * output_carry_modulus;
uint32_t box_size = polynomial_size / input_modulus_sup;
Torus output_delta = (1ul << 63) / output_modulus_sup;
Copy link
Member

@IceTDrinker IceTDrinker Jan 2, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this does not work for Torus u32 (don't know if you still support that) also this can overflow as ul (unsigned long) is not guaranteed to be 64 bits

https://en.cppreference.com/w/cpp/language/types

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed. Good catch.

We haven't dropped support, although we have no test or active development for u32.

I will fix this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants