Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Separate document for phase 1 custody game #818

Merged
merged 18 commits into from
Mar 28, 2019
Merged

Conversation

JustinDrake
Copy link
Contributor

@JustinDrake JustinDrake commented Mar 20, 2019

We now have two phase 1 documents:

  • 1_shard-data-chains.md: details for the fork choice rule for shard data chains
  • 1_custody-game.md: details changes to the beacon chain to support the custody game

Text moved away from `1_shard-data-chains.md` (see #812 rewrite).
@JustinDrake JustinDrake changed the title Create 1_shard-data-chains-validator.md Separate document for phase 1 custody game Mar 22, 2019
Copy link
Contributor

@CarlBeek CarlBeek left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice start, but either I am missing something or there are quite a few things that need to be changed with this.

A further thought: this game is missing challenger penalties for challenges that fail.

Something also doesn't quite sit right with me regarding the way bad responders are slashed, but I'll check again in the morning.

specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
# Add new chunk challenge record
state.chunk_challenge_records.append(ChunkChallengeRecord(
challenge_index=state.challenge_index,
challenger_index=get_beacon_proposer_index(state, state.slot),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not a fan of forcing the chunk challenger to be the proposer, but I agree it is much simpler.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is also a question I have. To be discussed on today's call.

))
state.challenge_index += 1
# Postpone responder withdrawability
responder.withdrawable_epoch = FAR_FUTURE_EPOCH
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this not open a grieving vector whereby a responder's exit is delayed up to CUSTODY_RESPONSE_DEADLINE by repeatedly posing challenges?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Vitalik is planning to revamp withdrawability. See item 23 in #675. To be discussed in today's call.

Copy link
Contributor

@dankrad dankrad left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I did not see how validators are forced to reveal their custody secrets? Don't we need to add a deadline for that?

specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
specs/core/1_custody-game.md Outdated Show resolved Hide resolved
assert min_challengeable_epoch <= slot_to_epoch(challenge.attestation.data.slot)
# Verify the responder participated in the attestation
assert challenge.responder_index in attestation.validator_indices
# A validator can be the challenger or responder for at most one challenge at a time
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What is the rationale behind only being responder to one challenge at a time? Would that not mean that I can prevent being challenged by challenging myself (possibly with another validator)?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a question I have for Vitalik :) To be discussed in today's call.

specs/core/1_custody-game.md Outdated Show resolved Hide resolved
specs/core/1_custody-game.md Show resolved Hide resolved
assert verify_standalone_attestation(state, convert_to_standalone(state, challenge.attestation))
# Verify the attestation is eligible for challenging
responder = state.validator_registry[challenge.responder_index]
min_challengeable_epoch = responder.exit_epoch - EPOCHS_PER_CUSTODY_PERIOD * (1 + responder.max_reveal_lateness)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What is the rationale behind this? Am I misreading this or does that mean if the responder has taken longer on past reveals, they will get "more buffering" from getting challenged before their exit?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agreed that the logic around max_reveal_lateness smells. I'd like to remove max_reveal_lateness. To be discussed on today's call.

@JustinDrake JustinDrake merged commit 1082c68 into dev Mar 28, 2019
JustinDrake pushed a commit that referenced this pull request Mar 28, 2019
See also #818.

===

* Replace custody challenge game with JABS

Replace the existing proof of custody game with a new game ("Justin's Awesome Bit Sum" or JABS) that works as follows:

* The data `D` is split up into 512-byte chunks `D[0] .... D[n-1]`, and use a mix function `mix(subkey, data) -> {0,1}` (currently the first bit of the hash of `subkey+data`). We calculate `M[i] = (mix(D[0]) + ... + mix(D[i-1])) % 2`, and set the custody bit to `M[n-1]`
* Anyone can challenge by providing the full `M` where `M[n-1]` is not equal to the custody bit
* Anyone can respond to a challenge by providing a specific position in `M` along with a branch of the data where `M[i-1] ^ mix(D[i]) != M[i]`

The maximum size of data is now `2**6` epochs *  `2**6` blocks * `2**14` bytes = `2**26` bytes, so assuming 512-byte mix chunks the maximum mix size is `2**17` bits or `2**14` bytes. The average mix size is `2**8` bytes.
@hwwhww hwwhww deleted the JustinDrake-patch-8 branch March 29, 2019 05:55
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants