mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-07 18:21:20 +00:00
68 lines
2.5 KiB
Go
68 lines
2.5 KiB
Go
|
package helpers
|
||
|
|
||
|
import (
|
||
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
||
|
"github.com/prysmaticlabs/prysm/shared/mathutil"
|
||
|
"github.com/prysmaticlabs/prysm/shared/params"
|
||
|
)
|
||
|
|
||
|
// EffectiveBalance returns the balance at stake for the validator.
|
||
|
// Beacon chain allows validators to top off their balance above MAX_DEPOSIT,
|
||
|
// but they can be slashed at most MAX_DEPOSIT at any time.
|
||
|
//
|
||
|
// Spec pseudocode definition:
|
||
|
// def get_effective_balance(state: State, index: int) -> int:
|
||
|
// """
|
||
|
// Returns the effective balance (also known as "balance at stake") for a ``validator`` with the given ``index``.
|
||
|
// """
|
||
|
// return min(state.validator_balances[idx], MAX_DEPOSIT)
|
||
|
func EffectiveBalance(state *pb.BeaconState, idx uint64) uint64 {
|
||
|
if state.ValidatorBalances[idx] > params.BeaconConfig().MaxDepositAmount {
|
||
|
return params.BeaconConfig().MaxDepositAmount
|
||
|
}
|
||
|
return state.ValidatorBalances[idx]
|
||
|
}
|
||
|
|
||
|
// BaseRewardQuotient takes the previous total balance and calculates for
|
||
|
// the quotient of the base reward.
|
||
|
//
|
||
|
// Spec pseudocode definition:
|
||
|
// base_reward_quotient =
|
||
|
// integer_squareroot(previous_total_balance) // BASE_REWARD_QUOTIENT
|
||
|
func BaseRewardQuotient(prevTotalBalance uint64) uint64 {
|
||
|
return mathutil.IntegerSquareRoot(prevTotalBalance) / params.BeaconConfig().BaseRewardQuotient
|
||
|
}
|
||
|
|
||
|
// BaseReward takes state and validator index to calculate for
|
||
|
// individual validator's base reward.
|
||
|
//
|
||
|
// Spec pseudocode definition:
|
||
|
// base_reward(state, index) =
|
||
|
// get_effective_balance(state, index) // base_reward_quotient // 5
|
||
|
func BaseReward(
|
||
|
state *pb.BeaconState,
|
||
|
validatorIndex uint64,
|
||
|
baseRewardQuotient uint64) uint64 {
|
||
|
|
||
|
validatorBalance := EffectiveBalance(state, validatorIndex)
|
||
|
return validatorBalance / baseRewardQuotient / 5
|
||
|
}
|
||
|
|
||
|
// InactivityPenalty takes state and validator index to calculate for
|
||
|
// individual validator's penalty for being offline.
|
||
|
//
|
||
|
// Spec pseudocode definition:
|
||
|
// inactivity_penalty(state, index, epochs_since_finality) =
|
||
|
// base_reward(state, index) + get_effective_balance(state, index)
|
||
|
// * epochs_since_finality // INACTIVITY_PENALTY_QUOTIENT // 2
|
||
|
func InactivityPenalty(
|
||
|
state *pb.BeaconState,
|
||
|
validatorIndex uint64,
|
||
|
baseRewardQuotient uint64,
|
||
|
epochsSinceFinality uint64) uint64 {
|
||
|
|
||
|
baseReward := BaseReward(state, validatorIndex, baseRewardQuotient)
|
||
|
validatorBalance := EffectiveBalance(state, validatorIndex)
|
||
|
return baseReward + validatorBalance*epochsSinceFinality/params.BeaconConfig().InactivityPenaltyQuotient/2
|
||
|
}
|