mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2024-12-25 08:05:17 +00:00
perf grinder test
This commit is contained in:
parent
58456c1057
commit
fd0e1449a5
@ -607,8 +607,8 @@ func (w *WesolowskiFrameProver) CalculateChallengeProof(
|
|||||||
input := binary.BigEndian.AppendUint64([]byte{}, uint64(nowMs))
|
input := binary.BigEndian.AppendUint64([]byte{}, uint64(nowMs))
|
||||||
input = append(input, challenge...)
|
input = append(input, challenge...)
|
||||||
|
|
||||||
// 4.5 minutes = 270 seconds, one increment should be ten seconds
|
// setting this to 10s for single data time proof
|
||||||
proofDuration := 270 * 1000
|
proofDuration := 10 * 1000
|
||||||
calibratedDifficulty := (int64(proofDuration) * 10000) / skew
|
calibratedDifficulty := (int64(proofDuration) * 10000) / skew
|
||||||
instanceInput := binary.BigEndian.AppendUint32([]byte{}, core)
|
instanceInput := binary.BigEndian.AppendUint32([]byte{}, core)
|
||||||
instanceInput = append(instanceInput, input...)
|
instanceInput = append(instanceInput, input...)
|
||||||
@ -649,8 +649,7 @@ func (w *WesolowskiFrameProver) VerifyChallengeProof(
|
|||||||
instanceInput = append(instanceInput, input...)
|
instanceInput = append(instanceInput, input...)
|
||||||
b := sha3.Sum256(instanceInput)
|
b := sha3.Sum256(instanceInput)
|
||||||
|
|
||||||
// 4.5 minutes = 270 seconds, one increment should be ten seconds
|
proofDuration := 10 * 1000
|
||||||
proofDuration := 270 * 1000
|
|
||||||
skew := (assertedDifficulty * 12) / 10
|
skew := (assertedDifficulty * 12) / 10
|
||||||
calibratedDifficulty := (int64(proofDuration) * 10000) / skew
|
calibratedDifficulty := (int64(proofDuration) * 10000) / skew
|
||||||
|
|
||||||
|
161
node/main.go
161
node/main.go
@ -4,6 +4,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"context"
|
||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
@ -20,11 +21,14 @@ import (
|
|||||||
"runtime/pprof"
|
"runtime/pprof"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"sync"
|
||||||
"syscall"
|
"syscall"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
"golang.org/x/crypto/sha3"
|
"golang.org/x/crypto/sha3"
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"google.golang.org/grpc/credentials/insecure"
|
||||||
"google.golang.org/protobuf/proto"
|
"google.golang.org/protobuf/proto"
|
||||||
"source.quilibrium.com/quilibrium/monorepo/node/execution/intrinsics/ceremony/application"
|
"source.quilibrium.com/quilibrium/monorepo/node/execution/intrinsics/ceremony/application"
|
||||||
"source.quilibrium.com/quilibrium/monorepo/node/p2p"
|
"source.quilibrium.com/quilibrium/monorepo/node/p2p"
|
||||||
@ -35,6 +39,8 @@ import (
|
|||||||
"github.com/cloudflare/circl/sign/ed448"
|
"github.com/cloudflare/circl/sign/ed448"
|
||||||
"github.com/libp2p/go-libp2p/core/crypto"
|
"github.com/libp2p/go-libp2p/core/crypto"
|
||||||
"github.com/libp2p/go-libp2p/core/peer"
|
"github.com/libp2p/go-libp2p/core/peer"
|
||||||
|
"github.com/multiformats/go-multiaddr"
|
||||||
|
mn "github.com/multiformats/go-multiaddr/net"
|
||||||
"github.com/pbnjay/memory"
|
"github.com/pbnjay/memory"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"source.quilibrium.com/quilibrium/monorepo/node/app"
|
"source.quilibrium.com/quilibrium/monorepo/node/app"
|
||||||
@ -115,6 +121,11 @@ var (
|
|||||||
0,
|
0,
|
||||||
"specifies the parent process pid for a data worker",
|
"specifies the parent process pid for a data worker",
|
||||||
)
|
)
|
||||||
|
perfGrind = flag.Bool(
|
||||||
|
"perf-grind",
|
||||||
|
true,
|
||||||
|
"runs perf grinder test",
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
var signatories = []string{
|
var signatories = []string{
|
||||||
@ -388,6 +399,11 @@ func main() {
|
|||||||
|
|
||||||
kzg.Init()
|
kzg.Init()
|
||||||
|
|
||||||
|
if *perfGrind {
|
||||||
|
runPerfGrinder()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
report := RunSelfTestIfNeeded(*configDirectory, nodeConfig)
|
report := RunSelfTestIfNeeded(*configDirectory, nodeConfig)
|
||||||
|
|
||||||
var node *app.Node
|
var node *app.Node
|
||||||
@ -434,6 +450,151 @@ func main() {
|
|||||||
|
|
||||||
var dataWorkers []*exec.Cmd
|
var dataWorkers []*exec.Cmd
|
||||||
|
|
||||||
|
func createParallelDataClients(
|
||||||
|
paralellism int,
|
||||||
|
logger *zap.Logger,
|
||||||
|
) ([]protobufs.DataIPCServiceClient, error) {
|
||||||
|
logger.Info(
|
||||||
|
"connecting to data worker processes",
|
||||||
|
zap.Int("parallelism", paralellism),
|
||||||
|
)
|
||||||
|
|
||||||
|
dataWorkerBaseListenMultiaddr := "/ip4/127.0.0.1/tcp/%d"
|
||||||
|
|
||||||
|
dataWorkerBaseListenPort := 40000
|
||||||
|
|
||||||
|
clients := make([]protobufs.DataIPCServiceClient, paralellism)
|
||||||
|
|
||||||
|
for i := 0; i < paralellism; i++ {
|
||||||
|
ma, err := multiaddr.NewMultiaddr(
|
||||||
|
fmt.Sprintf(
|
||||||
|
dataWorkerBaseListenMultiaddr,
|
||||||
|
int(dataWorkerBaseListenPort)+i,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
_, addr, err := mn.DialArgs(ma)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
conn, err := grpc.Dial(
|
||||||
|
addr,
|
||||||
|
grpc.WithTransportCredentials(
|
||||||
|
insecure.NewCredentials(),
|
||||||
|
),
|
||||||
|
grpc.WithDefaultCallOptions(
|
||||||
|
grpc.MaxCallSendMsgSize(10*1024*1024),
|
||||||
|
grpc.MaxCallRecvMsgSize(10*1024*1024),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
clients[i] = protobufs.NewDataIPCServiceClient(conn)
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.Info(
|
||||||
|
"connected to data worker processes",
|
||||||
|
zap.Int("parallelism", paralellism),
|
||||||
|
)
|
||||||
|
return clients, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func runPerfGrinder() {
|
||||||
|
logger, _ := zap.NewProduction()
|
||||||
|
prover := qcrypto.NewKZGInclusionProver(logger)
|
||||||
|
cores := runtime.GOMAXPROCS(0)
|
||||||
|
parallelism := cores - 1
|
||||||
|
difficultyMetric := int64(100000)
|
||||||
|
skew := (difficultyMetric * 12) / 10
|
||||||
|
|
||||||
|
clients, _ := createParallelDataClients(parallelism, logger)
|
||||||
|
logger.Info("running performance grinder test")
|
||||||
|
for {
|
||||||
|
logger.Info("run kzg prover")
|
||||||
|
// simulate a random chunk of data
|
||||||
|
b := make([]byte, 65536)
|
||||||
|
rand.Read(b)
|
||||||
|
commit, err := prover.Commit(b, protobufs.IntrinsicExecutionOutputType)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
proof, err := prover.ProveAggregate([]*qcrypto.InclusionCommitment{commit})
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
challenge, err := proto.Marshal(&protobufs.InclusionAggregateProof{
|
||||||
|
Filter: make([]byte, 32),
|
||||||
|
FrameNumber: 0,
|
||||||
|
InclusionCommitments: []*protobufs.InclusionCommitment{
|
||||||
|
{
|
||||||
|
Filter: make([]byte, 32),
|
||||||
|
FrameNumber: 0,
|
||||||
|
Position: 0,
|
||||||
|
TypeUrl: proof.InclusionCommitments[0].TypeUrl,
|
||||||
|
Commitment: proof.InclusionCommitments[0].Commitment,
|
||||||
|
Data: proof.InclusionCommitments[0].Data,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Proof: proof.Proof,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
proofs := make([][]byte, parallelism)
|
||||||
|
nextMetrics := make([]int64, parallelism)
|
||||||
|
|
||||||
|
wg := sync.WaitGroup{}
|
||||||
|
wg.Add(int(parallelism))
|
||||||
|
logger.Info("run weso provers")
|
||||||
|
ts := time.Now().UnixMilli()
|
||||||
|
for i := uint32(0); i < uint32(parallelism); i++ {
|
||||||
|
i := i
|
||||||
|
go func() {
|
||||||
|
resp, err :=
|
||||||
|
clients[i].CalculateChallengeProof(
|
||||||
|
context.Background(),
|
||||||
|
&protobufs.ChallengeProofRequest{
|
||||||
|
Challenge: challenge,
|
||||||
|
Core: i,
|
||||||
|
Skew: skew,
|
||||||
|
NowMs: ts,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
proofs[i], nextMetrics[i] = resp.Output, resp.NextSkew
|
||||||
|
wg.Done()
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
wg.Wait()
|
||||||
|
nextDifficultySum := uint64(0)
|
||||||
|
for i := 0; i < int(parallelism); i++ {
|
||||||
|
nextDifficultySum += uint64(nextMetrics[i])
|
||||||
|
}
|
||||||
|
|
||||||
|
nextDifficultyMetric := int64(nextDifficultySum / uint64(parallelism))
|
||||||
|
|
||||||
|
logger.Info(
|
||||||
|
"recalibrating difficulty metric",
|
||||||
|
zap.Int64("previous_difficulty_metric", difficultyMetric),
|
||||||
|
zap.Int64("next_difficulty_metric", nextDifficultyMetric),
|
||||||
|
)
|
||||||
|
difficultyMetric = nextDifficultyMetric
|
||||||
|
skew = (nextDifficultyMetric * 12) / 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func spawnDataWorkers() {
|
func spawnDataWorkers() {
|
||||||
process, err := os.Executable()
|
process, err := os.Executable()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user