From 33fb0112fa6a94467ee567076450c79a7d1a22ab Mon Sep 17 00:00:00 2001 From: dante <45801863+alexander-camuto@users.noreply.github.com> Date: Fri, 19 Apr 2024 09:58:10 -0400 Subject: [PATCH 1/2] chore: update visibility writeup --- Visibility:_What_is_Private?.md | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/Visibility:_What_is_Private?.md b/Visibility:_What_is_Private?.md index 2db08b1..6f18142 100644 --- a/Visibility:_What_is_Private?.md +++ b/Visibility:_What_is_Private?.md @@ -10,7 +10,7 @@ Visibility is controlled in the circuit settings (`settings.json` file), and is The question of what is private is very much related to the question of what we are proving. These questions tend to be a bit subtle and are really about designing the overall cryptosystem, of which your ezkl proof is a part. We provide these options to enable many different constructions. It can take some thought to determine which is right for your use case. -At a high level, mark those things `private` that you want to be secret to the prover, and allow the prover to change freely. Mark things `public` if you want them to be baked into the setup, and generally available (although see the comments about weight visibility below). Setting a part to `hashed` is a way to commit to it, and also a way to build bridges between proofs, making sure that a piece of data (input, weights, or output) is the same in multiple proofs. Hashed parts are also useful to reduce calldata size for smart contracts, and to allow something to be signed. Finally making a part `encrypted` proves encryption inside the circuit, which is useful for some constructions such as marketplaces with escrow contracts. +At a high level, mark those things `private` that you want to be secret to the prover, and allow the prover to change freely. Mark things `public` if you want them to be baked into the setup, and generally available (although see the comments about weight visibility below). Setting a part to `hashed` is a way to commit to it, and also a way to build bridges between proofs, making sure that a piece of data (input, weights, or output) is the same in multiple proofs. Hashed parts are also useful to reduce calldata size for smart contracts, and to allow something to be signed. Finally, setting a part to `kzgcommit` is a way to commit to it, and also a way to build bridges between proofs, making sure that a piece of data (input, weights, or output) is the same in multiple proofs. Note that the proof file contains both the instance data (e.g. a hash of the model input and the actual output of the model) and the bytes of the cryptographic proof. These parts (instance data, proof bytes) are analogous to the message hash and signature in a digital signature. @@ -26,24 +26,26 @@ Then a verifier or verifier contract checks both the signature and the ezkl proo When a model's weights are marked `public`, the weights are fixed at setup (circuit definition time). These weights are extractable from the proving key or the onnx file, but they can be kept private from the verifier as they are not part of the verifying key, proof, settings, or srs. Proofs can only be produced against the specific weights used at setup, so the verifier itself serves as a kind of implicit commitment to the weights. If you want to make an explicit commitment to the weights, for example to tie them to another model or sign them, use the hashed Visibility. - Private: The weights are private to the prover, and can be chosen freely by the prover. -- Public: The weights are fixed by the setup, visible in the proving key, but not visible in the verifying key or verifier (although be aware of dictionary attacks). +- Fixed: The weights are fixed by the setup, fully visible in the proving key, and only committed to in the verifying key or verifier (although be aware of dictionary attacks). - Hashed: The weights are private, but the hash of the weights is in the proof file, preventing the prover from changing the weights. -- Encrypted: The encrypted weights are in the proof file, and part of the proof is that this encryption is correct. +- KZGCommit: The kzg commitments to the weights are in the proof file, preventing the prover from changing the weights. ## Input visibility - Private: The input is private to the prover, and can be chosen freely by the prover. - Public: The input is part of the proof file, shared with the verifier. +- Fixed: The input is fixed by the setup, fully visible in the proving key, and only committed to in the verifying key or verifier (although be aware of dictionary attacks). - Hashed: The input is not sent in the proof file, but a Poseidon hash of the input is sent instead. The input is chosen by the prover, but it has to match the hash. The verifier cannot determine the input from the hash alone (although beware of dictionary attacks). -- Encrypted: The proof contains the encryption of the input, and part of the proof is that this encryption is correct. +- KZGCommit: The kzg commitment to the input is in the proof file, preventing the prover from changing the input. ## Output visibility - Private: The model output is private to the prover, and can be chosen freely by the prover. - Public: The model output is part of the proof file, shared with the verifier. +- Fixed: The model output is fixed by the setup, fully visible in the proving key, and only committed to in the verifying key or verifier (although be aware of dictionary attacks). - Hashed: The model output is not sent in the proof file, but a Poseidon hash of the output is sent instead. The verifier cannot determine the output from the hash alone (although beware of dictionary attacks). -- Encrypted: The proof contains the encryption of the output, and part of the proof is that this encryption is correct. +- KZGCommit: The kzg commitment to the output is in the proof file, preventing the prover from changing the input. -------------------- From 009e7cb3cadbd36ffb4be3e0843a80662899fd80 Mon Sep 17 00:00:00 2001 From: dante <45801863+alexander-camuto@users.noreply.github.com> Date: Fri, 19 Apr 2024 09:59:03 -0400 Subject: [PATCH 2/2] Update Visibility:_What_is_Private?.md --- Visibility:_What_is_Private?.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Visibility:_What_is_Private?.md b/Visibility:_What_is_Private?.md index 6f18142..ee18bac 100644 --- a/Visibility:_What_is_Private?.md +++ b/Visibility:_What_is_Private?.md @@ -23,7 +23,7 @@ Then a verifier or verifier contract checks both the signature and the ezkl proo ## Weight visibility -When a model's weights are marked `public`, the weights are fixed at setup (circuit definition time). These weights are extractable from the proving key or the onnx file, but they can be kept private from the verifier as they are not part of the verifying key, proof, settings, or srs. Proofs can only be produced against the specific weights used at setup, so the verifier itself serves as a kind of implicit commitment to the weights. If you want to make an explicit commitment to the weights, for example to tie them to another model or sign them, use the hashed Visibility. +When a model's weights are marked `fixed`, the weights are fixed at setup (circuit definition time). These weights are extractable from the proving key or the onnx file, but they can be kept private from the verifier as they are not part of the verifying key, proof, settings, or srs. Proofs can only be produced against the specific weights used at setup, so the verifier itself serves as a kind of implicit commitment to the weights. If you want to make an explicit commitment to the weights, for example to tie them to another model or sign them, use the hashed or kzgcommit visibility. - Private: The weights are private to the prover, and can be chosen freely by the prover. - Fixed: The weights are fixed by the setup, fully visible in the proving key, and only committed to in the verifying key or verifier (although be aware of dictionary attacks).