-
Notifications
You must be signed in to change notification settings - Fork 111
ABY3
ABY3 is a library-style framework for secure computation that provides fine-grained control over computation efficiency via multiple protocol support. It is modeled after ABY and supports exactly three parties.
It supports three sharing schemes: Arithmetic sharing, Boolean sharing, and Yao's garbled circuits. Specifically, it implements three protocols: X, Y, Z. Users can manually switch between circuit types during the secure computation.
ABY3 was not in the original paper; it was introduced later.
Threshold: ABY3 supports a 2-of-3 threshold based on a custom replicated secret sharing scheme. See [MR'18], Section 3.2.1.
There's a nicely commented tutorial in the repo that explains some of the library structure and types (it's not compiled by default though, you'll have to make your own main to do so). There isn't extended documentation listing, e.g. all secure types supported.
True to the spirit of ABY, ABY3 gives you plenty of power that can have a large effect on efficiency. In particular, the programmer can basically choose when rounds of communication happen.
There's also good documentation on how to compile the framework.