mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-07 10:12:19 +00:00
a8e501b3cf
* update deps * update deps * update protos/* * update deps * reset protos * update protos * update shared/params/config * update protos * update /shared * update shared/slotutil and shared/testutil * update beacon-chain/core/helpers * updates beacon-chain/state * update beacon-chain/forkchoice * update beacon-chain/blockchain * update beacon-chain/cache * update beacon-chain/core * update beacon-chain/db * update beacon-chain/node * update beacon-chain/p2p * update beacon-chain/rpc * update beacon-chain/sync * go mod tidy * make sure that beacon-chain build suceeds * go fmt * update e2e tests * update slasher * remove redundant alias * update validator * gazelle * fix build errors in unit tests * go fmt * update deps * update fuzz/BUILD.bazel * fix unit tests * more unit test fixes * fix blockchain UTs * more unit test fixes
58 lines
2.1 KiB
Go
58 lines
2.1 KiB
Go
// Package precompute provides gathering of nicely-structured
|
|
// data important to feed into epoch processing, such as attesting
|
|
// records and balances, for faster computation.
|
|
package precompute
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
|
stateTrie "github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
// New gets called at the beginning of process epoch cycle to return
|
|
// pre computed instances of validators attesting records and total
|
|
// balances attested in an epoch.
|
|
func New(ctx context.Context, state *stateTrie.BeaconState) ([]*Validator, *Balance, error) {
|
|
ctx, span := trace.StartSpan(ctx, "precomputeEpoch.New")
|
|
defer span.End()
|
|
pValidators := make([]*Validator, state.NumValidators())
|
|
pBal := &Balance{}
|
|
|
|
currentEpoch := helpers.CurrentEpoch(state)
|
|
prevEpoch := helpers.PrevEpoch(state)
|
|
|
|
if err := state.ReadFromEveryValidator(func(idx int, val stateTrie.ReadOnlyValidator) error {
|
|
// Was validator withdrawable or slashed
|
|
withdrawable := prevEpoch+1 >= val.WithdrawableEpoch()
|
|
pVal := &Validator{
|
|
IsSlashed: val.Slashed(),
|
|
IsWithdrawableCurrentEpoch: withdrawable,
|
|
CurrentEpochEffectiveBalance: val.EffectiveBalance(),
|
|
}
|
|
// Was validator active current epoch
|
|
if helpers.IsActiveValidatorUsingTrie(val, currentEpoch) {
|
|
pVal.IsActiveCurrentEpoch = true
|
|
pBal.ActiveCurrentEpoch += val.EffectiveBalance()
|
|
}
|
|
// Was validator active previous epoch
|
|
if helpers.IsActiveValidatorUsingTrie(val, prevEpoch) {
|
|
pVal.IsActivePrevEpoch = true
|
|
pBal.ActivePrevEpoch += val.EffectiveBalance()
|
|
}
|
|
// Set inclusion slot and inclusion distance to be max, they will be compared and replaced
|
|
// with the lower values
|
|
pVal.InclusionSlot = uint64(params.BeaconConfig().FarFutureEpoch)
|
|
pVal.InclusionDistance = uint64(params.BeaconConfig().FarFutureEpoch)
|
|
|
|
pValidators[idx] = pVal
|
|
return nil
|
|
}); err != nil {
|
|
return nil, nil, errors.Wrap(err, "failed to initialize precompute")
|
|
}
|
|
return pValidators, pBal, nil
|
|
}
|