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

LowMC in Bristol Fashion #1

Open
jacob14916 opened this issue Jun 30, 2022 · 4 comments
Open

LowMC in Bristol Fashion #1

jacob14916 opened this issue Jun 30, 2022 · 4 comments

Comments

@jacob14916
Copy link

Hi Marcel!
@GnarlyMshtep and I are working on implementing a protocol in MP-SPDZ that uses the LowMC cipher. Would it be possible to add LowMC to this repo? Do you know of any generators for LowMC in Bristol Fashion? We couldn't find any online.
Thanks,
Jacob

@mkskeller
Copy link
Owner

I'm not aware of any work in this direction, but @rdragos might know more. I'm happy to add LowMC to this repo. Please add a note that you put your contribution under the existing BSD license or public domain.

@rdragos
Copy link

rdragos commented Jul 2, 2022

I am not aware of any work as well, probably the closest thing you can get is a VHDL implementation of LowMC here. From what I can tell VHDL has been used to convert the floating point arithmetic to Bristol Circuits, perhaps you can use that as a starting point, see for more details how SCALE-MAMBA has done it here.

The CCS'16 paper on MPC friendly primitives contains code for evaluating LowMC for arithmetic circuits in F_{2^{128}}. I can link you to that if you want although it's old research code which is pretty hard to use.

@jacob14916
Copy link
Author

jacob14916 commented Jul 2, 2022

I emailed Michael Zohner and he pointed me to this example from the ABY project which with one line of modification can output LowMC circuits in Bristol format. Unfortunately, it is only the first version of LowMC and so does not contain any of the security updates or optimizations that came after, all of which we need for our paper. We will likely end up generating our own circuits by modifying that example.

@rdragos, is the MPC friendly primitives paper this one? Reading through the paper, I encountered the Legendre PRF. It seems almost too good to be true - are there any qualifications to the recommendation to use it in the low latency setting that you included at the end of the paper? Would it be, for instance, looked down upon by the community as a non-standard assumption? Or if it is so good, why hadn't I heard of it before?

@rdragos
Copy link

rdragos commented Jul 2, 2022

@jacob14916, the reason you might not have heard about it is that it's relatively new (2016) and people prefer using a tradition blockcipher to encrypt their data locally (since that is faster on the client side) and then do the decryption inside MPC.

Usually people stick to the standards (in industry) when it comes for clients trying to encrypt their data.

As for the cryptanalysis of Legendre PRF the most recent paper (I know of) is by Beullens et al.. It was used further by Beullens and Delpech de Saint Guilhem for developing post quantum signatures.

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

No branches or pull requests

3 participants