c-kzg-4844/README.md

61 lines
1.4 KiB
Markdown
Raw Normal View History

# C-KZG-4844
2022-11-01 14:24:02 +00:00
This is a minimal library for EIP-4844 that implements the [Polynomial
Commitments](https://github.com/ethereum/consensus-specs/blob/dev/specs/deneb/polynomial-commitments.md)
API. It was originally a stripped-down copy of
[C-KZG](https://github.com/benjaminion/c-kzg), but it has been heavily modified
since then.
## Interface functions
There are functions for KZG operations:
2022-11-04 23:56:16 +00:00
2022-11-01 14:24:02 +00:00
- `blob_to_kzg_commitment`
- `compute_kzg_proof`
- `compute_blob_kzg_proof`
- `verify_kzg_proof`
- `verify_blob_kzg_proof`
- `verify_blob_kzg_proof_batch`
2022-11-01 14:24:02 +00:00
There are functions for loading/freeing the trusted setup:
- `load_trusted_setup`
- `load_trusted_setup_file`
- `free_trusted_setup`
2022-11-04 23:56:16 +00:00
## Bindings
There are bindings for the following languages:
| Language | Link |
|----------|--------------------------------------|
| C# | [README](bindings/csharp/README.md) |
| Go | [README](bindings/go/README.md) |
| Java | [README](bindings/java/README.md) |
2023-03-08 13:04:30 +00:00
| Nim | [README](bindings/nim/README.md) |
| Node.js | [README](bindings/node.js/README.md) |
| Python | [README](bindings/python/README.md) |
| Rust | [README](bindings/rust/README.md) |
2022-11-04 23:56:16 +00:00
## Installation
Initialize the blst submodule:
2022-11-04 23:56:16 +00:00
```
git submodule update --init
```
Build the blst library:
2022-11-04 23:56:16 +00:00
```
cd src
make blst
```
Build/test the C-KZG-4844 library:
2022-11-04 23:56:16 +00:00
```
cd src
make
```