Skip to content

Commit

Permalink
Remove transition_digest
Browse files Browse the repository at this point in the history
  • Loading branch information
hwwhww committed Jun 9, 2020
1 parent 65a739f commit dacf86a
Show file tree
Hide file tree
Showing 5 changed files with 8 additions and 32 deletions.
1 change: 0 additions & 1 deletion specs/phase1/beacon-chain.md
Original file line number Diff line number Diff line change
Expand Up @@ -349,7 +349,6 @@ class ShardBlockHeader(Container):
class ShardState(Container):
slot: Slot
gasprice: Gwei
transition_digest: Bytes32
latest_block_root: Root
```

Expand Down
1 change: 0 additions & 1 deletion specs/phase1/phase1-fork.md
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,6 @@ def upgrade_to_phase1(pre: phase0.BeaconState) -> BeaconState:
ShardState(
slot=pre.slot,
gasprice=MIN_GASPRICE,
transition_digest=Root(),
latest_block_root=Root(),
) for i in range(INITIAL_ACTIVE_SHARDS)
),
Expand Down
2 changes: 1 addition & 1 deletion specs/phase1/shard-fork-choice.md
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,7 @@ def on_shard_block(store: Store, shard_store: ShardStore, signed_shard_block: Si
assert verify_shard_block_message(beacon_parent_state, shard_parent_state, shard_block)
assert verify_shard_block_signature(beacon_parent_state, signed_shard_block)

post_state = get_post_shard_state(beacon_parent_state, shard_parent_state, shard_block)
post_state = get_post_shard_state(shard_parent_state, shard_block)

# Add new block to the store
shard_store.blocks[hash_tree_root(shard_block)] = shard_block
Expand Down
34 changes: 6 additions & 28 deletions specs/phase1/shard-transition.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@

- [Introduction](#introduction)
- [Helper functions](#helper-functions)
- [Misc](#misc)
- [Shard block verification functions](#shard-block-verification-functions)
- [Shard state transition](#shard-state-transition)
- [Fraud proofs](#fraud-proofs)
Expand All @@ -24,19 +23,6 @@ This document describes the shard transition function and fraud proofs as part o

## Helper functions

### Misc

```python
def compute_shard_transition_digest(beacon_parent_state: BeaconState,
shard_state: ShardState,
beacon_parent_root: Root,
shard_body_root: Root) -> Bytes32:
# TODO: use SSZ hash tree root
return hash(
hash_tree_root(shard_state) + beacon_parent_root + shard_body_root
)
```

### Shard block verification functions

```python
Expand Down Expand Up @@ -77,11 +63,10 @@ def verify_shard_block_signature(beacon_state: BeaconState,
## Shard state transition

```python
def shard_state_transition(beacon_state: BeaconState,
shard_state: ShardState,
def shard_state_transition(shard_state: ShardState,
block: ShardBlock) -> None:
"""
Update ``shard_state`` with shard ``block`` and ``beacon_state`.
Update ``shard_state`` with shard ``block``.
"""
shard_state.slot = block.slot
prev_gasprice = shard_state.gasprice
Expand All @@ -91,25 +76,18 @@ def shard_state_transition(beacon_state: BeaconState,
else:
latest_block_root = hash_tree_root(block)
shard_state.latest_block_root = latest_block_root
shard_state.transition_digest = compute_shard_transition_digest(
beacon_state,
shard_state,
block.beacon_parent_root,
hash_tree_root(block.body),
)
```

We have a pure function `get_post_shard_state` for describing the fraud proof verification and honest validator behavior.

```python
def get_post_shard_state(beacon_state: BeaconState,
shard_state: ShardState,
def get_post_shard_state(shard_state: ShardState,
block: ShardBlock) -> ShardState:
"""
A pure function that returns a new post ShardState instead of modifying the given `shard_state`.
"""
post_state = shard_state.copy()
shard_state_transition(beacon_state, post_state, block)
shard_state_transition(post_state, block)
return post_state
```

Expand Down Expand Up @@ -151,8 +129,8 @@ def is_valid_fraud_proof(beacon_state: BeaconState,
else:
shard_state = transition.shard_states[offset_index - 1] # Not doing the actual state updates here.

shard_state = get_post_shard_state(beacon_state, shard_state, block)
if shard_state.transition_digest != transition.shard_states[offset_index].transition_digest:
shard_state = get_post_shard_state(shard_state, block)
if shard_state != transition.shard_states[offset_index]:
return True

return False
Expand Down
2 changes: 1 addition & 1 deletion specs/phase1/validator.md
Original file line number Diff line number Diff line change
Expand Up @@ -289,7 +289,7 @@ def get_shard_transition_fields(
else:
shard_block = SignedShardBlock(message=ShardBlock(slot=slot, shard=shard))
shard_data_roots.append(Root())
shard_state = get_post_shard_state(beacon_state, shard_state, shard_block.message)
shard_state = get_post_shard_state(shard_state, shard_block.message)
shard_states.append(shard_state)
shard_block_lengths.append(len(shard_block.message.body))

Expand Down

0 comments on commit dacf86a

Please sign in to comment.