From 23c36477e56d975cd3c73e33783e8d3bd2012d60 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Tue, 7 Feb 2023 18:05:55 +0800 Subject: [PATCH 1/5] feat(protocol): add a script to calculate protocol configs --- .../protocol/utils/generate_config/main.py | 51 +++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 packages/protocol/utils/generate_config/main.py diff --git a/packages/protocol/utils/generate_config/main.py b/packages/protocol/utils/generate_config/main.py new file mode 100644 index 00000000000..bb420ec09c3 --- /dev/null +++ b/packages/protocol/utils/generate_config/main.py @@ -0,0 +1,51 @@ +import math + + +if __name__ == "__main__": + print("Expected block time (seconds)", end=": ") + block_time = int(input()) + + print("Expected proof time (minutes)", end=": ") + proof_time = int(input()) * 60 + + print("Slot availability multiplier", end=": ") + slot_availability_multiplier = int(input()) + if slot_availability_multiplier <= 5: + print("error: Slot availability multiplier must be greater than 5") + exit(1) + + print("Number of ZKPs required per block before verificaiton", end=": ") + zk_proofs_per_block = int(input()) + + if zk_proofs_per_block < 1 or zk_proofs_per_block > 5: + print("error: Number of ZKPs must be between 1 and 5") + exit(1) + + print("Extra slots (e.g, 50 means 50% more slots)", end=": ") + extra_slots = int(input()) + + print("---------") + min_num_slots = math.ceil(1.0 * proof_time / block_time) + if zk_proofs_per_block > 1: + min_num_slots *= 2 + + print("min num slots:", min_num_slots) + max_num_slots = min_num_slots + math.ceil(min_num_slots * extra_slots / 100) + 1 + + k = slot_availability_multiplier + n = max_num_slots + + # https://www.wolframalpha.com/input?i=solve++%28n%2Bx%29%28n%2Bx-1%29%3Dk*%281%2Bx%29x+for+x + fee_smoothing_factor = ( + k - 2 * n + 1 - math.sqrt(k * (k + 4 * n * n - 8 * n + 2) + 1.0) + ) / (2 - 2 * k) + + fee_smoothing_factor = int(fee_smoothing_factor * 1000) + + # f = fee_smoothing_factor + # print(1.0*(f+n*1000)*(f+n*1000-1000)/((f+1000)*f)) + + print("---------") + print("maxNumBlocks:", max_num_slots) + print("zkProofsPerBlock:", zk_proofs_per_block) + print("slotSmoothingFactor:", fee_smoothing_factor) From 4bf58f698e3a562390f9f4144010629c60ed8389 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Tue, 7 Feb 2023 18:15:12 +0800 Subject: [PATCH 2/5] Create README.md --- packages/protocol/utils/generate_config/README.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 packages/protocol/utils/generate_config/README.md diff --git a/packages/protocol/utils/generate_config/README.md b/packages/protocol/utils/generate_config/README.md new file mode 100644 index 00000000000..d8d3c7986e8 --- /dev/null +++ b/packages/protocol/utils/generate_config/README.md @@ -0,0 +1,12 @@ +# README + +A script to calculate `slotSmoothingFactor` in `TaikoData.Config` given: + +- expected block time +- expected proof time +- expected slot availability multiplier + ... + +## How to run + +`python3 main.py` From 7e9c63fed036ed820d78f46a624d2b4c6dd17f00 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Tue, 7 Feb 2023 18:15:15 +0800 Subject: [PATCH 3/5] Update CHANGELOG.md --- packages/protocol/CHANGELOG.md | 26 ++++++++++++-------------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/packages/protocol/CHANGELOG.md b/packages/protocol/CHANGELOG.md index de72e82c62c..95c2a8e9785 100644 --- a/packages/protocol/CHANGELOG.md +++ b/packages/protocol/CHANGELOG.md @@ -2,25 +2,23 @@ ## [0.2.0](https://github.com/taikoxyz/taiko-mono/compare/protocol-v0.1.0...protocol-v0.2.0) (2023-01-31) - ### Features -* **protocol:** add `proto_broker` / `oracle_prover` addresses into `AddressManager` in deploy_L1 script ([#13079](https://github.com/taikoxyz/taiko-mono/issues/13079)) ([f3bea40](https://github.com/taikoxyz/taiko-mono/commit/f3bea40fbcdf4139cc84903ab69d1e0daf641c7c)) -* **protocol:** add special logics for alpha-2 testnet ([#12987](https://github.com/taikoxyz/taiko-mono/issues/12987)) ([3b71285](https://github.com/taikoxyz/taiko-mono/commit/3b712857b5d5ede2a3683d949d1974c8cceeb69a)) -* **protocol:** deploy the generated Yul plonk verifier ([#13016](https://github.com/taikoxyz/taiko-mono/issues/13016)) ([eb5d564](https://github.com/taikoxyz/taiko-mono/commit/eb5d564ec469b1ec79619b4d563c3f9989d264c2)) -* **protocol:** enable two dimensional circuit/verifier lookup. ([#13066](https://github.com/taikoxyz/taiko-mono/issues/13066)) ([51d1f67](https://github.com/taikoxyz/taiko-mono/commit/51d1f67aa45fec8e2de73c1ed5a992306c6339c1)) -* **protocol:** implement `Bridge.isMessageFailed` ([#13004](https://github.com/taikoxyz/taiko-mono/issues/13004)) ([45153d9](https://github.com/taikoxyz/taiko-mono/commit/45153d92cbcd0e80438c925d5ce5c52df3abd696)) -* **protocol:** implement releaseEther & releaseERC20 ([#13008](https://github.com/taikoxyz/taiko-mono/issues/13008)) ([088933e](https://github.com/taikoxyz/taiko-mono/commit/088933e74f7163459e328d61d8331235ab87e388)) -* **protocol:** improve sync header storage on L2 ([#13041](https://github.com/taikoxyz/taiko-mono/issues/13041)) ([86c9fe4](https://github.com/taikoxyz/taiko-mono/commit/86c9fe44a3200490032610c017bfc88c3a57a8dd)) -* **protocol:** temporarily force an `oracle prover` to be the first prover ([#13070](https://github.com/taikoxyz/taiko-mono/issues/13070)) ([d7401a2](https://github.com/taikoxyz/taiko-mono/commit/d7401a20c66a3c52330c4f92c95c71c902d74452)) - +- **protocol:** add `proto_broker` / `oracle_prover` addresses into `AddressManager` in deploy_L1 script ([#13079](https://github.com/taikoxyz/taiko-mono/issues/13079)) ([f3bea40](https://github.com/taikoxyz/taiko-mono/commit/f3bea40fbcdf4139cc84903ab69d1e0daf641c7c)) +- **protocol:** add special logics for alpha-2 testnet ([#12987](https://github.com/taikoxyz/taiko-mono/issues/12987)) ([3b71285](https://github.com/taikoxyz/taiko-mono/commit/3b712857b5d5ede2a3683d949d1974c8cceeb69a)) +- **protocol:** deploy the generated Yul plonk verifier ([#13016](https://github.com/taikoxyz/taiko-mono/issues/13016)) ([eb5d564](https://github.com/taikoxyz/taiko-mono/commit/eb5d564ec469b1ec79619b4d563c3f9989d264c2)) +- **protocol:** enable two dimensional circuit/verifier lookup. ([#13066](https://github.com/taikoxyz/taiko-mono/issues/13066)) ([51d1f67](https://github.com/taikoxyz/taiko-mono/commit/51d1f67aa45fec8e2de73c1ed5a992306c6339c1)) +- **protocol:** implement `Bridge.isMessageFailed` ([#13004](https://github.com/taikoxyz/taiko-mono/issues/13004)) ([45153d9](https://github.com/taikoxyz/taiko-mono/commit/45153d92cbcd0e80438c925d5ce5c52df3abd696)) +- **protocol:** implement releaseEther & releaseERC20 ([#13008](https://github.com/taikoxyz/taiko-mono/issues/13008)) ([088933e](https://github.com/taikoxyz/taiko-mono/commit/088933e74f7163459e328d61d8331235ab87e388)) +- **protocol:** improve sync header storage on L2 ([#13041](https://github.com/taikoxyz/taiko-mono/issues/13041)) ([86c9fe4](https://github.com/taikoxyz/taiko-mono/commit/86c9fe44a3200490032610c017bfc88c3a57a8dd)) +- **protocol:** temporarily force an `oracle prover` to be the first prover ([#13070](https://github.com/taikoxyz/taiko-mono/issues/13070)) ([d7401a2](https://github.com/taikoxyz/taiko-mono/commit/d7401a20c66a3c52330c4f92c95c71c902d74452)) ### Bug Fixes -* **protocol:** fix `test:integration` waiting node timeout ([#13006](https://github.com/taikoxyz/taiko-mono/issues/13006)) ([07debb7](https://github.com/taikoxyz/taiko-mono/commit/07debb779c1a142cf6050c31a5a8c9b72f26d376)) -* **protocol:** fix a downloading `solc` binary script bug ([#13074](https://github.com/taikoxyz/taiko-mono/issues/13074)) ([8167e9d](https://github.com/taikoxyz/taiko-mono/commit/8167e9dda0b0f70405e969f590f714b45af5b192)) -* **protocol:** fix two protocol bugs ([#13034](https://github.com/taikoxyz/taiko-mono/issues/13034)) ([1bfa69b](https://github.com/taikoxyz/taiko-mono/commit/1bfa69b4458f7edc4b72efe9c2d8cf9c7050853e)) -* **protocol:** update `ProofVerifier` address name in `AddressManager` ([#13063](https://github.com/taikoxyz/taiko-mono/issues/13063)) ([4144f4b](https://github.com/taikoxyz/taiko-mono/commit/4144f4bda154116f5e34759ced173a16f409202f)) +- **protocol:** fix `test:integration` waiting node timeout ([#13006](https://github.com/taikoxyz/taiko-mono/issues/13006)) ([07debb7](https://github.com/taikoxyz/taiko-mono/commit/07debb779c1a142cf6050c31a5a8c9b72f26d376)) +- **protocol:** fix a downloading `solc` binary script bug ([#13074](https://github.com/taikoxyz/taiko-mono/issues/13074)) ([8167e9d](https://github.com/taikoxyz/taiko-mono/commit/8167e9dda0b0f70405e969f590f714b45af5b192)) +- **protocol:** fix two protocol bugs ([#13034](https://github.com/taikoxyz/taiko-mono/issues/13034)) ([1bfa69b](https://github.com/taikoxyz/taiko-mono/commit/1bfa69b4458f7edc4b72efe9c2d8cf9c7050853e)) +- **protocol:** update `ProofVerifier` address name in `AddressManager` ([#13063](https://github.com/taikoxyz/taiko-mono/issues/13063)) ([4144f4b](https://github.com/taikoxyz/taiko-mono/commit/4144f4bda154116f5e34759ced173a16f409202f)) ## [0.1.0](https://github.com/taikoxyz/taiko-mono/compare/protocol-v0.0.1...protocol-v0.1.0) (2023-01-19) From 5ddd12f642688d2fb76e96a7d4eb26ddbb5fc9e0 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Tue, 7 Feb 2023 18:29:14 +0800 Subject: [PATCH 4/5] Update main.py --- packages/protocol/utils/generate_config/main.py | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/packages/protocol/utils/generate_config/main.py b/packages/protocol/utils/generate_config/main.py index bb420ec09c3..7928454dc24 100644 --- a/packages/protocol/utils/generate_config/main.py +++ b/packages/protocol/utils/generate_config/main.py @@ -21,13 +21,19 @@ print("error: Number of ZKPs must be between 1 and 5") exit(1) + if zk_proofs_per_block == 1: + min_num_slots = math.ceil(1.0 * proof_time / block_time) + initial_uncle_delay = proof_time + else: + print("Inital uncle proof delay (minutes)", end=": ") + initial_uncle_delay = int(input()) * 60 + min_num_slots = math.ceil(1.0 * (proof_time + initial_uncle_delay) / block_time) + + print("Extra slots (e.g, 50 means 50% more slots)", end=": ") extra_slots = int(input()) print("---------") - min_num_slots = math.ceil(1.0 * proof_time / block_time) - if zk_proofs_per_block > 1: - min_num_slots *= 2 print("min num slots:", min_num_slots) max_num_slots = min_num_slots + math.ceil(min_num_slots * extra_slots / 100) + 1 @@ -46,6 +52,7 @@ # print(1.0*(f+n*1000)*(f+n*1000-1000)/((f+1000)*f)) print("---------") + print("initialUncleDelay:", initial_uncle_delay) print("maxNumBlocks:", max_num_slots) print("zkProofsPerBlock:", zk_proofs_per_block) print("slotSmoothingFactor:", fee_smoothing_factor) From 1c2b963aa28a731571a3799528f568a0e121657a Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Tue, 7 Feb 2023 18:51:11 +0800 Subject: [PATCH 5/5] Update main.py --- packages/protocol/utils/generate_config/main.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/protocol/utils/generate_config/main.py b/packages/protocol/utils/generate_config/main.py index 7928454dc24..1597eb71de6 100644 --- a/packages/protocol/utils/generate_config/main.py +++ b/packages/protocol/utils/generate_config/main.py @@ -29,7 +29,6 @@ initial_uncle_delay = int(input()) * 60 min_num_slots = math.ceil(1.0 * (proof_time + initial_uncle_delay) / block_time) - print("Extra slots (e.g, 50 means 50% more slots)", end=": ") extra_slots = int(input()) @@ -52,7 +51,7 @@ # print(1.0*(f+n*1000)*(f+n*1000-1000)/((f+1000)*f)) print("---------") - print("initialUncleDelay:", initial_uncle_delay) + print("initialUncleDelay:", int(initial_uncle_delay / 60), "minutes") print("maxNumBlocks:", max_num_slots) print("zkProofsPerBlock:", zk_proofs_per_block) print("slotSmoothingFactor:", fee_smoothing_factor)