From 84558e0c4c72dca4f347e49b22741363157038be Mon Sep 17 00:00:00 2001 From: Justin Date: Wed, 14 Aug 2019 15:48:30 +0200 Subject: [PATCH 1/2] Add summaries and expansions to simple-serialize.md --- specs/simple-serialize.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/specs/simple-serialize.md b/specs/simple-serialize.md index 119022248f..ecef6ddfce 100644 --- a/specs/simple-serialize.md +++ b/specs/simple-serialize.md @@ -217,6 +217,12 @@ We now define Merkleization `hash_tree_root(value)` of an object `value` recursi Let `value` be a self-signed container object. The convention is that the signature (e.g. a `"bytes96"` BLS12-381 signature) be the last field of `value`. Further, the signed message for `value` is `signing_root(value) = hash_tree_root(truncate_last(value))` where `truncate_last` truncates the last element of `value`. +## Summaries and expansions + +Let `A` be an object derived from another object `B` by replacing some of the (possibly nested) values of `B` by their `hash_tree_root`. We say `A` is a "summary" of `B`, and that `B` is an "expansion" of `A`. Notice `hash_tree_root(A) == hash_tree_root(B)`. + +We similarly define "summary types" and "expansion types". For example, [`BeaconBlock`](https://github.com/ethereum/eth2.0-specs/blob/dev/specs/core/0_beacon-chain.md#beaconblock) is an expansion type of [`BeaconBlockHeader`](https://github.com/ethereum/eth2.0-specs/blob/dev/specs/core/0_beacon-chain.md#beaconblockheader). Notice that objects expand to at most one object of a given expansion type. For example, `BeaconBlockHeader` objects uniquely expand to `BeaconBlock` objects. + ## Implementations | Language | Project | Maintainer | Implementation | From 5d8c31cfb17feff2edffbba1830437569611bc42 Mon Sep 17 00:00:00 2001 From: Danny Ryan Date: Wed, 14 Aug 2019 11:07:03 -0600 Subject: [PATCH 2/2] Update specs/simple-serialize.md --- specs/simple-serialize.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/specs/simple-serialize.md b/specs/simple-serialize.md index ecef6ddfce..50d091c072 100644 --- a/specs/simple-serialize.md +++ b/specs/simple-serialize.md @@ -221,7 +221,7 @@ Let `value` be a self-signed container object. The convention is that the signat Let `A` be an object derived from another object `B` by replacing some of the (possibly nested) values of `B` by their `hash_tree_root`. We say `A` is a "summary" of `B`, and that `B` is an "expansion" of `A`. Notice `hash_tree_root(A) == hash_tree_root(B)`. -We similarly define "summary types" and "expansion types". For example, [`BeaconBlock`](https://github.com/ethereum/eth2.0-specs/blob/dev/specs/core/0_beacon-chain.md#beaconblock) is an expansion type of [`BeaconBlockHeader`](https://github.com/ethereum/eth2.0-specs/blob/dev/specs/core/0_beacon-chain.md#beaconblockheader). Notice that objects expand to at most one object of a given expansion type. For example, `BeaconBlockHeader` objects uniquely expand to `BeaconBlock` objects. +We similarly define "summary types" and "expansion types". For example, [`BeaconBlock`](./core/0_beacon-chain.md#beaconblock) is an expansion type of [`BeaconBlockHeader`](./core/0_beacon-chain.md#beaconblockheader). Notice that objects expand to at most one object of a given expansion type. For example, `BeaconBlockHeader` objects uniquely expand to `BeaconBlock` objects. ## Implementations