PICOcode.AnalysisModules package

Subpackages

Submodules

PICOcode.AnalysisModules.pico40l_cuts module

apply_common_cuts(run_type_fractions=None, cut_dict={'AP:alpha:gt': 18.17414536944306, 'AP:bulk:gt': 0, 'AP:neutron:lt': 18.17414536944306, 'R2:bulk:ge': 0, 'R2:bulk:le': 19321, 'R2:wall:ge': 19321, 'Z:bulk:ge': -400, 'Z:bulk:le': 0, 'Z:wall:ge': -400, 'Z:wall:le': 0, 'abs(PT4-pset):bulk:le': 1, 'abs(piezo_t0_v1_global-dytran_t0):bulk:lt': 0.02, 'dytranC:single:lt': 1.2, 'dytran_aprime:multiples:ge': [0.0727, 0.078], 'dytran_aprime:singles:ge': [0.02, 0.02], 'dytran_aprime:singles:le': [0.0727, 0.078], 'dytran_combo_sum_param:bulk:gt': 0, 'dytran_cprime:bulk:ge': [-0.0013, 0.0018], 'dytran_cprime:singles:le': [-0.00077, 0.0027], 'dytran_cprime:wall:le': [-0.0013, 0.0018], 'piezo_t0_v1_global:bulk:gt': -999, 'pset:bulk:eq': 30, 'run_type:alpha:eq': [99], 'run_type:neutron:eq': [91, 95], 'te:bulk:ge': 5, 'trigger_camera:bulk:ge': 4, 'trigger_mask:bulk:eq': 12, 'trigger_plc:pressure:eq': 16, 'trigger_route:bulk:eq': 'trigger_camera'}, recon_path='master', recon=None, include_multis=False, random=False, other_cuts=None, verbose=False, debug=False)

Cut on a recon file, and return a numpy cut for the events which pass the cuts.

By default, this applies cuts to return bulk events.

Parameters:
run_type_fractions: dict(int: int) or None, default=None

None, or a dictionary with keys that are run types, and values that are either: - between 0 and 1, inclusive: fraction of all events passing cuts

which are returned in the cut array.

  • Greater than 1: return up to the value’s number of events which pass cuts.

If random is False, then the first N values are returned. If run_type_fractions is None, make no cuts on run types.

cut_dict: dict(str: (int, float, list)),

default=cuts (defined in file)

Cuts to apply. Must have the same keys as the cuts dictionary above.

recon_path: str

Path to the recon file.

recon: None or PICOcode.ReconFile

Recon file on which to apply cuts. If None, read the file at recon_path and apply cuts to it. Useful if a recon file has been modified prior to applying cuts.

include_multis: bool, default=False

Whether to include multi-bubble events in the returned cut array.

random: bool, default=False

Whether to randomize the results. If True and the run_type_fraction of each run_type is less than 1 (or less than the number of events passing cuts), then the returned array has a random sample of events passing cuts.

other_cuts: array of bool or None, default=None

Other cuts to apply to the recon data. Useful when using random=True, otherwise identical to using get_bulk_events(…) & other_cuts. If None, then does not apply additional cuts.

verbose: bool, default=False

Print the number of events passing cuts before returning.

debug: bool, default=False

Print the number of events passing after each cut. Note the numbers printed are with all previous cuts applied as well, so each step will have the same or fewer events.

Returns:
np.ndarray

An array which contains True on events passing cuts (up to the fraction or number of events specified in run_type_fractions).

Notes

The returned array may be used in conjunction with other cuts, e.g. >>> cut = get_bulk_events() & (recon.AP < cuts[“AP_neutron_lt”])

If include_multis is True, the returned array only includes the first entry in the recon file for that event, since the cut on ibub==1 is still made. This is intentional to avoid double-counting of multi-bubble events.

get_bulk_events(run_type_fractions=None, cut_dict={'AP:alpha:gt': 18.17414536944306, 'AP:bulk:gt': 0, 'AP:neutron:lt': 18.17414536944306, 'R2:bulk:ge': 0, 'R2:bulk:le': 19321, 'R2:wall:ge': 19321, 'Z:bulk:ge': -400, 'Z:bulk:le': 0, 'Z:wall:ge': -400, 'Z:wall:le': 0, 'abs(PT4-pset):bulk:le': 1, 'abs(piezo_t0_v1_global-dytran_t0):bulk:lt': 0.02, 'dytranC:single:lt': 1.2, 'dytran_aprime:multiples:ge': [0.0727, 0.078], 'dytran_aprime:singles:ge': [0.02, 0.02], 'dytran_aprime:singles:le': [0.0727, 0.078], 'dytran_combo_sum_param:bulk:gt': 0, 'dytran_cprime:bulk:ge': [-0.0013, 0.0018], 'dytran_cprime:singles:le': [-0.00077, 0.0027], 'dytran_cprime:wall:le': [-0.0013, 0.0018], 'piezo_t0_v1_global:bulk:gt': -999, 'pset:bulk:eq': 30, 'run_type:alpha:eq': [99], 'run_type:neutron:eq': [91, 95], 'te:bulk:ge': 5, 'trigger_camera:bulk:ge': 4, 'trigger_mask:bulk:eq': 12, 'trigger_plc:pressure:eq': 16, 'trigger_route:bulk:eq': 'trigger_camera'}, recon_path='master', recon=None, include_multis=False, random=False, other_cuts=None, verbose=False, debug=False)
get_multiples_events(run_type_fractions=None, cut_dict={'AP:alpha:gt': 18.17414536944306, 'AP:bulk:gt': 0, 'AP:neutron:lt': 18.17414536944306, 'R2:bulk:ge': 0, 'R2:bulk:le': 19321, 'R2:wall:ge': 19321, 'Z:bulk:ge': -400, 'Z:bulk:le': 0, 'Z:wall:ge': -400, 'Z:wall:le': 0, 'abs(PT4-pset):bulk:le': 1, 'abs(piezo_t0_v1_global-dytran_t0):bulk:lt': 0.02, 'dytranC:single:lt': 1.2, 'dytran_aprime:multiples:ge': [0.0727, 0.078], 'dytran_aprime:singles:ge': [0.02, 0.02], 'dytran_aprime:singles:le': [0.0727, 0.078], 'dytran_combo_sum_param:bulk:gt': 0, 'dytran_cprime:bulk:ge': [-0.0013, 0.0018], 'dytran_cprime:singles:le': [-0.00077, 0.0027], 'dytran_cprime:wall:le': [-0.0013, 0.0018], 'piezo_t0_v1_global:bulk:gt': -999, 'pset:bulk:eq': 30, 'run_type:alpha:eq': [99], 'run_type:neutron:eq': [91, 95], 'te:bulk:ge': 5, 'trigger_camera:bulk:ge': 4, 'trigger_mask:bulk:eq': 12, 'trigger_plc:pressure:eq': 16, 'trigger_route:bulk:eq': 'trigger_camera'}, recon_path='master', recon=None, random=False, other_cuts=None, verbose=False, debug=False)
get_singles_events(run_type_fractions=None, cut_dict={'AP:alpha:gt': 18.17414536944306, 'AP:bulk:gt': 0, 'AP:neutron:lt': 18.17414536944306, 'R2:bulk:ge': 0, 'R2:bulk:le': 19321, 'R2:wall:ge': 19321, 'Z:bulk:ge': -400, 'Z:bulk:le': 0, 'Z:wall:ge': -400, 'Z:wall:le': 0, 'abs(PT4-pset):bulk:le': 1, 'abs(piezo_t0_v1_global-dytran_t0):bulk:lt': 0.02, 'dytranC:single:lt': 1.2, 'dytran_aprime:multiples:ge': [0.0727, 0.078], 'dytran_aprime:singles:ge': [0.02, 0.02], 'dytran_aprime:singles:le': [0.0727, 0.078], 'dytran_combo_sum_param:bulk:gt': 0, 'dytran_cprime:bulk:ge': [-0.0013, 0.0018], 'dytran_cprime:singles:le': [-0.00077, 0.0027], 'dytran_cprime:wall:le': [-0.0013, 0.0018], 'piezo_t0_v1_global:bulk:gt': -999, 'pset:bulk:eq': 30, 'run_type:alpha:eq': [99], 'run_type:neutron:eq': [91, 95], 'te:bulk:ge': 5, 'trigger_camera:bulk:ge': 4, 'trigger_mask:bulk:eq': 12, 'trigger_plc:pressure:eq': 16, 'trigger_route:bulk:eq': 'trigger_camera'}, recon_path='master', recon=None, random=False, other_cuts=None, verbose=False, debug=False)
get_wall_events(run_type_fractions=None, cut_dict={'AP:alpha:gt': 18.17414536944306, 'AP:bulk:gt': 0, 'AP:neutron:lt': 18.17414536944306, 'R2:bulk:ge': 0, 'R2:bulk:le': 19321, 'R2:wall:ge': 19321, 'Z:bulk:ge': -400, 'Z:bulk:le': 0, 'Z:wall:ge': -400, 'Z:wall:le': 0, 'abs(PT4-pset):bulk:le': 1, 'abs(piezo_t0_v1_global-dytran_t0):bulk:lt': 0.02, 'dytranC:single:lt': 1.2, 'dytran_aprime:multiples:ge': [0.0727, 0.078], 'dytran_aprime:singles:ge': [0.02, 0.02], 'dytran_aprime:singles:le': [0.0727, 0.078], 'dytran_combo_sum_param:bulk:gt': 0, 'dytran_cprime:bulk:ge': [-0.0013, 0.0018], 'dytran_cprime:singles:le': [-0.00077, 0.0027], 'dytran_cprime:wall:le': [-0.0013, 0.0018], 'piezo_t0_v1_global:bulk:gt': -999, 'pset:bulk:eq': 30, 'run_type:alpha:eq': [99], 'run_type:neutron:eq': [91, 95], 'te:bulk:ge': 5, 'trigger_camera:bulk:ge': 4, 'trigger_mask:bulk:eq': 12, 'trigger_plc:pressure:eq': 16, 'trigger_route:bulk:eq': 'trigger_camera'}, recon_path='master', recon=None, include_multis=False, random=False, other_cuts=None, verbose=False, debug=False)

Module contents