Home | History | Annotate | Download | only in benchmarks
      1 Contents
      2 --------
      3 
      4 This folder contains three kinds of file:
      5 
      6 - Code, such as ProtoBench.java, to build the benchmarking framework.
      7 - Protocol buffer definitions (.proto files)
      8 - Sample data files
      9 
     10 If we end up with a lot of different benchmarks it may be worth
     11 separating these out info different directories, but while there are
     12 so few they might as well all be together.
     13 
     14 Running a benchmark (Java)
     15 --------------------------
     16 
     17 1) Build protoc and the Java protocol buffer library. The examples
     18    below assume a jar file (protobuf.jar) has been built and copied
     19    into this directory.
     20 
     21 2) Build ProtoBench:
     22    $ javac -d tmp -cp protobuf.jar ProtoBench.java
     23    
     24 3) Generate code for the relevant benchmark protocol buffer, e.g.
     25    $ protoc --java_out=tmp google_size.proto google_speed.proto
     26    
     27 4) Build the generated code, e.g.
     28    $ cd tmp
     29    $ javac -d . -cp ../protobuf.jar benchmarks/*.java
     30            
     31 5) Run the test. Arguments are given in pairs - the first argument
     32    is the descriptor type; the second is the filename. For example:
     33    $ java -cp .;../protobuf.jar com.google.protocolbuffers.ProtoBench
     34           benchmarks.GoogleSize$SizeMessage1 ../google_message1.dat
     35           benchmarks.GoogleSpeed$SpeedMessage1 ../google_message1.dat
     36           benchmarks.GoogleSize$SizeMessage2 ../google_message2.dat
     37           benchmarks.GoogleSpeed$SpeedMessage2 ../google_message2.dat
     38           
     39 6) Wait! Each test runs for around 30 seconds, and there are 6 tests
     40    per class/data combination. The above command would therefore take
     41    about 12 minutes to run.
     42 
     43    
     44 Benchmarks available
     45 --------------------
     46 
     47 From Google:
     48 google_size.proto and google_speed.proto, messages
     49 google_message1.dat and google_message2.dat. The proto files are
     50 equivalent, but optimized differently.
     51