Ai
4 Star 0 Fork 0

甘宇/go-ethereum

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
sort.go 2.23 KB
一键复制 编辑 原始数据 按行查看 历史
甘宇 提交于 2021-04-16 18:14 +08:00 . Initial commit
// Copyright 2018 The aqchain-blockchain Authors
// This file is part of the aqchain-blockchain library.
//
// The aqchain-blockchain library is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// The aqchain-blockchain library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the aqchain-blockchain library. If not, see <http://www.gnu.org/licenses/>.
// Package poc implements the delegated-proof-of-stake consensus engine.
package poc
import (
"bytes"
"gitee.com/aqchain/go-ethereum/common"
"math/big"
"sort"
)
type ScoreItem struct {
addr common.Address
score *big.Int
}
type CandidateSlice []ScoreItem
func (s CandidateSlice) Len() int { return len(s) }
func (s CandidateSlice) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
func (s CandidateSlice) Less(i, j int) bool {
//we need sort reverse, so ...
isLess := s[i].score.Cmp(s[j].score)
if isLess > 0 {
return true
} else if isLess < 0 {
return false
}
// if the stake equal
return bytes.Compare(s[i].addr.Bytes(), s[j].addr.Bytes()) > 0
}
func (s *Snapshot) buildCandidateSlice() CandidateSlice {
var candidateSlice CandidateSlice
for address, contribution := range s.Candidates {
if !candidateNeedPD || s.isCandidate(address) {
if _, ok := s.Punished[address]; ok {
var creditWeight uint64
if s.Punished[address] > defaultFullCredit-minCalSignerQueueCredit {
creditWeight = minCalSignerQueueCredit
} else {
creditWeight = defaultFullCredit - s.Punished[address]
}
candidateSlice = append(candidateSlice, ScoreItem{address, new(big.Int).Mul(contribution, big.NewInt(int64(creditWeight)))})
} else {
candidateSlice = append(candidateSlice, ScoreItem{address, new(big.Int).Mul(contribution, big.NewInt(defaultFullCredit))})
}
}
}
sort.Sort(candidateSlice)
return candidateSlice
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/aqchain/go-ethereum.git
git@gitee.com:aqchain/go-ethereum.git
aqchain
go-ethereum
go-ethereum
v0.0.9

搜索帮助