circom

zkSnark 电路编译器。「zkSnark circuit compiler」

Github星跟蹤圖

Chat on Telegram
Website
GitHub top language

About ==>circom

CIRCUIT COMPILER FOR ZK PROVING SYSTEMS

Circom is a novel domain-specific language for defining arithmetic circuits that can be used to generate zero-knowledge proofs. Circom compiler is a circom language compiler written in Rust that can be used to generate a R1CS file with a set of associated constraints and a program (written either in C++ or WebAssembly) to efficiently compute a valid assignment to all wires of the circuit. One of the main particularities of circom is its modularity that allows the programmers to define parameterizable circuits called templates, which can be instantiated to form larger circuits. The idea of building circuits from small individual components makes it easier to test, review, audit, or formally verify large and complex circom circuits. In this regard, circom users can create their own custom templates or instantiate templates from circomLib, a publicly available library that counts with hundreds of circuits such as comparators, hash functions, digital signatures, binary and decimal converters, and many more. Circomlib is publicly available to practitioners and developers.

The implementations of proving systems are also available in our libraries including snarkjs, written in Javascript and Pure Web Assembly, wasmsnark written in native Web Assembly, rapidSnark written in C++ and Intel Assembly.

Circom aims to provide developers a holistic framework to construct arithmetic circuits through an easy-to-use interface and abstracting the complexity of the proving mechanisms.

Circom language reference can be found at circom language reference

At this time there are two available syntax highlighters: circom Visual Studio Code highlight syntax and circom Vim highlight syntax

Documentation

All documentation is available in circom 2 Documentation, we encourage you to read it. If you are new start with the Getting started section.
Basic background on Zero-knowledge proofs can be found on Background section

Install

Refer to Installation section

:warning: Deprecation note

The previous circom 1 compiler written in Javascript is deprecated, but circom 1 repository is still available

Community

Thank you for considering contributing to the circom & snarkjs framework!

As the circom and snarkjs community grows new tools, circuits, or projects have appeared. Here we link some of them:

CIRCUITS

TOOLS

主要指標

概覽
名稱與所有者iden3/circom
主編程語言WebAssembly
編程語言Rust (語言數: 6)
平台Linux, Mac, Windows
許可證GNU General Public License v3.0
所有者活动
創建於2021-10-11 07:55:24
推送於2025-04-07 21:03:05
最后一次提交2025-04-07 23:03:05
發布數23
最新版本名稱v2.2.2 (發布於 )
第一版名稱v2.0.0 (發布於 2022-06-24 10:27:48)
用户参与
星數1.5k
關注者數21
派生數325
提交數1k
已啟用問題?
問題數168
打開的問題數56
拉請求數125
打開的拉請求數45
關閉的拉請求數34
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?