Skip to content

Latest commit

 

History

History
32 lines (21 loc) · 1.01 KB

README.md

File metadata and controls

32 lines (21 loc) · 1.01 KB

circom-rsa-verify

This repository contains an implementation of a Zero Knowledge Proof for RSA signature verify for the Circom language. Currently supported pkcs1v15 + sha256 and exponent is 65537. The Montgomery Exponentiation algorithm and Montgomery CIOS product is used to calculate large numbers Modular exponentiation

Getting started

Running circuits test cases

git submodule update --init --recursive; cd circom-ecdsa; npm i; cd ..; npm i; npm test

Circuits Benchmark

RSA verify: pkcs1v15/sha256/2048 bits key

  • Env: Mac mini (M1, 2020). 8 cores. 8 threads

Circuit infomation

  • snarkJS: Curve: bn-128
  • snarkJS: # of Wires: 530676
  • snarkJS: # of Constraints: 536212
  • snarkJS: # of Private Inputs: 0
  • snarkJS: # of Public Inputs: 100
  • snarkJS: # of Labels: 583860
  • snarkJS: # of Outputs: 0

Ref

  1. Arithmetic of Finite Fields