From f556727fd2207671faf6d7460e3066a22a832703 Mon Sep 17 00:00:00 2001 From: Alex Kuzmin <6849426+alxkzmn@users.noreply.github.com> Date: Tue, 26 Mar 2024 12:18:58 +0800 Subject: [PATCH] Add range check sufficiency explanation in the chip docs (#278) --- prover/src/chips/range/range_check.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/prover/src/chips/range/range_check.rs b/prover/src/chips/range/range_check.rs index 27c59194..fffb2aa4 100644 --- a/prover/src/chips/range/range_check.rs +++ b/prover/src/chips/range/range_check.rs @@ -9,6 +9,21 @@ use std::fmt::Debug; /// Configuration for the Range Check u64 Chip /// Used to verify that an element lies in the u64 range. /// +/// To prove that the 64-bit balance values would not cause the overflow of the grand sum, +/// let's consider the case at the limit in which we have 2^28 users and all their +/// balances are the maximum possible (namely, 2^64-1): +/// +/// >>> 2**28 * (2**64-1) +/// 4951760157141521099328061440 +/// >>> n = 4951760157141521099328061440 +/// >>> num_bits = n.bit_length() +/// >>> print(num_bits) +/// 92 +/// +/// The resulting grand sum is only 92 bits. Therefore, we can conclude that the +/// range check of 64 bits on the 2^28 user balances safely removes the risk of overflow +/// in the grand sum calculation. +/// /// # Fields /// /// * `zs`: Four advice columns - contain the truncated right-shifted values of the element to be checked