449 frh = frag.get_header()
453 pulser_arr = np.empty(n_frames)
454 calibration_arr = np.empty(n_frames)
455 ready_arr = np.empty(n_frames)
456 context_arr = np.empty(n_frames)
457 wib_sync_arr = np.empty(n_frames)
458 femb_sync_arr = np.empty(n_frames)
459 cd_arr = np.empty(n_frames)
460 crc_err_arr = np.empty(n_frames)
461 link_valid_arr = np.empty(n_frames)
462 lol_arr = np.empty(n_frames)
463 colddata_ts0_arr = np.empty(n_frames)
464 colddata_ts1_arr = np.empty(n_frames)
466 for i
in range(n_frames):
469 pulser_arr[i] = wh.pulser
470 calibration_arr[i] = wh.calibration
471 ready_arr[i] = wh.ready
472 context_arr[i] = wh.context
474 wib_sync_arr[i] = wh.wib_sync
475 femb_sync_arr[i] = wh.femb_sync
478 crc_err_arr[i] = wh.crc_err
479 link_valid_arr[i] = wh.link_valid
482 colddata_ts0_arr[i] = wh.colddata_timestamp_0
483 colddata_ts1_arr[i] = wh.colddata_timestamp_1
498 colddata_ts0_diff = np.diff(colddata_ts0_arr)
499 colddata_ts0_diff[colddata_ts0_diff<0] = colddata_ts0_diff[colddata_ts0_diff<0]+0x8000
502 colddata_ts1_diff = np.diff(colddata_ts1_arr)
503 colddata_ts1_diff[colddata_ts1_diff<0] = colddata_ts1_diff[colddata_ts1_diff<0]+0x8000
506 ts_arr = self.
unpacker.np_array_timestamp(frag)
509 wh = self.
frame_obj(frag.get_data()).get_wibheader()
510 ts_diff_vals, ts_diff_counts = np.unique(np.diff(self.
unpacker.np_array_timestamp(frag)),return_counts=
True)
512 trigger=frh.trigger_number,
513 sequence=frh.sequence_number,
514 src_id=frh.element_id.id,
515 femb_id=(wh.channel>>1)&0x3,
516 colddata_id=wh.channel&0x1,
518 pulser_vals=pulser_change_val, pulser_idx=pulser_change_idx,
519 calibration_vals=calibration_change_val, calibration_idx=calibration_change_idx,
520 ready_vals=ready_change_val, ready_idx=ready_change_idx,
521 context_vals=context_change_val, context_idx=context_change_idx,
522 wib_sync_vals=wib_sync_change_val, wib_sync_idx=wib_sync_change_idx,
523 femb_sync_vals=femb_sync_change_val, femb_sync_idx=femb_sync_change_idx,
524 cd_vals=cd_change_val, cd_idx=cd_change_idx,
525 crc_err_vals=crc_err_change_val, crc_err_idx=crc_err_change_idx,
526 link_valid_vals=link_valid_change_val, link_valid_idx=link_valid_change_idx,
527 lol_vals=lol_change_val, lol_idx=lol_change_idx,
528 colddata_timestamp_0_diff_vals=colddata_ts0_diff_change_val,
529 colddata_timestamp_0_diff_idx=colddata_ts0_diff_change_idx,
530 colddata_timestamp_0_first=colddata_ts0_arr[0],
531 colddata_timestamp_1_diff_vals=colddata_ts1_diff_change_val,
532 colddata_timestamp_1_diff_idx=colddata_ts1_diff_change_idx,
533 colddata_timestamp_1_first=colddata_ts1_arr[0],
534 timestamp_dts_diff_vals=ts_diff_change_val, timestamp_dts_diff_idx=ts_diff_change_idx,
535 timestamp_dts_first=ts_arr[0],
541 frh = frag.get_header()
542 trigger_number = frh.trigger_number
549 if not (get_ana_data
or get_wvfm_data):
555 adcs = self.
unpacker.np_array_adc(frag)
557 channels = [ self.
channel_map.get_offline_channel_from_det_crate_slot_stream_chan(det, crate, slot, stream, c)
for c
in range(self.
N_CHANNELS_PER_FRAME) ]
558 planes = [ self.
channel_map.get_plane_from_offline_channel(uc)
for uc
in channels ]
559 elements = [ self.
channel_map.get_element_id_from_offline_channel(uc)
for uc
in channels ]
563 adc_mean = np.mean(adcs,axis=0)
564 adc_rms = np.std(adcs,axis=0)
565 adc_max = np.max(adcs,axis=0)
566 adc_min = np.min(adcs,axis=0)
567 adc_median = np.median(adcs,axis=0)
569 trigger=frh.trigger_number,
570 sequence=frh.sequence_number,
571 src_id=frh.element_id.id,
572 channel=channels[i_ch],
574 element=elements[i_ch],
575 wib_chan=wib_chans[i_ch],
576 adc_mean=adc_mean[i_ch],
577 adc_rms=adc_rms[i_ch],
578 adc_max=adc_max[i_ch],
579 adc_min=adc_min[i_ch],
582 timestamps = self.
unpacker.np_array_timestamp(frag)
583 ffts = np.abs(np.fft.rfft(adcs,axis=0))
585 trigger=frh.trigger_number,
586 sequence=frh.sequence_number,
587 src_id=frh.element_id.id,
588 channel=channels[i_ch],
590 element=elements[i_ch],
591 wib_chan=wib_chans[i_ch],
592 timestamps=timestamps,
596 return ana_data, wvfm_data