mirror of
https://github.com/arnaucube/poulpy.git
synced 2026-02-10 05:06:44 +01:00
Enables external circuits to be called
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<4>),
|
||||
B1(BitCircuit<8>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<4>),
|
||||
B1(BitCircuit<4>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<4>),
|
||||
B1(BitCircuit<4>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<12>),
|
||||
B1(BitCircuit<18>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 37;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<256>),
|
||||
}
|
||||
@@ -10,16 +10,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 1usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
1
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 1;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 1usize> = Circuit([AnyBitCircuit::B0(BitCircuit::new(
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<256>),
|
||||
}
|
||||
@@ -10,16 +10,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 1usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
1
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 1;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 1usize> = Circuit([AnyBitCircuit::B0(BitCircuit::new(
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<192>),
|
||||
B1(BitCircuit<186>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 37;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<192>),
|
||||
B1(BitCircuit<192>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 37;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<4>),
|
||||
B1(BitCircuit<8>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitInfo, Circuit, GetBitCircuitInfo, Node};
|
||||
use crate::tfhe::bdd_arithmetic::{BitCircuit, BitCircuitFamily, BitCircuitInfo, Circuit, Node};
|
||||
pub(crate) enum AnyBitCircuit {
|
||||
B0(BitCircuit<4>),
|
||||
B1(BitCircuit<4>),
|
||||
@@ -72,16 +72,9 @@ impl BitCircuitInfo for AnyBitCircuit {
|
||||
}
|
||||
}
|
||||
|
||||
impl GetBitCircuitInfo<u32> for Circuit<AnyBitCircuit, 32usize> {
|
||||
fn input_size(&self) -> usize {
|
||||
2 * u32::BITS as usize
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
u32::BITS as usize
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
impl BitCircuitFamily for AnyBitCircuit {
|
||||
const INPUT_BITS: usize = 64;
|
||||
const OUTPUT_BITS: usize = 32;
|
||||
}
|
||||
|
||||
pub(crate) static OUTPUT_CIRCUITS: Circuit<AnyBitCircuit, 32usize> = Circuit([
|
||||
|
||||
@@ -19,13 +19,33 @@ pub trait GetBitCircuitInfo<T: UnsignedInteger> {
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize);
|
||||
}
|
||||
|
||||
pub(crate) struct BitCircuit<const N: usize> {
|
||||
pub(crate) nodes: [Node; N],
|
||||
pub(crate) max_inter_state: usize,
|
||||
pub struct BitCircuit<const N: usize> {
|
||||
pub nodes: [Node; N],
|
||||
pub max_inter_state: usize,
|
||||
}
|
||||
|
||||
pub trait BitCircuitFamily {
|
||||
const INPUT_BITS: usize;
|
||||
const OUTPUT_BITS: usize;
|
||||
}
|
||||
|
||||
pub struct Circuit<C: BitCircuitInfo, const N: usize>(pub [C; N]);
|
||||
|
||||
impl<C, T: UnsignedInteger, const N: usize> GetBitCircuitInfo<T> for Circuit<C, N>
|
||||
where
|
||||
C: BitCircuitInfo + BitCircuitFamily,
|
||||
{
|
||||
fn input_size(&self) -> usize {
|
||||
C::INPUT_BITS
|
||||
}
|
||||
fn output_size(&self) -> usize {
|
||||
C::OUTPUT_BITS
|
||||
}
|
||||
fn get_circuit(&self, bit: usize) -> (&[Node], usize) {
|
||||
self.0[bit].info()
|
||||
}
|
||||
}
|
||||
|
||||
pub trait ExecuteBDDCircuit<T: UnsignedInteger, BE: Backend> {
|
||||
fn execute_bdd_circuit<C, G, O>(&self, out: &mut [GLWE<O>], inputs: &G, circuit: &C, scratch: &mut Scratch<BE>)
|
||||
where
|
||||
@@ -51,7 +71,7 @@ where
|
||||
{
|
||||
#[cfg(debug_assertions)]
|
||||
{
|
||||
assert_eq!(inputs.bit_size(), circuit.input_size());
|
||||
assert!(inputs.bit_size() >= circuit.input_size());
|
||||
assert!(out.len() >= circuit.output_size());
|
||||
}
|
||||
|
||||
@@ -119,7 +139,7 @@ where
|
||||
}
|
||||
|
||||
impl<const N: usize> BitCircuit<N> {
|
||||
pub(crate) const fn new(nodes: [Node; N], max_inter_state: usize) -> Self {
|
||||
pub const fn new(nodes: [Node; N], max_inter_state: usize) -> Self {
|
||||
Self {
|
||||
nodes,
|
||||
max_inter_state,
|
||||
|
||||
@@ -9,7 +9,7 @@ pub use bdd_2w_to_1w::*;
|
||||
pub use blind_rotation::*;
|
||||
pub use ciphertexts::*;
|
||||
pub(crate) use circuits::*;
|
||||
pub(crate) use eval::*;
|
||||
pub use eval::*;
|
||||
pub use key::*;
|
||||
|
||||
pub mod tests;
|
||||
|
||||
Reference in New Issue
Block a user