forked from CMS-HGCAL/rpi-daq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdaq-zmq-server.py
82 lines (71 loc) · 3.42 KB
/
daq-zmq-server.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import zmq,yaml
import ctypes,struct,datetime,time
import rpi_daq, unpacker
import skiroc2cms_bit_string as sk2conf
if __name__ == "__main__":
context = zmq.Context()
socket = context.socket(zmq.REP)
socket.bind("tcp://*:5555")
pusher=context.socket(zmq.PUSH)
pusher.bind("tcp://*:5556")
daq_options=yaml.YAMLObject()
theDaq=0
packer=0
try:
while True:
string = socket.recv()
print("Received request: %s" % string)
content = string.split()
if content[0] == "DAQ_CONFIG":
socket.send("READY_FOR_CONFIG")
yamlstring=socket.recv()
print yamlstring
yaml_conf=yaml.safe_load(yamlstring)
socket.send(yaml.dump(yaml_conf))
daq_options=yaml_conf['daq_options']
theDaq=rpi_daq.rpi_daq(daq_options)#can modify global daq parameter here (DAC_HIGH_WORD,DAC_LOW_WORD,TRIGGER_DELAY)
dataSize=30786 # 30784 + 2 for injection value
if daq_options['compressRawData']==True:
dataSize=15394 # 30784/2 + 2 for injection value
packer=struct.Struct('B'*dataSize)
elif content[0] == "CONFIGURE":
the_bit_string=sk2conf.bit_string()
if daq_options['externalChargeInjection']==True:
the_bit_string.set_channels_for_charge_injection(daq_options['channelIds'])
if daq_options['preampFeedbackCapacitance']>63:
print "!!!!!!!!! WARNING :: preampFeedbackCapacitance should not be higher than 63 !!!!!!!"
the_bit_string.set_preamp_feedback_capacitance(daq_options['preampFeedbackCapacitance'])
the_bit_string.set_channels_to_mask(daq_options['channelIdsToMask'])
the_bit_string.set_channels_to_disable_trigger_tot(daq_options['channelIdsDisableTOT'])
the_bit_string.set_channels_to_disable_trigger_toa(daq_options['channelIdsDisableTOA'])
the_bit_string.set_tot_dac_threshold(daq_options['totDACThreshold'])
the_bit_string.Print()
the_bits_c_uchar_p=the_bit_string.get_48_unsigned_char_p()
outputBitString=theDaq.configure(the_bits_c_uchar_p)
msg=''
for i in range(48):
msg=msg+hex(outputBitString[i])+' '
socket.send(msg)
elif content[0] == "PROCESS_EVENT":
rawdata=theDaq.processEvent()
pdata=packer.pack(*rawdata)
socket.send(pdata)
elif content[0] == "PROCESS_AND_PUSH_N_EVENTS":
socket.send("start to process and push the events")
print("start to process and push the events")
for i in xrange(daq_options['nEvent']):
rawdata=theDaq.processEvent()
pdata=packer.pack(*rawdata)
pusher.send(pdata)
print("finish to process and push the events")
elif content[0] == "END_OF_RUN":
pusher.close()
socket.send("CLOSING_SERVER")
socket.close()
context.term()
break
except KeyboardInterrupt:
print('\nClosing server')
pusher.close()
socket.close()
context.term()