From 72f35262f6fcbe583d529807b00fdd012f8ccee6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lancelot=20de=20Ferri=C3=A8re?= Date: Wed, 15 May 2024 18:36:34 +0200 Subject: [PATCH] Fix binary protocol serialisation examples to align with reality The witness is prepended wit more information than currently stated / it's unclear. --- docs/HowTo/serialize.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/docs/HowTo/serialize.md b/docs/HowTo/serialize.md index 36e0c9f..91273cb 100644 --- a/docs/HowTo/serialize.md +++ b/docs/HowTo/serialize.md @@ -75,12 +75,14 @@ For performance reason (witnesses can be large), witnesses should be encoded usi While there is no standard yet, we followed similar patterns used by other zk-SNARK libraries. ```no-lang -// Full witness -> [uint32(nbElements) | publicVariables | secretVariables] +// Full witness -> [uint32(nbPublicElements) | uint32(nbPrivateElements) | uint32(nbElements) | publicVariables | secretVariables] // Public witness -> [uint32(nbElements) | publicVariables ] ``` Where: +- `nbPublicElements == len(publicVariables)`. +- `nbPrivateElements == len(secretVariables)`. - `nbElements == len(publicVariables) + len(secretVariables)`. - each variable (a _field element_) is encoded as a big-endian byte array, where `len(bytes(variable)) == len(bytes(modulus))` @@ -100,8 +102,8 @@ type Circuit struct { A valid witness would be: -- `[uint32(3)|bytes(Y)|bytes(X)|bytes(Z)]` -- Hex representation with values `Y = 35`, `X = 3`, `Z = 2` `00000003000000000000000000000000000000000000000000000000000000000000002300000000000000000000000000000000000000000000000000000000000000030000000000000000000000000000000000000000000000000000000000000002` +- `[uint32(1)|uint32(2)|uint32(3)|bytes(Y)|bytes(X)|bytes(Z)]` +- Hex representation with values `Y = 35`, `X = 3`, `Z = 2` `000000010000000200000003000000000000000000000000000000000000000000000000000000000000002300000000000000000000000000000000000000000000000000000000000000030000000000000000000000000000000000000000000000000000000000000002` ### Example