throughput.py
85 lines
| 2.1 KiB
| text/x-python
|
PythonLexer
MinRK
|
r3564 | import time | |
import numpy as np | |||
MinRK
|
r3666 | from IPython import parallel | |
MinRK
|
r3564 | ||
nlist = map(int, np.logspace(2,9,16,base=2)) | |||
nlist2 = map(int, np.logspace(2,8,15,base=2)) | |||
tlist = map(int, np.logspace(7,22,16,base=2)) | |||
nt = 16 | |||
def wait(t=0): | |||
import time | |||
time.sleep(t) | |||
def echo(s=''): | |||
return s | |||
def time_throughput(nmessages, t=0, f=wait): | |||
MinRK
|
r3666 | client = parallel.Client() | |
MinRK
|
r3564 | view = client[None] | |
# do one ping before starting timing | |||
if f is echo: | |||
t = np.random.random(t/8) | |||
view.apply_sync(echo, '') | |||
client.spin() | |||
tic = time.time() | |||
for i in xrange(nmessages): | |||
view.apply(f, t) | |||
lap = time.time() | |||
client.barrier() | |||
toc = time.time() | |||
return lap-tic, toc-tic | |||
def time_twisted(nmessages, t=0, f=wait): | |||
from IPython.kernel import client as kc | |||
client = kc.TaskClient() | |||
if f is wait: | |||
s = "import time; time.sleep(%f)"%t | |||
task = kc.StringTask(s) | |||
elif f is echo: | |||
t = np.random.random(t/8) | |||
s = "s=t" | |||
task = kc.StringTask(s, push=dict(t=t), pull=['s']) | |||
else: | |||
raise | |||
# do one ping before starting timing | |||
client.barrier(client.run(task)) | |||
tic = time.time() | |||
tids = [] | |||
for i in xrange(nmessages): | |||
tids.append(client.run(task)) | |||
lap = time.time() | |||
client.barrier(tids) | |||
toc = time.time() | |||
return lap-tic, toc-tic | |||
def do_runs(nlist,t=0,f=wait, trials=2, runner=time_throughput): | |||
A = np.zeros((len(nlist),2)) | |||
for i,n in enumerate(nlist): | |||
t1 = t2 = 0 | |||
for _ in range(trials): | |||
time.sleep(.25) | |||
ts = runner(n,t,f) | |||
t1 += ts[0] | |||
t2 += ts[1] | |||
t1 /= trials | |||
t2 /= trials | |||
A[i] = (t1,t2) | |||
A[i] = n/A[i] | |||
print n,A[i] | |||
return A | |||
def do_echo(n,tlist=[0],f=echo, trials=2, runner=time_throughput): | |||
A = np.zeros((len(tlist),2)) | |||
for i,t in enumerate(tlist): | |||
t1 = t2 = 0 | |||
for _ in range(trials): | |||
time.sleep(.25) | |||
ts = runner(n,t,f) | |||
t1 += ts[0] | |||
t2 += ts[1] | |||
t1 /= trials | |||
t2 /= trials | |||
A[i] = (t1,t2) | |||
A[i] = n/A[i] | |||
print t,A[i] | |||
return A | |||