diff --git a/xgm.py b/xgm.py index 400ae78eda4661fdc424216a1a50e9898f026e87..506bfccc1a675609cc0f22bc5b8339732f4eef33 100644 --- a/xgm.py +++ b/xgm.py @@ -518,7 +518,7 @@ def mcpPeaks(data, intstart, intstop, bkgstart, bkgstop, mcp=1, t_offset=None, n pattern and determine the t_offset assuming mininum pulse separation of 220 ns and digitizer resolution of 2 GHz. npulses: number of pulses. If None, takes the maximum number of - pulses according to the bunch patter (field 'npulses_sase3') + pulses according to the bunch pattern (field 'npulses_sase3') Output: results: DataArray with dims trainId x max(sase3 pulses) @@ -592,7 +592,32 @@ def getTIMapd(data, mcp=1, use_apd=True, intstart=None, intstop=None, t_offset=t_offset, npulses=npulses) return tim + #1. case where number of SASE 3 pulses were not changed during the run: sa3 = data['sase3'].where(data['sase3']>1, drop=True) + sa3 -= sa3[0,0] + idx = np.unique(sa3, axis=0) + npulses_sa3 = data['npulses_sase3'] + maxpulses = int(npulses_sa3.max().values) + if npulses is not None: + maxpulses = np.min([npulses, maxpulses]) + if len(idx)==1: + if use_apd: + apd = data['MCP{}apd'.format(mcp)] + initialDelay = data.attrs['run'].get_array( + 'SCS_UTC1_ADQ/ADC/1', 'board1.apd.channel_0.initialDelay.value')[0].values + upperLimit = data.attrs['run'].get_array( + 'SCS_UTC1_ADQ/ADC/1', 'board1.apd.channel_0.upperLimit.value')[0].values + period = upperLimit - initialDelay #period of the apd in number of digitizer samples + idx /= int(period/440) #440 samples correspond to the separation between two pulses at 4.5 MHz + if len(idx)==1: + idx = idx[0].astype(int) + tim = apd.isel(apdId=idx) + return tim + else: + apd = mcpPeaks(data, intstart, intstop, bkgstart, bkgstop, mcp=mcp, + t_offset=t_offset, npulses=maxpulses) + + #2. case where the number of SASE 3 pulses varied during the run: npulses_sa3 = data['npulses_sase3'] maxpulses = int(npulses_sa3.max().values) if npulses is not None: