forked from M-Labs/artiq
master: broadcast realtime results
This commit is contained in:
parent
ebdd92c7c4
commit
c0bdc92b18
24
artiq/management/rt_results.py
Normal file
24
artiq/management/rt_results.py
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
from artiq.management.sync_struct import Notifier, process_mod
|
||||||
|
|
||||||
|
|
||||||
|
class RTResults:
|
||||||
|
def __init__(self):
|
||||||
|
self.sets = Notifier(dict())
|
||||||
|
self.current_set = "default"
|
||||||
|
|
||||||
|
def init(self, description):
|
||||||
|
data = dict()
|
||||||
|
for rtr in description.keys():
|
||||||
|
if isinstance(rtr, tuple):
|
||||||
|
for e in rtr:
|
||||||
|
data[e] = []
|
||||||
|
else:
|
||||||
|
data[rtr] = []
|
||||||
|
self.sets[self.current_set] = {
|
||||||
|
"description": description,
|
||||||
|
"data": data
|
||||||
|
}
|
||||||
|
|
||||||
|
def update(self, mod):
|
||||||
|
target = self.sets[self.current_set]["data"]
|
||||||
|
process_mod(target, mod)
|
@ -48,8 +48,8 @@ class ParentPDB:
|
|||||||
set = make_parent_action("set_parameter", "name value")
|
set = make_parent_action("set_parameter", "name value")
|
||||||
|
|
||||||
|
|
||||||
init_rt_results = make_parent_action("init_rt_results", "data")
|
init_rt_results = make_parent_action("init_rt_results", "description")
|
||||||
update_rt_results = make_parent_action("update_rt_results", "data")
|
update_rt_results = make_parent_action("update_rt_results", "mod")
|
||||||
|
|
||||||
|
|
||||||
def publish_rt_results(notifier, data):
|
def publish_rt_results(notifier, data):
|
||||||
|
@ -8,6 +8,7 @@ from artiq.management.pc_rpc import Server
|
|||||||
from artiq.management.sync_struct import Publisher
|
from artiq.management.sync_struct import Publisher
|
||||||
from artiq.management.db import FlatFileDB, SimpleHistory
|
from artiq.management.db import FlatFileDB, SimpleHistory
|
||||||
from artiq.management.scheduler import Scheduler
|
from artiq.management.scheduler import Scheduler
|
||||||
|
from artiq.management.rt_results import RTResults
|
||||||
|
|
||||||
|
|
||||||
def _get_args():
|
def _get_args():
|
||||||
@ -24,14 +25,6 @@ def _get_args():
|
|||||||
return parser.parse_args()
|
return parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
def init_rt_results(data):
|
|
||||||
print("init realtime results: " + str(data))
|
|
||||||
|
|
||||||
|
|
||||||
def update_rt_results(data):
|
|
||||||
print("update realtime results: " + str(data))
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
args = _get_args()
|
args = _get_args()
|
||||||
|
|
||||||
@ -39,6 +32,7 @@ def main():
|
|||||||
pdb = FlatFileDB("pdb.pyon")
|
pdb = FlatFileDB("pdb.pyon")
|
||||||
simplephist = SimpleHistory(30)
|
simplephist = SimpleHistory(30)
|
||||||
pdb.hooks.append(simplephist)
|
pdb.hooks.append(simplephist)
|
||||||
|
rtr = RTResults()
|
||||||
|
|
||||||
loop = asyncio.get_event_loop()
|
loop = asyncio.get_event_loop()
|
||||||
atexit.register(lambda: loop.close())
|
atexit.register(lambda: loop.close())
|
||||||
@ -47,8 +41,8 @@ def main():
|
|||||||
"req_device": ddb.request,
|
"req_device": ddb.request,
|
||||||
"req_parameter": pdb.request,
|
"req_parameter": pdb.request,
|
||||||
"set_parameter": pdb.set,
|
"set_parameter": pdb.set,
|
||||||
"init_rt_results": init_rt_results,
|
"init_rt_results": rtr.init,
|
||||||
"update_rt_results": update_rt_results
|
"update_rt_results": rtr.update
|
||||||
})
|
})
|
||||||
loop.run_until_complete(scheduler.start())
|
loop.run_until_complete(scheduler.start())
|
||||||
atexit.register(lambda: loop.run_until_complete(scheduler.stop()))
|
atexit.register(lambda: loop.run_until_complete(scheduler.stop()))
|
||||||
@ -67,7 +61,8 @@ def main():
|
|||||||
"periodic": scheduler.periodic,
|
"periodic": scheduler.periodic,
|
||||||
"devices": ddb.data,
|
"devices": ddb.data,
|
||||||
"parameters": pdb.data,
|
"parameters": pdb.data,
|
||||||
"parameters_simplehist": simplephist.history
|
"parameters_simplehist": simplephist.history,
|
||||||
|
"rt_results": rtr.sets
|
||||||
})
|
})
|
||||||
loop.run_until_complete(server_notify.start(
|
loop.run_until_complete(server_notify.start(
|
||||||
args.bind, args.port_notify))
|
args.bind, args.port_notify))
|
||||||
|
Loading…
Reference in New Issue
Block a user