py_benchmark.py 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import sys
  2. import os
  3. import timeit
  4. import math
  5. import fnmatch
  6. # BEGIN CPP GENERATED MESSAGE
  7. # CPP generated code must be linked before importing the generated Python code
  8. # for the descriptor can be found in the pool
  9. if len(sys.argv) < 2:
  10. raise IOError("Need string argument \"true\" or \"false\" for whether to use cpp generated code")
  11. if sys.argv[1] == "true":
  12. sys.path.append( os.path.dirname( os.path.dirname( os.path.abspath(__file__) ) ) + "/.libs" )
  13. import libbenchmark_messages
  14. sys.path.append( os.path.dirname( os.path.dirname( os.path.abspath(__file__) ) ) + "/tmp" )
  15. elif sys.argv[1] != "false":
  16. raise IOError("Need string argument \"true\" or \"false\" for whether to use cpp generated code")
  17. # END CPP GENERATED MESSAGE
  18. import datasets.google_message1.proto2.benchmark_message1_proto2_pb2 as benchmark_message1_proto2_pb2
  19. import datasets.google_message1.proto3.benchmark_message1_proto3_pb2 as benchmark_message1_proto3_pb2
  20. import datasets.google_message2.benchmark_message2_pb2 as benchmark_message2_pb2
  21. import datasets.google_message3.benchmark_message3_pb2 as benchmark_message3_pb2
  22. import datasets.google_message4.benchmark_message4_pb2 as benchmark_message4_pb2
  23. import benchmarks_pb2 as benchmarks_pb2
  24. def run_one_test(filename):
  25. data = open(os.path.dirname(sys.argv[0]) + "/../" + filename).read()
  26. benchmark_dataset = benchmarks_pb2.BenchmarkDataset()
  27. benchmark_dataset.ParseFromString(data)
  28. benchmark_util = Benchmark(full_iteration=len(benchmark_dataset.payload),
  29. module="py_benchmark",
  30. setup_method="init")
  31. print "Message %s of dataset file %s" % \
  32. (benchmark_dataset.message_name, filename)
  33. benchmark_util.set_test_method("parse_from_benchmark")
  34. print benchmark_util.run_benchmark(setup_method_args='"%s"' % (filename))
  35. benchmark_util.set_test_method("serialize_to_benchmark")
  36. print benchmark_util.run_benchmark(setup_method_args='"%s"' % (filename))
  37. print ""
  38. def init(filename):
  39. global benchmark_dataset, message_class, message_list, counter
  40. message_list=[]
  41. counter = 0
  42. data = open(os.path.dirname(sys.argv[0]) + "/../" + filename).read()
  43. benchmark_dataset = benchmarks_pb2.BenchmarkDataset()
  44. benchmark_dataset.ParseFromString(data)
  45. if benchmark_dataset.message_name == "benchmarks.proto3.GoogleMessage1":
  46. message_class = benchmark_message1_proto3_pb2.GoogleMessage1
  47. elif benchmark_dataset.message_name == "benchmarks.proto2.GoogleMessage1":
  48. message_class = benchmark_message1_proto2_pb2.GoogleMessage1
  49. elif benchmark_dataset.message_name == "benchmarks.proto2.GoogleMessage2":
  50. message_class = benchmark_message2_pb2.GoogleMessage2
  51. elif benchmark_dataset.message_name == "benchmarks.google_message3.GoogleMessage3":
  52. message_class = benchmark_message3_pb2.GoogleMessage3
  53. elif benchmark_dataset.message_name == "benchmarks.google_message4.GoogleMessage4":
  54. message_class = benchmark_message4_pb2.GoogleMessage4
  55. else:
  56. raise IOError("Message %s not found!" % (benchmark_dataset.message_name))
  57. for one_payload in benchmark_dataset.payload:
  58. temp = message_class()
  59. temp.ParseFromString(one_payload)
  60. message_list.append(temp)
  61. def parse_from_benchmark():
  62. global counter, message_class, benchmark_dataset
  63. m = message_class().ParseFromString(benchmark_dataset.payload[counter % len(benchmark_dataset.payload)])
  64. counter = counter + 1
  65. def serialize_to_benchmark():
  66. global counter, message_list, message_class
  67. s = message_list[counter % len(benchmark_dataset.payload)].SerializeToString()
  68. counter = counter + 1
  69. class Benchmark:
  70. def __init__(self, module=None, test_method=None,
  71. setup_method=None, full_iteration = 1):
  72. self.full_iteration = full_iteration
  73. self.module = module
  74. self.test_method = test_method
  75. self.setup_method = setup_method
  76. def set_test_method(self, test_method):
  77. self.test_method = test_method
  78. def full_setup_code(self, setup_method_args=''):
  79. setup_code = ""
  80. setup_code += "from %s import %s\n" % (self.module, self.test_method)
  81. setup_code += "from %s import %s\n" % (self.module, self.setup_method)
  82. setup_code += "%s(%s)\n" % (self.setup_method, setup_method_args)
  83. return setup_code
  84. def dry_run(self, test_method_args='', setup_method_args=''):
  85. return timeit.timeit(stmt="%s(%s)" % (self.test_method, test_method_args),
  86. setup=self.full_setup_code(setup_method_args),
  87. number=self.full_iteration);
  88. def run_benchmark(self, test_method_args='', setup_method_args=''):
  89. reps = self.full_iteration;
  90. t = self.dry_run(test_method_args, setup_method_args);
  91. if t < 3 :
  92. reps = int(math.ceil(3 / t)) * self.full_iteration
  93. t = timeit.timeit(stmt="%s(%s)" % (self.test_method, test_method_args),
  94. setup=self.full_setup_code(setup_method_args),
  95. number=reps);
  96. return "Average time for %s: %.2f ns" % \
  97. (self.test_method, 1.0 * t / reps * (10 ** 9))
  98. if __name__ == "__main__":
  99. for i in range(2, len(sys.argv)):
  100. run_one_test(sys.argv[i])