0

Eclipse Juno(4.2) で Scala(2.10) で Caliper を使用しようとしています。まず、配列に対して foreachloop を単純に繰り返すベンチマークを設定しました。

import com.google.caliper.Param
import com.google.caliper.SimpleBenchmark

class Benchmark extends SimpleBenchmark {

  @Param(Array("10", "100", "1000", "10000"))
  val length: Int = 0
  var array: Array[Int] = _

  override def setUp() {
    array = new Array(length)
  }

  def timeForeach(reps: Int) = {
    var result = 0
    array.foreach {
      result += _
    }
    result
  }

ベンチマークを開始すると:

object myRunner {
 def main(args: Array[String]) {
   Runner.main(classOf[Benchmark], args)
 }
}

理解できないこれらの例外が発生します

0% Scenario{vm=java, trial=0, benchmark=Foreach, length=10}  Failed to execute java -cp C:\Users\bob\workspace\myBenchmark\bin;C:\Users\bob\workspace\caliper\caliper\target>\classes;C:\Users\bob\workspace\caliper\caliper\target\test-classes;C:\Users\bob\.m2\repository\com\google\code\findbugs\jsr305\1.3.9\jsr305-1.3.9.jar;C:\Users\bob\.m2\repository\com\google\code\gson\gson\1.7.1\gson-1.7.1.jar;C:\Users\bob\.m2\repository\com\google\guava\guava\11.0.1\guava-11.0.1.jar;C:\Users\bob\.m2\repository\com\google\code\java-allocation-instrumenter\java-allocation-instrumenter\2.0\java-allocation-instrumenter-2.0.jar;C:\Users\bob\.m2\repository\asm\asm\3.3.1\asm-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-analysis\3.3.1\asm-analysis-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-commons\3.3.1\asm-commons-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-tree\3.3.1\asm-tree-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-util\3.3.1\asm-util-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-xml\3.3.1\asm-xml-3.3.1.jar;C:\Users\bob\.m2\repository\junit\junit\3.8.2\junit-3.8.2.jar com.google.caliper.InProcessRunner --warmupMillis 3000 --runMillis 1000 --measurementType TIME --marker //ZxJ/ -Dbenchmark=Foreach -Dlength=10 org.example.Benchmark
Exception in thread "main" java.lang.NoClassDefFoundError: scala/Function1
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Unknown Source)
    at com.google.caliper.ScenarioSelection.getClassByName(ScenarioSelection.java:154)
    at com.google.caliper.ScenarioSelection.prepareSuite(ScenarioSelection.java:123)
    at com.google.caliper.ScenarioSelection.select(ScenarioSelection.java:83)
    at com.google.caliper.InProcessRunner.run(InProcessRunner.java:38)
    at com.google.caliper.InProcessRunner.main(InProcessRunner.java:103)
Caused by: java.lang.ClassNotFoundException: scala.Function1
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 7 more

An exception was thrown from the benchmark code.
com.google.caliper.ConfigurationException: Failed to execute java -cp C:\Users\bob\workspace\myBenchmark\bin;C:\Users\bob\workspace\caliper\caliper\target\classes;C:\Users\bob\workspace\caliper\caliper\target\test-classes;C:\Users\bob\.m2\repository\com\google\code\findbugs\jsr305\1.3.9\jsr305-1.3.9.jar;C:\Users\bob\.m2\repository\com\google\code\gson\gson\1.7.1\gson-1.7.1.jar;C:\Users\bob\.m2\repository\com\google\guava\guava\11.0.1\guava-11.0.1.jar;C:\Users\bob\.m2\repository\com\google\code\java-allocation-instrumenter\java-allocation-instrumenter\2.0\java-allocation-instrumenter-2.0.jar;C:\Users\bob\.m2\repository\asm\asm\3.3.1\asm-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-analysis\3.3.1\asm-analysis-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-commons\3.3.1\asm-commons-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-tree\3.3.1\asm-tree-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-util\3.3.1\asm-util-3.3.1.jar;C:\Users\bob\.m2\repository\asm\asm-xml\3.3.1\asm-xml-3.3.1.jar;C:\Users\bob\.m2\repository\junit\junit\3.8.2\junit-3.8.2.jar com.google.caliper.InProcessRunner --warmupMillis 3000 --runMillis 1000 --measurementType TIME --marker //ZxJ/ -Dbenchmark=Foreach -Dlength=10 org.example.Benchmark
    at com.google.caliper.Runner.measure(Runner.java:309)
    at com.google.caliper.Runner.runScenario(Runner.java:229)
    at com.google.caliper.Runner.runOutOfProcess(Runner.java:378)
    at com.google.caliper.Runner.run(Runner.java:97)
    at com.google.caliper.Runner.main(Runner.java:423)
    at com.google.caliper.Runner.main(Runner.java:436)
    at org.example.myRunner$.main(myRunner.scala:7)
    at org.example.myRunner.main(myRunner.scala)

クラスパスに問題があると思いますが、よくわかりません。

誰かが私を助けてくれることを願っています:)

前もって感謝します

4

3 に答える 3

2

Caliperが新しいJVMを実行しているように見え、クラスパスにScalaライブラリを含める必要があることを認識していません。

この質問javaでは、コマンドラインのコマンドを使用してScalaアプリを実行する方法について説明します。これは、この問題を解決するための良い出発点になるはずです。

于 2013-01-09T16:38:35.890 に答える
0

ご協力いただきありがとうございます。問題は予想通り愚かなクラスパスでした。googlecodeからcaliperプロジェクトをダウンロードし、scala依存関係を追加しました。今、私は依存関係のある独自のjarを作成しましたが、それは非常にうまく機能します。

とにかく答えてくれてありがとう:-)

于 2013-01-15T09:00:06.437 に答える