Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/version-1.5.x' into node-2611-fo…
Browse files Browse the repository at this point in the history
…rbidden-ride-v1-v3
  • Loading branch information
xrtm000 committed Oct 6, 2023
2 parents bfd9df6 + a659a53 commit 4ac6293
Show file tree
Hide file tree
Showing 193 changed files with 4,086 additions and 2,984 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@ abstract class DBState extends ScorexLogging {
new RocksDBWriter(
rdb,
settings.blockchainSettings,
settings.dbSettings.copy(maxCacheSize = 1)
settings.dbSettings.copy(maxCacheSize = 1),
settings.enableLightMode
)

AddressScheme.current = new AddressScheme { override val chainId: Byte = 'W' }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ object RollbackBenchmark extends ScorexLogging {
val settings = Application.loadApplicationConfig(Some(new File(args(0))))
val rdb = RDB.open(settings.dbSettings)
val time = new NTP(settings.ntpServer)
val rocksDBWriter = new RocksDBWriter(rdb, settings.blockchainSettings, settings.dbSettings)
val rocksDBWriter = new RocksDBWriter(rdb, settings.blockchainSettings, settings.dbSettings, settings.enableLightMode)

val issuer = KeyPair(new Array[Byte](32))

Expand Down Expand Up @@ -80,6 +80,7 @@ object RollbackBenchmark extends ScorexLogging {
0,
None,
genesisBlock.header.generationSignature,
ByteStr.empty,
genesisBlock
)

Expand All @@ -103,7 +104,7 @@ object RollbackBenchmark extends ScorexLogging {
val nextSnapshot = StateSnapshot.build(rocksDBWriter, portfolios2.toMap).explicitGet()

log.info("Appending next block")
rocksDBWriter.append(nextSnapshot, 0, 0, None, ByteStr.empty, nextBlock)
rocksDBWriter.append(nextSnapshot, 0, 0, None, ByteStr.empty, ByteStr.empty, nextBlock)

log.info("Rolling back")
val start = System.nanoTime()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,8 @@ object EnvironmentFunctionsBenchmark {

override def accountScript(addressOrAlias: Recipient): Option[Script] = ???

override def calculateDelay(hitSource: ByteStr, baseTarget: Long, generator: ByteStr, balance: Long): Long = ???

def callScript(
dApp: Address,
func: String,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
package com.wavesplatform.lang.v1

import com.wavesplatform.common.utils.EitherExt2
import com.wavesplatform.lang.Common
import com.wavesplatform.lang.directives.values.StdLibVersion
import com.wavesplatform.lang.v1.FunctionHeader.Native
import com.wavesplatform.lang.v1.compiler.Terms.*
import com.wavesplatform.lang.v1.evaluator.FunctionIds.REPLACE_BY_INDEX_OF_LIST
import com.wavesplatform.lang.v1.evaluator.ctx.impl.PureContext
import com.wavesplatform.lang.v1.traits.Environment
import org.openjdk.jmh.annotations.*
import org.openjdk.jmh.infra.Blackhole

import scala.concurrent.duration.{MICROSECONDS, SECONDS}

@OutputTimeUnit(MICROSECONDS)
@BenchmarkMode(Array(Mode.AverageTime))
@Threads(1)
@Fork(1)
@Warmup(iterations = 10, time = 1, timeUnit = SECONDS)
@Measurement(iterations = 10, time = 1, timeUnit = SECONDS)
class ListReplaceByIndexBenchmark {
@Benchmark
def listReplaceFirstByIndex(st: ListReplaceByIndexSt, bh: Blackhole): Unit =
bh.consume(eval(st.ctx, st.replaceFirst))

@Benchmark
def listReplaceMiddleByIndex(st: ListReplaceByIndexSt, bh: Blackhole): Unit =
bh.consume(eval(st.ctx, st.replaceMiddle))

@Benchmark
def listReplaceLastByIndex(st: ListReplaceByIndexSt, bh: Blackhole): Unit =
bh.consume(eval(st.ctx, st.replaceLast))
}

@State(Scope.Benchmark)
class ListReplaceByIndexSt {
val ctx =
PureContext
.build(StdLibVersion.VersionDic.all.max, useNewPowPrecision = true)
.withEnvironment[Environment]
.evaluationContext(Common.emptyBlockchainEnvironment())

val list = ARR(Vector.fill(1000)(CONST_LONG(Long.MaxValue)), limited = true).explicitGet()

val replaceFirst =
FUNCTION_CALL(
Native(REPLACE_BY_INDEX_OF_LIST),
List(
list,
CONST_LONG(0),
CONST_LONG(777)
)
)

val replaceMiddle =
FUNCTION_CALL(
Native(REPLACE_BY_INDEX_OF_LIST),
List(
list,
CONST_LONG(500),
CONST_LONG(777)
)
)

val replaceLast =
FUNCTION_CALL(
Native(REPLACE_BY_INDEX_OF_LIST),
List(
list,
CONST_LONG(999),
CONST_LONG(777)
)
)
}
Original file line number Diff line number Diff line change
@@ -1,100 +1,97 @@
package com.wavesplatform.lang.v1

import java.util.concurrent.TimeUnit

import cats.Id
import cats.kernel.Monoid
import cats.implicits.catsSyntaxSemigroup
import com.wavesplatform.common.state.ByteStr
import com.wavesplatform.common.utils.{Base58, EitherExt2}
import com.wavesplatform.crypto.Curve25519
import com.wavesplatform.lang.Global
import com.wavesplatform.lang.directives.values.{V1, V4}
import com.wavesplatform.lang.directives.values.StdLibVersion
import com.wavesplatform.lang.v1.EnvironmentFunctionsBenchmark.{curve25519, randomBytes}
import com.wavesplatform.lang.v1.FunctionHeader.Native
import com.wavesplatform.lang.v1.ScriptEvaluatorBenchmark.*
import com.wavesplatform.lang.v1.compiler.Terms.*
import com.wavesplatform.lang.v1.evaluator.Contextful.NoContext
import com.wavesplatform.lang.v1.evaluator.EvaluatorV1.*
import com.wavesplatform.lang.v1.evaluator.FunctionIds
import com.wavesplatform.lang.v1.evaluator.FunctionIds.{FROMBASE58, SIGVERIFY, TOBASE58}
import com.wavesplatform.lang.v1.evaluator.ctx.EvaluationContext
import com.wavesplatform.lang.v1.evaluator.ctx.impl.{CryptoContext, PureContext}
import com.wavesplatform.lang.v1.evaluator.{EvaluatorV1, FunctionIds}
import com.wavesplatform.lang.v1.traits.Environment
import com.wavesplatform.lang.{Common, Global}
import org.openjdk.jmh.annotations.*
import org.openjdk.jmh.infra.Blackhole

import java.util.concurrent.TimeUnit
import scala.concurrent.duration.SECONDS
import scala.util.Random

object ScriptEvaluatorBenchmark {
val version = V1
val pureEvalContext: EvaluationContext[NoContext, Id] =
PureContext.build(V1, useNewPowPrecision = true).evaluationContext
val evaluatorV1: EvaluatorV1[Id, NoContext] = new EvaluatorV1[Id, NoContext]()
val lastVersion = StdLibVersion.VersionDic.all.max
val context =
(PureContext.build(lastVersion, useNewPowPrecision = true) |+| CryptoContext.build(Global, lastVersion))
.withEnvironment[Environment]
.evaluationContext(Common.emptyBlockchainEnvironment())
}

@OutputTimeUnit(TimeUnit.MICROSECONDS)
@BenchmarkMode(Array(Mode.AverageTime))
@Threads(1)
@Fork(1)
@Warmup(iterations = 10)
@Measurement(iterations = 10)
@Warmup(iterations = 10, time = 1, timeUnit = SECONDS)
@Measurement(iterations = 10, time = 1, timeUnit = SECONDS)
class ScriptEvaluatorBenchmark {
@Benchmark
def bigSum(st: BigSum, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](pureEvalContext, st.expr))
def bigSum(st: BigSum, bh: Blackhole): Unit = bh.consume(eval(context, st.expr))

@Benchmark
def nestedBlocks(st: NestedBlocks, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.expr))
def nestedBlocks(st: NestedBlocks, bh: Blackhole): Unit = bh.consume(eval(context, st.expr))

@Benchmark
def signatures(st: Signatures, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.expr))
def signatures(st: Signatures, bh: Blackhole): Unit = bh.consume(eval(context, st.expr))

@Benchmark
def base58encode(st: Base58Perf, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.encode))
def base58encode(st: Base58Perf, bh: Blackhole): Unit = bh.consume(eval(context, st.encode))

@Benchmark
def base58decode(st: Base58Perf, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.decode))
def base58decode(st: Base58Perf, bh: Blackhole): Unit = bh.consume(eval(context, st.decode))

@Benchmark
def stringConcat(st: Concat, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.strings))
def stringConcat(st: Concat, bh: Blackhole): Unit = bh.consume(eval(context, st.strings))

@Benchmark
def bytesConcat(st: Concat, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.bytes))
def bytesConcat(st: Concat, bh: Blackhole): Unit = bh.consume(eval(context, st.bytes))

@Benchmark
def listMedianRandomElements(st: Median, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.randomElements(Random.nextInt(10000))))
bh.consume(eval(context, st.randomElements(Random.nextInt(10000))))

@Benchmark
def listMedianSortedElements(st: Median, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.sortedElements))
bh.consume(eval(context, st.sortedElements))

@Benchmark
def listMedianSortedReverseElements(st: Median, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.sortedReverseElements))
bh.consume(eval(context, st.sortedReverseElements))

@Benchmark
def listMedianEqualElements(st: Median, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.equalElements))
bh.consume(eval(context, st.equalElements))

@Benchmark
def listRemoveFirstByIndex(st: ListRemoveByIndex, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.removeFirst))
bh.consume(eval(context, st.removeFirst))

@Benchmark
def listRemoveMiddleByIndex(st: ListRemoveByIndex, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.removeMiddle))
bh.consume(eval(context, st.removeMiddle))

@Benchmark
def listRemoveLastByIndex(st: ListRemoveByIndex, bh: Blackhole): Unit =
bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.removeLast))
bh.consume(eval(context, st.removeLast))

@Benchmark
def sigVerify32Kb(st: SigVerify32Kb, bh: Blackhole): Unit = bh.consume(evaluatorV1.apply[EVALUATED](st.context, st.expr))
def sigVerify32Kb(st: SigVerify32Kb, bh: Blackhole): Unit =
bh.consume(eval(context, st.expr))
}

@State(Scope.Benchmark)
class NestedBlocks {
val context: EvaluationContext[NoContext, Id] = pureEvalContext

val expr: EXPR = {
val blockCount = 300
val cond = FUNCTION_CALL(PureContext.eq, List(REF(s"v$blockCount"), CONST_LONG(0)))
Expand All @@ -107,9 +104,6 @@ class NestedBlocks {

@State(Scope.Benchmark)
class Base58Perf {
val context: EvaluationContext[NoContext, Id] =
Monoid.combine(pureEvalContext, CryptoContext.build(Global, version).evaluationContext)

val encode: EXPR = {
val base58Count = 120
val sum = (1 to base58Count).foldRight[EXPR](CONST_LONG(0)) { case (i, e) =>
Expand Down Expand Up @@ -150,9 +144,6 @@ class Base58Perf {

@State(Scope.Benchmark)
class Signatures {
val context: EvaluationContext[NoContext, Id] =
Monoid.combine(pureEvalContext, CryptoContext.build(Global, version).evaluationContext)

val expr: EXPR = {
val sigCount = 20
val sum = (1 to sigCount).foldRight[EXPR](CONST_LONG(0)) { case (i, e) =>
Expand Down Expand Up @@ -191,8 +182,6 @@ class Signatures {

@State(Scope.Benchmark)
class Concat {
val context: EvaluationContext[NoContext, Id] = pureEvalContext

private val Steps = 180

private def expr(init: EXPR, func: FunctionHeader, operand: EXPR, count: Int) =
Expand All @@ -218,8 +207,6 @@ class Concat {

@State(Scope.Benchmark)
class Median {
val context: EvaluationContext[NoContext, Id] = PureContext.build(V4, useNewPowPrecision = true).evaluationContext

val randomElements: Array[EXPR] =
(1 to 10000).map { _ =>
val listOfLong = (1 to 1000).map(_ => CONST_LONG(Random.nextLong()))
Expand Down Expand Up @@ -260,9 +247,6 @@ class Median {

@State(Scope.Benchmark)
class SigVerify32Kb {
val context: EvaluationContext[NoContext, Id] =
Monoid.combine(PureContext.build(V4, useNewPowPrecision = true).evaluationContext, CryptoContext.build(Global, V4).evaluationContext)

val expr: EXPR = {
val (privateKey, publicKey) = curve25519.generateKeypair
val message = randomBytes(32 * 1024 - 1)
Expand All @@ -281,12 +265,6 @@ class SigVerify32Kb {

@State(Scope.Benchmark)
class ListRemoveByIndex {
val context: EvaluationContext[NoContext, Id] =
Monoid.combine(
PureContext.build(V4, useNewPowPrecision = true).evaluationContext,
CryptoContext.build(Global, V4).evaluationContext
)

val list: ARR = ARR(Vector.fill(1000)(CONST_LONG(Long.MaxValue)), limited = true).explicitGet()

val removeFirst: EXPR =
Expand All @@ -312,7 +290,7 @@ class ListRemoveByIndex {
Native(FunctionIds.REMOVE_BY_INDEX_OF_LIST),
List(
list,
CONST_LONG(1000)
CONST_LONG(999)
)
)
}
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ package object v1 {
def eval(
ctx: EvaluationContext[Environment, Id],
expr: EXPR,
stdLibVersion: StdLibVersion
stdLibVersion: StdLibVersion = StdLibVersion.VersionDic.all.max
): (Log[Id], Int, Either[ExecutionError, Terms.EVALUATED]) =
EvaluatorV2.applyCompleted(ctx, expr, LogExtraInfo(), stdLibVersion, newMode = true, correctFunctionCallScope = true, enableExecutionLog = false)
}
10 changes: 5 additions & 5 deletions benchmark/src/test/scala/com/wavesplatform/state/BaseState.scala
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package com.wavesplatform.state

import java.io.File
import java.nio.file.Files

import com.typesafe.config.ConfigFactory
import com.wavesplatform.account.KeyPair
import com.wavesplatform.block.Block
Expand Down Expand Up @@ -76,11 +75,12 @@ trait BaseState {
.block

private def append(prev: Option[Block], next: Block): Unit = {
val preconditionSnapshot =
BlockDiffer.fromBlock(state, prev, next, MiningConstraint.Unlimited, next.header.generationSignature)
val differResult =
BlockDiffer
.fromBlock(state, prev, next, None, MiningConstraint.Unlimited, next.header.generationSignature)
.explicitGet()
.snapshot
state.append(preconditionSnapshot, 0, 0, None, next.header.generationSignature, next)

state.append(differResult.snapshot, 0, 0, None, next.header.generationSignature, differResult.computedStateHash, next)
}

def applyBlock(b: Block): Unit = {
Expand Down
Loading

0 comments on commit 4ac6293

Please sign in to comment.