pub struct BinaryAdd {}
Expand description

A structure that defines the custom operation BinaryAdd that implements the binary adder.

The binary adder takes two arrays of length-n bitstrings and returns the elementwise binary sum of these arrays, ignoring a possible overflow.

The last dimension of both inputs must be the same; it defines the length of input bitstrings. If input shapes are different, the broadcasting rules are applied (see the NumPy broadcasting rules). For example, if input arrays are of shapes [2,3], and [1,3], the resulting array has shape [2,3].

Each bitstring of the output contains n bits; thus, this operation does not handle overflows.

The binary adder is either depth- or size-optimized depending on the inlining mode.

This operation is needed for conversion between arithmetic and boolean additive MPC shares (i.e. A2B and B2A operations in MPC).

To use this and other custom operations in computation graphs, see Graph::custom_op.

Custom operation arguments

  • Node containing a binary array or scalar
  • Node containing a binary array or scalar

Custom operation returns

New BinaryAdd node

Example

let c = create_context().unwrap();
let g = c.create_graph().unwrap();
let t = array_type(vec![2, 3], BIT);
let n1 = g.input(t.clone()).unwrap();
let n2 = g.input(t.clone()).unwrap();
let n3 = g.custom_op(CustomOperation::new(BinaryAdd {}), vec![n1, n2]).unwrap();

Trait Implementations

Defines the logic of a custom operation. Read more

Specifies and returns the name of this custom operation. Read more

Formats the value using the given formatter. Read more

Deserialize this value from the given Serde deserializer. Read more

Feeds this value into the given Hasher. Read more

Feeds a slice of this type into the given Hasher. Read more

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Compare self to key and return true if they are equal.

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.