This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
start = time.time() | |
for pv_name in pv_list: | |
pv = PV(pv_name) | |
if pv.wait_for_connection(timeout=1.0): | |
result[pv_name] = pv.get(use_monitor=False) | |
else: | |
result[pv_name] = 'not connected' | |
duration = time.time() - start | |
print int(round(duration * 1000)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
start = time.time() | |
for pv_name in pv_list: | |
ch = ca.create_channel(pv_name, connect=False, auto_cb=False) | |
result[pv_name] = [ch, None, None] | |
for pv_name, data in result.items(): | |
result[pv_name][1] = ca.connect_channel(data[0], timeout=1.0) | |
ca.poll() | |
for pv_name, data in result.items(): | |
if result[pv_name][1]: | |
ca.get(data[0], wait=False) | |
ca.poll() | |
for pv_name, data in result.items(): | |
if result[pv_name][1]: | |
val = ca.get_complete(data[0]) | |
result[pv_name][2] = val | |
else: | |
result[pv_name][2] = 'not connected' | |
duration = time.time() - start | |
print int(round(duration * 1000)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# ... | |
from multiprocessing import Process, Manager | |
def get(d, pv_name, size, start, pid): | |
pv = PV(pv_name) | |
if pv.wait_for_connection(timeout=1.0): | |
d[pv_name] = pv.get(use_monitor=False) | |
else: | |
d[pv_name] = 'not connected' | |
if len(d) == size: | |
print int(round((time.time() - start) * 1000)) | |
os.kill(pid, signal.SIGTERM) | |
# ... | |
size = len(pv_list) | |
manager = Manager() | |
d = manager.dict() | |
start = time.time() | |
pid = os.getpid() | |
for pv_name in pv_list: | |
p = Process(target=get, args=(d, pv_name, size, start, pid)) | |
p.start() | |
time.sleep(30) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
def get(d, pv_name, size, start, pid): | |
ch = ca.create_channel(pv_name, connect=False, auto_cb=False) | |
if ca.connect_channel(ch, timeout=1.0): | |
d[pv_name] = ca.get(ch, wait=True) | |
else: | |
d[pv_name] = 'not connected' | |
if len(d) == size: | |
print int(round((time.time() - start) * 1000)) | |
os.kill(pid, signal.SIGTERM) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
start = Date.now(); | |
size = pv_list.length; | |
pv_list.forEach(function(pv) { | |
ca.exec('caget', pv, function(err, result) { | |
complete = complete + 1; | |
if (err) { | |
results[pv] = { | |
name: pv, | |
value: 'unavailable' | |
}; | |
} else { | |
results[pv] = ca.parseCaget(result); | |
} | |
if (complete == size) { | |
console.log('the snapshot took ' + (Date.now() - start) + ' milliseconds.'); | |
} | |
}); | |
}); |