5 个不稳定版本
0.3.0 | 2024年5月21日 |
---|---|
0.2.6 | 2024年5月21日 |
0.2.5 | 2024年5月21日 |
0.2.1 | 2024年5月21日 |
0.1.0 | 2024年5月21日 |
#2615 in 神奇豆子
35KB
644 行
PeerDAS KZG
是什么
这是一个兼容以太坊区块链中使用的 PeerDAS KZG 承诺方案的密码学库。
为什么
此库中实现的密码学是 Ethereum 版本数据可用性采样(DAS)的先决条件。该库以模块化的方式实现,因此也可以使用底层的多项式承诺方案,用于不同的目的。
构建源代码
此库是用 Rust 编写的,并提供对 C、C#、node.js、golang、Java 和 Nim 的绑定。这些绑定可以在 bindings
文件夹中找到。这些绑定公开了一个与 Ethereum 需要的 API 兼容的 API。
如果您只想修改密码学,则需要 Rust 编译器。对于绑定,应检查相应语言的 README 文件以了解其他要求。
构建所有内容
要构建包括绑定所需的艺术品在内的所有内容,可以运行
./scripts/compile.sh
要仅构建本机 Rust 代码,可以运行
cargo build
基准测试
可以通过调用来运行基准测试
cargo bench
注意:这将基准测试底层的 Rust 库。它不会考虑(如果有)通过特定语言调用库时的任何差异。一个例子是调用 Golang 中的外国语言时的 CGO 开销;在我们的情况下,这种开销与实际进行的计算相比可以忽略不计。
许可证
根据以下之一许可和分发:
MIT 许可证:LICENSE-MIT 或 http://opensource.org/licenses/MIT
或
Apache许可证,版本2.0(LICENSE-APACHEv2或https://apache.ac.cn/licenses/LICENSE-2.0),由您选择。除非根据这些条款,否则不得复制、修改或分发这些文件。
依赖项
~9MB
~246K SLoC