Remove last inclusion_slot(..) call
This commit is contained in:
parent
21d75ef0bd
commit
53456a6c79
@ -2,7 +2,6 @@ use attester_sets::AttesterSets;
|
|||||||
use errors::EpochProcessingError as Error;
|
use errors::EpochProcessingError as Error;
|
||||||
use fnv::FnvHashMap;
|
use fnv::FnvHashMap;
|
||||||
use fnv::FnvHashSet;
|
use fnv::FnvHashSet;
|
||||||
use inclusion_distance::{inclusion_distance, inclusion_slot};
|
|
||||||
use integer_sqrt::IntegerSquareRoot;
|
use integer_sqrt::IntegerSquareRoot;
|
||||||
use log::debug;
|
use log::debug;
|
||||||
use rayon::prelude::*;
|
use rayon::prelude::*;
|
||||||
@ -280,6 +279,28 @@ pub fn process_rewards_and_penalities(
|
|||||||
return Err(Error::PreviousTotalBalanceIsZero);
|
return Err(Error::PreviousTotalBalanceIsZero);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Map is ValidatorIndex -> ProposerIndex
|
||||||
|
let mut inclusion_slots: FnvHashMap<usize, (Slot, usize)> = FnvHashMap::default();
|
||||||
|
for a in &previous_epoch_attestations {
|
||||||
|
let participants =
|
||||||
|
state.get_attestation_participants(&a.data, &a.aggregation_bitfield, spec)?;
|
||||||
|
let inclusion_distance = (a.inclusion_slot - a.data.slot).as_u64();
|
||||||
|
for participant in participants {
|
||||||
|
if let Some((existing_distance, _)) = inclusion_slots.get(&participant) {
|
||||||
|
if *existing_distance <= inclusion_distance {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let proposer_index = state
|
||||||
|
.get_beacon_proposer_index(a.data.slot, spec)
|
||||||
|
.map_err(|_| Error::UnableToDetermineProducer)?;
|
||||||
|
inclusion_slots.insert(
|
||||||
|
participant,
|
||||||
|
(Slot::from(inclusion_distance), proposer_index),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Justification and finalization
|
// Justification and finalization
|
||||||
|
|
||||||
let epochs_since_finality = next_epoch - state.finalized_epoch;
|
let epochs_since_finality = next_epoch - state.finalized_epoch;
|
||||||
@ -327,19 +348,19 @@ pub fn process_rewards_and_penalities(
|
|||||||
|
|
||||||
if attesters.previous_epoch.indices.contains(&index) {
|
if attesters.previous_epoch.indices.contains(&index) {
|
||||||
let base_reward = state.base_reward(index, base_reward_quotient, spec);
|
let base_reward = state.base_reward(index, base_reward_quotient, spec);
|
||||||
let inclusion_distance =
|
|
||||||
inclusion_distance(state, &previous_epoch_attestations, index, spec);
|
|
||||||
|
|
||||||
if let Ok(inclusion_distance) = inclusion_distance {
|
let (inclusion_distance, _) = inclusion_slots
|
||||||
if inclusion_distance > 0 {
|
.get(&index)
|
||||||
|
.expect("Inconsistent inclusion_slots.");
|
||||||
|
|
||||||
|
if *inclusion_distance > 0 {
|
||||||
safe_add_assign!(
|
safe_add_assign!(
|
||||||
balance,
|
balance,
|
||||||
base_reward * spec.min_attestation_inclusion_delay
|
base_reward * spec.min_attestation_inclusion_delay
|
||||||
/ inclusion_distance
|
/ inclusion_distance.as_u64()
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
balance
|
balance
|
||||||
})
|
})
|
||||||
@ -378,18 +399,17 @@ pub fn process_rewards_and_penalities(
|
|||||||
|
|
||||||
if attesters.previous_epoch.indices.contains(&index) {
|
if attesters.previous_epoch.indices.contains(&index) {
|
||||||
let base_reward = state.base_reward(index, base_reward_quotient, spec);
|
let base_reward = state.base_reward(index, base_reward_quotient, spec);
|
||||||
let inclusion_distance =
|
|
||||||
inclusion_distance(state, &previous_epoch_attestations, index, spec);
|
|
||||||
|
|
||||||
if let Ok(inclusion_distance) = inclusion_distance {
|
let (inclusion_distance, _) = inclusion_slots
|
||||||
if inclusion_distance > 0 {
|
.get(&index)
|
||||||
safe_sub_assign!(
|
.expect("Inconsistent inclusion_slots.");
|
||||||
|
|
||||||
|
if *inclusion_distance > 0 {
|
||||||
|
safe_add_assign!(
|
||||||
balance,
|
balance,
|
||||||
base_reward
|
base_reward * spec.min_attestation_inclusion_delay
|
||||||
- base_reward * spec.min_attestation_inclusion_delay
|
/ inclusion_distance.as_u64()
|
||||||
/ inclusion_distance
|
)
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -399,34 +419,17 @@ pub fn process_rewards_and_penalities(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Attestation inclusion
|
// Attestation inclusion
|
||||||
let mut inclusion_slots: FnvHashMap<usize, (Slot, Slot)> = FnvHashMap::default();
|
//
|
||||||
for a in previous_epoch_attestations {
|
|
||||||
let participants =
|
|
||||||
state.get_attestation_participants(&a.data, &a.aggregation_bitfield, spec)?;
|
|
||||||
let inclusion_distance = (a.inclusion_slot - a.data.slot).as_u64();
|
|
||||||
for participant in participants {
|
|
||||||
if let Some((existing_distance, _)) = inclusion_slots.get(&participant) {
|
|
||||||
if *existing_distance <= inclusion_distance {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
inclusion_slots.insert(participant, (Slot::from(inclusion_distance), a.data.slot));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for &index in &attesters.previous_epoch.indices {
|
for &index in &attesters.previous_epoch.indices {
|
||||||
let (_, inclusion_slot) = inclusion_slots
|
let (_, proposer_index) = inclusion_slots
|
||||||
.get(&index)
|
.get(&index)
|
||||||
.ok_or_else(|| Error::InclusionSlotsInconsistent(index))?;
|
.ok_or_else(|| Error::InclusionSlotsInconsistent(index))?;
|
||||||
|
|
||||||
let proposer_index = state
|
let base_reward = state.base_reward(*proposer_index, base_reward_quotient, spec);
|
||||||
.get_beacon_proposer_index(*inclusion_slot, spec)
|
|
||||||
.map_err(|_| Error::UnableToDetermineProducer)?;
|
|
||||||
|
|
||||||
let base_reward = state.base_reward(proposer_index, base_reward_quotient, spec);
|
|
||||||
|
|
||||||
safe_add_assign!(
|
safe_add_assign!(
|
||||||
state.validator_balances[proposer_index],
|
state.validator_balances[*proposer_index],
|
||||||
base_reward / spec.attestation_inclusion_reward_quotient
|
base_reward / spec.attestation_inclusion_reward_quotient
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user