5个版本 (破坏性)

0.5.0 2024年4月4日
0.4.0 2024年4月1日
0.3.0 2024年3月31日
0.2.0 2024年3月31日
0.1.0 2024年3月31日

#727 in 算法

每月 36 次下载

MITLGPL-3.0+

24KB
576

bgv-rs

高效的FHE库

快速入门

[dependencies]
bgv = "0.5.0"

示例

use rand::Rng;
use bgv::{math, BGV};

const T: u64 = 65537; // plaintext modulus
const N: usize = 1024; // polynomial degree
const L: usize = 15; // levels
const NBITS: u8 = 50; // small prime bit length
const MU: f64 = 0.0; // sampling mean
const SIGMA: f64 = 3.19; // sampling std. dev

let mut rng = rand::thread_rng();
let b = BGV::new(N, L, NBITS, MU, SIGMA, T);
let k = b.key_gen(); // generate keys

let m1: Vec<u64> = (0..N).map(|_| rng.gen_range(0..T) as u64).collect();
let m2: Vec<u64> = (0..N).map(|_| rng.gen_range(0..T) as u64).collect();
let sum: Vec<u64> = (0..N).map(|i| math::modadd(m1[i], m2[i], T)).collect();

let x = b.encrypt(&m1, &k.pk);
let y = b.encrypt(&m2, &k.pk);
let c = b.add(&x, &y); // homomorphic addition

let m3 = b.decrypt(&c, &k.s);
assert_eq!(m3, sum);

lib.rs:

高效的FHE库

示例

 use rand::Rng;
 use bgv::{math, BGV};

 const T: u64 = 65537;
 const N: usize = 1024;
 const L: usize = 15;
 const NBITS: u8 = 50;
 const MU: f64 = 0.0;
 const SIGMA: f64 = 3.19;

 let mut rng = rand::thread_rng();
 let b = BGV::new(N, L, NBITS, MU, SIGMA, T);
 let k = b.key_gen();

 let m1: Vec<u64> = (0..N).map(|_| rng.gen_range(0..T) as u64).collect();
 let m2: Vec<u64> = (0..N).map(|_| rng.gen_range(0..T) as u64).collect();
 let sum: Vec<u64> = (0..N).map(|i| math::modadd(m1[i], m2[i], T)).collect();

 let x = b.encrypt(&m1, &k.pk);
 let y = b.encrypt(&m2, &k.pk);
 let c = b.add(&x, &y);

 let m3 = b.decrypt(&c, &k.s);
 assert_eq!(m3, sum);

依赖项

~4.5MB
~84K SLoC