icon | order |
---|---|
bug |
86 |
!!! If you need direct technical support, join our Discord to post your question in the #ezkl-support-forum and tag @devhelp to get a response from the team. !!!
ezkl
is a command line tool, and a library that can be used from Rust or Python. You may want to use Python to create a neural network and export it. Though ezkl is built with Rust, you do not need to use Rust except possibly for installation.
No, Rust is not a requirement to use the library. As long as you have the ONNX file and proper input & output format of the model, you can use ezkl
.
Generating a structured reference string takes a considerable amount of time and memory. Make sure your machine has enough memory available and wait for the process to finish. Alternatively, download a pre-generated srs using get-srs
. This is both safer and faster.
All ezkl
requires is an onnx file and a JSON configuration of mock inputs and outputs of the neural network. At this time, it works best with PyTorch.
We believe that ezkl
is the fastest zkml package available, and we are working hard every day to make it faster. Feel free to run cargo bench
on your machine to see what the benchmarks are for your hardware.
No. We recently integrated a WASM verifier that you can use to verify proofs from your web application. You can also use the EVM verifier to verify proofs locally, or the command line ezkl verify
command.
A VerifyError is thrown when the Mock prover fails, often due to a mismatched shape problem in the model. Please verify that your input.json inputs and outputs match those of your .onnx file.
A DimMismatch error is thrown when there is a mismatch in the lengths of the tensor operands during circuit construction.
This error is thrown when there is an error during the creation of a lookup table.
A TableAlreadyAssigned Error is thrown when ezkl
attempts to initialize a lookup table that has already been initialized.
An UnsupportedOp Error is thrown when there is an operation in the ONNX file that ezkl
cannot yet handle. Please look at the supported operations under src/circuit/ops to get an idea of what operations ezkl
can handle.
This is a pyo3 error that occurs when a data type fails to be extracted from Python to Rust. Please make sure you are passing the correct data types when utilizing the python bindings.
InvalidLookupInputs is thrown when the wrong inputs were passed to a lookup node.
InvalidDims is thrown when there is a shape mismatch in circuit construction. Invalid dimensions were used for a node with the given index and description.
This error means that the wrong method was called to configure a node with the given index and description.
MissingNode is thrown when a requested node is missing in the graph with the given index.
OpMismatch is thrown when an unsupported method was called on a node with the given index and description.
UnsupportedOp is thrown when there is an operation in the onnx graph that isn't supported by ezkl
.
MissingParams is thrown when a node has missing parameters; please check the parameters in your model's operations.
MisformedParams is thrown when a node has misformed parameters; the error can stem from erroneous padding height and width dimensions, wrong kernel / data format, dilations that are not uint type, and more.
This error is typically thrown when no public variables are passed to the circuit configuration function.
ezkl
only supports divisions by constants.
ezkl
only supports constant exponents.
This error is thrown when attempting to rescale inputs for an operation.
This error is thrown when a model fails to load. Please check your onnx file for missing connections / unsupported layers. We suggest using Netron to view onnx files.