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

Add fields demo #45

Merged
merged 9 commits into from
Oct 19, 2023
Merged

Add fields demo #45

merged 9 commits into from
Oct 19, 2023

Conversation

xqft
Copy link
Contributor

@xqft xqft commented Oct 18, 2023

This adds the finite fields of bn254 with the sum and mul operations, and some mockups for the verifier

@xqft xqft changed the base branch from main to demo_verifier_eth October 18, 2023 16:53
@xqft xqft marked this pull request as ready for review October 19, 2023 17:41
@xqft xqft changed the title Demo verifier step1 Add fields demo Oct 19, 2023
Copy link
Contributor

@pablodeymo pablodeymo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

@pablodeymo pablodeymo merged commit 24ebb27 into demo_verifier_eth Oct 19, 2023
3 of 4 checks passed
@pablodeymo pablodeymo deleted the demo_verifier_step1 branch October 19, 2023 18:10
pablodeymo added a commit that referenced this pull request Oct 30, 2023
* WIP generating test proof

* KZG test generator done

* Add verifier index

* Update makefile

* Verifier steps

* chore: forge init

* forge install: forge-std

v1.7.1

* rest.yml removed

* Initial files

* serializedProof as an input

* Added some operations over bn254 using precompiles

* Moved bn254.sol

* BN254.sol file included

* Added bn254 test

* Fix test

* Deprecated old verifier

* Delete duplicated file

* Fix foundry submodule name

* WIP deserialize_proof in verifier.sol

* adding ark-bn254 crate

* bn254 file

* Add fields demo (#45)

* WIP Implementing Fields and Commitments

* Added inv field

* Added scalar field

* Added 'using for'

* Small tweak

* Added base field test

* Fixed base test, added scalar test

* Removed inv

* Solidity verifier step 2 (#51)

* WIP step 2

* WIP step 2

* Added polycomm msm, continued step2

* Added mask_custom

* Remove commented blocks

* Replace solidity verifier bn254 lib and fixes (#54)

* WIP replace bn254 lib

* Fix length

* Multiple fixes

* Added partial_verify run test

* Fix partial verify test

* Add CI job

* Added setup step to CI job

* Added ci make rule

* Use action

* Revert BN254

* Remove utils.sol

* Fix partial verify test

* New bn254 (#56)

* Revert "Revert BN254"

This reverts commit 934d3bb.

* Revert "Remove utils.sol"

This reverts commit 999ce22.

* Deserialize proof in solidity (#53)

* deserialization of opening proof

* improving error return in deserializeOpeningProof

* changes in test_deserialize_opening_proof

* small changes

* Demo verifier eth test deserialize (#57)

* Added rmp serialization

* Better test for deser

* Refactor, cleared some code

* Formatting

* Removed unused circuit_gen

* WIP Deserialize URS

* WIP URS deserialization

* Fixed deser, added test

* Added comments'

* Implemented pow for base field

* Removed unnecesary log

* Added FFT

* Fix fft

* WIP generating basis

* Finish iFFT

* Finished calculate_lagrange_bases

* Implemented inv for field

* Refactor xgcd

* Fixed lagrange_base nested arrays problem

* WIP Iterative FFT

* Finished iterative FFT

* Fixed circular dependency

---------

Co-authored-by: Pablo Deymonnaz <[email protected]>
Co-authored-by: Estéfano Bargas <[email protected]>

---------

Co-authored-by: Pablo Deymonnaz <[email protected]>
Co-authored-by: Pablo Deymonnaz <[email protected]>
pablodeymo added a commit that referenced this pull request Nov 1, 2023
* WIP generating test proof

* KZG test generator done

* Add verifier index

* Update makefile

* Verifier steps

* chore: forge init

* forge install: forge-std

v1.7.1

* rest.yml removed

* Initial files

* serializedProof as an input

* Added some operations over bn254 using precompiles

* Moved bn254.sol

* BN254.sol file included

* Added bn254 test

* Fix test

* Deprecated old verifier

* Delete duplicated file

* Fix foundry submodule name

* WIP deserialize_proof in verifier.sol

* adding ark-bn254 crate

* bn254 file

* Add fields demo (#45)

* WIP Implementing Fields and Commitments

* Added inv field

* Added scalar field

* Added 'using for'

* Small tweak

* Added base field test

* Fixed base test, added scalar test

* Removed inv

* Solidity verifier step 2 (#51)

* WIP step 2

* WIP step 2

* Added polycomm msm, continued step2

* Added mask_custom

* Remove commented blocks

* deserialization of opening proof

* improving error return in deserializeOpeningProof

* changes in test_deserialize_opening_proof

* Replace solidity verifier bn254 lib and fixes (#54)

* WIP replace bn254 lib

* Fix length

* Multiple fixes

* Added partial_verify run test

* Fix partial verify test

* Add CI job

* Added setup step to CI job

* Added ci make rule

* Use action

* Revert BN254

* Remove utils.sol

* Fix partial verify test

* small changes

* New bn254 (#56)

* Revert "Revert BN254"

This reverts commit 934d3bb.

* Revert "Remove utils.sol"

This reverts commit 999ce22.

* Added rmp serialization

* Better test for deser

* Refactor, cleared some code

* Formatting

* Removed unused circuit_gen

* WIP Deserialize URS

* WIP URS deserialization

* Fixed deser, added test

* Added comments'

* Implemented pow for base field

* Removed unnecesary log

* Added FFT

* Fix fft

* WIP generating basis

* Finish iFFT

* Finished calculate_lagrange_bases

* Implemented inv for field

* Refactor xgcd

* Fixed lagrange_base nested arrays problem

* WIP Iterative FFT

* Finished iterative FFT

* Fixed circular dependency

* Fix out of bounds err

* Uncomment test

* New pow of two related functions

* Fix get_primitive_root_of_unity()

* Remove conflict market

* Fix makefile

* Fix xgcd

* Fix inv scalar field

* Fix is_pow_of_two()

* Fix get_twiddles arr

* Fixed last part of calculate_lagrange_basis

* Fix flat polycomm

---------

Co-authored-by: Pablo Deymonnaz <[email protected]>
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

Successfully merging this pull request may close these issues.

2 participants