ray/test/microbenchmarks.py

102 lines
3.6 KiB
Python
Raw Normal View History

2016-05-22 10:05:14 -07:00
import unittest
2016-06-10 14:12:15 -07:00
import ray
2016-05-22 10:05:14 -07:00
import time
import numpy as np
import test_functions
class MicroBenchmarkTest(unittest.TestCase):
2016-05-22 10:05:14 -07:00
def testTiming(self):
reload(test_functions)
ray.init(start_ray_local=True, num_workers=3)
2016-05-22 10:05:14 -07:00
2016-05-26 16:33:30 -07:00
# measure the time required to submit a remote task to the scheduler
2016-05-22 10:05:14 -07:00
elapsed_times = []
for _ in range(1000):
start_time = time.time()
test_functions.empty_function.remote()
2016-05-22 10:05:14 -07:00
end_time = time.time()
elapsed_times.append(end_time - start_time)
elapsed_times = np.sort(elapsed_times)
average_elapsed_time = sum(elapsed_times) / 1000
print "Time required to submit an empty function call:"
print " Average: {}".format(average_elapsed_time)
print " 90th percentile: {}".format(elapsed_times[900])
print " 99th percentile: {}".format(elapsed_times[990])
print " worst: {}".format(elapsed_times[999])
# average_elapsed_time should be about 0.00038
2016-05-22 10:05:14 -07:00
2016-05-26 16:33:30 -07:00
# measure the time required to submit a remote task to the scheduler (where the remote task returns one value)
2016-05-22 10:05:14 -07:00
elapsed_times = []
for _ in range(1000):
start_time = time.time()
test_functions.trivial_function.remote()
2016-05-22 10:05:14 -07:00
end_time = time.time()
elapsed_times.append(end_time - start_time)
elapsed_times = np.sort(elapsed_times)
average_elapsed_time = sum(elapsed_times) / 1000
print "Time required to submit a trivial function call:"
print " Average: {}".format(average_elapsed_time)
print " 90th percentile: {}".format(elapsed_times[900])
print " 99th percentile: {}".format(elapsed_times[990])
print " worst: {}".format(elapsed_times[999])
# average_elapsed_time should be about 0.001
2016-05-22 10:05:14 -07:00
2016-06-23 12:58:48 -07:00
# measure the time required to submit a remote task to the scheduler and get the result
2016-05-22 10:05:14 -07:00
elapsed_times = []
for _ in range(1000):
start_time = time.time()
x = test_functions.trivial_function.remote()
2016-06-23 12:58:48 -07:00
ray.get(x)
2016-05-22 10:05:14 -07:00
end_time = time.time()
elapsed_times.append(end_time - start_time)
elapsed_times = np.sort(elapsed_times)
average_elapsed_time = sum(elapsed_times) / 1000
2016-06-23 12:58:48 -07:00
print "Time required to submit a trivial function call and get the result:"
2016-05-22 10:05:14 -07:00
print " Average: {}".format(average_elapsed_time)
print " 90th percentile: {}".format(elapsed_times[900])
print " 99th percentile: {}".format(elapsed_times[990])
print " worst: {}".format(elapsed_times[999])
# average_elapsed_time should be about 0.0013
2016-05-22 10:05:14 -07:00
2016-06-23 12:58:48 -07:00
# measure the time required to do do a put
2016-05-22 10:05:14 -07:00
elapsed_times = []
for _ in range(1000):
start_time = time.time()
2016-06-23 12:58:48 -07:00
ray.put(1)
2016-05-22 10:05:14 -07:00
end_time = time.time()
elapsed_times.append(end_time - start_time)
elapsed_times = np.sort(elapsed_times)
average_elapsed_time = sum(elapsed_times) / 1000
2016-06-23 12:58:48 -07:00
print "Time required to put an int:"
2016-05-22 10:05:14 -07:00
print " Average: {}".format(average_elapsed_time)
print " 90th percentile: {}".format(elapsed_times[900])
print " 99th percentile: {}".format(elapsed_times[990])
print " worst: {}".format(elapsed_times[999])
# average_elapsed_time should be about 0.00087
2016-05-22 10:05:14 -07:00
ray.worker.cleanup()
def testCache(self):
ray.init(start_ray_local=True, num_workers=1)
A = np.random.rand(5000, 5000)
v = np.random.rand(5000)
A_id = ray.put(A)
v_id = ray.put(v)
a = time.time()
for i in range(100):
A.dot(v)
b = time.time() - a
c = time.time()
for i in range(100):
ray.get(A_id).dot(ray.get(v_id))
d = time.time() - c
self.assertLess(d, 1.5 * b)
ray.worker.cleanup()
2016-06-24 19:43:24 -07:00
if __name__ == "__main__":
unittest.main(verbosity=2)