Skip to content
Snippets Groups Projects

Compare revisions

Changes are shown as if the source revision was being merged into the target revision. Learn more about comparing revisions.

Source

Select target project
No results found
Select Git revision
  • release
  • workshop
2 results

Target

Select target project
  • mecinam2/ccs
1 result
Select Git revision
  • release
  • workshop
2 results
Show changes
Commits on Source (2)
......@@ -659,7 +659,7 @@ class FpmProcessor:
def filter_frames(objlist, empty_frames=True):
if not empty_frames:
if empty_frames:
return [x for x in objlist if isinstance(x, EventFrame)]
else:
return [x for x in objlist if isinstance(x, EventFrame) and x.nevts > 0]
......
"""
Examples for Athena WFI DE communications
"""
import communication as com
import packet_config_ATHENA_DE as de
import tools.dataprocessing.athena_de_frame_proc as fputils
# set up socket and connect
decon = com.Connector('', 12345, msgdecoding='hex')
decon.connect()
# example commands
# test echo interface (0x20)
decon.send(b'\x20\xDE\xAD')
# HK interface 0x33
decon.send(de.HkCmdRead(0x1000)) # get PCM MODE register
decon.send(de.HkCmdWrite(0x1000, 0x0001)) # set PCM MODE register
# CMD interface 0x34
decon.send(de.CmdWrite(0x3C00, 0x0001)) # write sequencer register
decon.send(de.CmdWrite(0x3C00, 1), rx=False) # write sequencer register, but don't fetch cmd response from socket
decon.send(de.CmdRead(0x3C00)) # read sequencer register
# SCI interface 0x35
decon.send(de.SciCmd(100)) # set science data output rate
# dump cmd log (decon.log)
logfile = '/path/to/de_cmd.log'
decon.dump_log(logfile)
# automatically log to file
decon.setup_storage(logfile)
# run rx thread on socket, received data is put in recvd_data_buf queue
decon.start_receiver()
decon.receiver.recvd_data_buf
# optionally, add custom TM processing
# define packet parser and event frame processor
ppa = de.FpmPktParser(96) # SCI (0x35) packets have 96 bytes by default (plus the interface byte)
ppr = de.FpmProcessor()
decon.start_receiver(pkt_parser_func=ppa, procfunc=ppr)
# get the frames from the processed data list and view them
fv = fputils.FrameViewer(de.filter_frames(decon.proc_data, empty_frames=False))
fv.show(cmap='inferno', interpolation='none')
# custom TM processing function; must take bytestring as arg *data*, and timestamp kwarg *ts*
def msg_to_hex_string(data, ts=''):
try:
return '{}: {}\n'.format(ts, data.hex(' ', 1))
except Exception as err:
print(err)
return '# ERROR #\n'
# this logs the received data hex-formatted in outfile
decon.start_receiver(procfunc=msg_to_hex_string, outfile='/path/to/de_rx.log', ofmode='w')
# processed data is also collected in
decon.receiver.proc_data