| 1 |  |  | # -*- coding: utf-8 -*- | 
            
                                                                                                            
                            
            
                                    
            
            
                | 2 |  |  | """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 3 |  |  | This file contains the general Qudi trace analysis logic. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 4 |  |  | Qudi is free software: you can redistribute it and/or modify | 
            
                                                                                                            
                            
            
                                    
            
            
                | 5 |  |  | it under the terms of the GNU General Public License as published by | 
            
                                                                                                            
                            
            
                                    
            
            
                | 6 |  |  | the Free Software Foundation, either version 3 of the License, or | 
            
                                                                                                            
                            
            
                                    
            
            
                | 7 |  |  | (at your option) any later version. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 8 |  |  | Qudi is distributed in the hope that it will be useful, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 9 |  |  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
            
                                                                                                            
                            
            
                                    
            
            
                | 10 |  |  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
            
                                                                                                            
                            
            
                                    
            
            
                | 11 |  |  | GNU General Public License for more details. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 12 |  |  | You should have received a copy of the GNU General Public License | 
            
                                                                                                            
                            
            
                                    
            
            
                | 13 |  |  | along with Qudi. If not, see <http://www.gnu.org/licenses/>. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 14 |  |  | Copyright (c) the Qudi Developers. See the COPYRIGHT.txt file at the | 
            
                                                                                                            
                            
            
                                    
            
            
                | 15 |  |  | top-level directory of this distribution and at <https://github.com/Ulm-IQO/qudi/> | 
            
                                                                                                            
                            
            
                                    
            
            
                | 16 |  |  | """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 17 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 18 |  |  | from qtpy import QtCore | 
            
                                                                                                            
                            
            
                                    
            
            
                | 19 |  |  | import numpy as np | 
            
                                                                                                            
                            
            
                                    
            
            
                | 20 |  |  | from scipy.signal import gaussian | 
            
                                                                                                            
                            
            
                                    
            
            
                | 21 |  |  | from scipy.ndimage import filters | 
            
                                                                                                            
                            
            
                                    
            
            
                | 22 |  |  | import scipy.integrate as integrate | 
            
                                                                                                            
                            
            
                                    
            
            
                | 23 |  |  | from scipy.interpolate import InterpolatedUnivariateSpline | 
            
                                                                                                            
                            
            
                                    
            
            
                | 24 |  |  | from collections import OrderedDict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 25 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 26 |  |  | from core.module import Connector | 
            
                                                                                                            
                            
            
                                    
            
            
                | 27 |  |  | from logic.generic_logic import GenericLogic | 
            
                                                                                                            
                            
            
                                    
            
            
                | 28 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 29 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 30 |  |  | class TraceAnalysisLogic(GenericLogic): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 31 |  |  |     """ Perform a gated counting measurement with the hardware.  """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 32 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 33 |  |  |     _modclass = 'TraceAnalysisLogic' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 34 |  |  |     _modtype = 'logic' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 35 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 36 |  |  |     # declare connectors | 
            
                                                                                                            
                            
            
                                    
            
            
                | 37 |  |  |     counterlogic1 = Connector(interface='CounterLogic') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 38 |  |  |     savelogic = Connector(interface='SaveLogic') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 39 |  |  |     fitlogic = Connector(interface='FitLogic') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 40 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 41 |  |  |     sigHistogramUpdated = QtCore.Signal() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 42 |  |  |     sigAnalysisResultsUpdated = QtCore.Signal() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 43 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 44 |  |  |     def __init__(self, config, **kwargs): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 45 |  |  |         """ Create CounterLogic object with connectors. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 46 |  |  |         @param dict config: module configuration | 
            
                                                                                                            
                            
            
                                    
            
            
                | 47 |  |  |         @param dict kwargs: optional parameters | 
            
                                                                                                            
                            
            
                                    
            
            
                | 48 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 49 |  |  |         super().__init__(config=config, **kwargs) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 50 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 51 |  |  |         self.log.debug('The following configuration was found.') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 52 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 53 |  |  |         # checking for the right configuration | 
            
                                                                                                            
                            
            
                                    
            
            
                | 54 |  |  |         for key in config.keys(): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 55 |  |  |             self.log.debug('{0}: {1}'.format(key, config[key])) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 56 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 57 |  |  |         self.hist_data = None | 
            
                                                                                                            
                            
            
                                    
            
            
                | 58 |  |  |         self._hist_num_bins = None | 
            
                                                                                                            
                            
            
                                    
            
            
                | 59 |  |  |         self.spin_flip_prob = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 60 |  |  |         self.fidelity_left = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 61 |  |  |         self.fidelity_right = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 62 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 63 |  |  |     def on_activate(self): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 64 |  |  |         """ Initialisation performed during activation of the module. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 65 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 66 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 67 |  |  |         # self._counter_logic = self.get_connector('counterlogic1') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 68 |  |  |         self._save_logic = self.get_connector('savelogic') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 69 |  |  |         self._fit_logic = self.get_connector('fitlogic') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 70 |  |  |         self.trace = np.array([]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 71 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 72 |  |  |         # self._counter_logic.sigGatedCounterFinished.connect(self.do_calculate_histogram) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 73 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 74 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 75 |  |  |         self.current_fit_function = 'No Fit' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 76 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 77 |  |  |     def on_deactivate(self): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 78 |  |  |         """ Deinitialisation performed during deactivation of the module. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 79 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 80 |  |  |         return | 
            
                                                                                                            
                            
            
                                    
            
            
                | 81 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 82 |  |  |     def set_num_bins_histogram(self, num_bins, update=True): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 83 |  |  |         """ Set the number of bins | 
            
                                                                                                            
                            
            
                                    
            
            
                | 84 |  |  |         @param int num_bins: number of bins for the histogram | 
            
                                                                                                            
                            
            
                                    
            
            
                | 85 |  |  |         @param bool update: if the change of bins should evoke a recalculation | 
            
                                                                                                            
                            
            
                                    
            
            
                | 86 |  |  |                             of the histogram. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 87 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 88 |  |  |         self._hist_num_bins = num_bins | 
            
                                                                                                            
                            
            
                                    
            
            
                | 89 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 90 |  |  |         if update: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 91 |  |  |             self.do_calculate_histogram() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 92 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 93 |  |  |     def do_calculate_histogram(self, mode='normal'): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 94 |  |  |         """ Passes all the needed parameters to the appropriated methods. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 95 |  |  |         @return: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 96 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 97 |  |  |         if mode == 'normal': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 98 |  |  |             self.hist_data = self.calculate_histogram(self._counter_logic.countdata[0], | 
            
                                                                                                            
                            
            
                                    
            
            
                | 99 |  |  |                                                       self._hist_num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 100 |  |  |         if mode == 'fastcomtec': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 101 |  |  |             self.sigHistogramUpdated.emit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 102 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 103 |  |  |     def calculate_histogram(self, trace, num_bins=None, custom_bin_arr=None): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 104 |  |  |         """ Calculate the histogram of a given trace. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 105 |  |  |         @param np.array trace: a 1D trace | 
            
                                                                                                            
                            
            
                                    
            
            
                | 106 |  |  |         @param int num_bins: number of bins between the minimal and maximal | 
            
                                                                                                            
                            
            
                                    
            
            
                | 107 |  |  |                              value of the trace. That must be an integer greater | 
            
                                                                                                            
                            
            
                                    
            
            
                | 108 |  |  |                              than or equal to 1. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 109 |  |  |         @param np.array custom_bin_arr: optional, 1D array. If a specific, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 110 |  |  |                                         non-uniform binning array is desired | 
            
                                                                                                            
                            
            
                                    
            
            
                | 111 |  |  |                                         then it can be passed to the numpy | 
            
                                                                                                            
                            
            
                                    
            
            
                | 112 |  |  |                                         routine. Then the parameter num_bins is | 
            
                                                                                                            
                            
            
                                    
            
            
                | 113 |  |  |                                         ignored. Otherwise a uniform binning is | 
            
                                                                                                            
                            
            
                                    
            
            
                | 114 |  |  |                                         applied by default. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 115 |  |  |         @return: np.array: a 2D array, where first entry are the x_values and | 
            
                                                                                                            
                            
            
                                    
            
            
                | 116 |  |  |                            second entry are the count values. The length of the | 
            
                                                                                                            
                            
            
                                    
            
            
                | 117 |  |  |                            array is normally determined by the num_bins | 
            
                                                                                                            
                            
            
                                    
            
            
                | 118 |  |  |                            parameter. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 119 |  |  |         Usually the bins for the histogram are taken to be equally spaced, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 120 |  |  |         ranging from the minimal to the maximal value of the input trace array. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 121 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 122 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 123 |  |  |         if custom_bin_arr is not None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 124 |  |  |             hist_y_val, hist_x_val = np.histogram(trace, custom_bin_arr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 125 |  |  |                                                   density=False) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 126 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 127 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 128 |  |  |             # analyze the trace, and check whether all values are the same | 
            
                                                                                                            
                            
            
                                    
            
            
                | 129 |  |  |             difference = trace.max() - trace.min() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 130 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 131 |  |  |             # if all values are the same, run at least the method with an zero | 
            
                                                                                                            
                            
            
                                    
            
            
                | 132 |  |  |             # array. That will ensure at least an output: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 133 |  |  |             if np.isclose(0, difference) and num_bins is None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 134 |  |  |                 # numpy can handle an array of zeros | 
            
                                                                                                            
                            
            
                                    
            
            
                | 135 |  |  |                 num_bins = 50 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 136 |  |  |                 hist_y_val, hist_x_val = np.histogram(trace, num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 137 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 138 |  |  |             # if no number of bins are passed, then take the integer difference | 
            
                                                                                                            
                            
            
                                    
            
            
                | 139 |  |  |             # between the counts, that will prevent strange histogram artifacts: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 140 |  |  |             elif not np.isclose(0, difference) and num_bins is None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 141 |  |  |                 hist_y_val, hist_x_val = np.histogram(trace, int(difference)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 142 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 143 |  |  |             # a histogram with self defined number of bins | 
            
                                                                                                            
                            
            
                                    
            
            
                | 144 |  |  |             else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 145 |  |  |                 hist_y_val, hist_x_val = np.histogram(trace, num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 146 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 147 |  |  |         self.hist_data = np.array([hist_x_val, hist_y_val]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 148 |  |  |         self.sigHistogramUpdated.emit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 149 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 150 |  |  |         return self.hist_data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 151 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 152 |  |  |     def analyze_flip_prob(self, trace, num_bins=None, threshold=None): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 153 |  |  |         """General method, which analysis how often a value was changed from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 154 |  |  |            one data point to another in relation to a certain threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 155 |  |  |         @param np.array trace: 1D trace of data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 156 |  |  |         @param int num_bins: optional, if a specific size for the histogram is | 
            
                                                                                                            
                            
            
                                    
            
            
                | 157 |  |  |                              desired, which is used to calculate the threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 158 |  |  |         @param float threshold: optional, if a specific threshold is going to be | 
            
                                                                                                            
                            
            
                                    
            
            
                | 159 |  |  |                                 used, otherwise the threshold is calculated from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 160 |  |  |                                 the data. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 161 |  |  |         @return tuple(flip_prop, param): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 162 |  |  |                       float flip_prop: the actual flip probability | 
            
                                                                                                            
                            
            
                                    
            
            
                | 163 |  |  |                       int num_of_flips: the total number of flips | 
            
                                                                                                            
                            
            
                                    
            
            
                | 164 |  |  |                       float fidelity: the fidelity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 165 |  |  |                       float threshold: the calculated or passed threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 166 |  |  |                       float lifetime_dark: the lifetime in the dark state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 167 |  |  |                       float lifetime_bright: lifetime in the bright state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 168 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 169 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 170 |  |  |         hist_data = self.calculate_histogram(trace=trace, num_bins=num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 171 |  |  |         threshold_fit, fidelity, fit_param = self.calculate_threshold(hist_data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 172 |  |  |         bin_trace = self.calculate_binary_trace(trace, threshold_fit) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 173 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 174 |  |  |         # here the index_arr contain all indices where the state is above | 
            
                                                                                                            
                            
            
                                    
            
            
                | 175 |  |  |         # threshold, indicating the bright state. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 176 |  |  |         index_arr, filtered_arr = self.extract_filtered_values(trace, threshold_fit, below=False) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 177 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 178 |  |  |         # by shifting the index_arr one value further, one will investigate | 
            
                                                                                                            
                            
            
                                    
            
            
                | 179 |  |  |         # basically the next state, where a change has happened. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 180 |  |  |         next_index_arr = index_arr + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 181 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 182 |  |  |         # Just for safety neglect the last value in the index_arr so that one | 
            
                                                                                                            
                            
            
                                    
            
            
                | 183 |  |  |         # will not go beyond the array. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 184 |  |  |         next_filtered_bin_arr = bin_trace[next_index_arr[:-1]] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 185 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 186 |  |  |         # calculate how many darkstates are present in the array, remember | 
            
                                                                                                            
                            
            
                                    
            
            
                | 187 |  |  |         # filtered_arr contains all the bright states. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 188 |  |  |         num_dark_state = len(trace) - len(filtered_arr) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 189 |  |  |         num_bright_state = len(filtered_arr) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 190 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 191 |  |  |         # extract the number of state, which has been flipped to dark state | 
            
                                                                                                            
                            
            
                                    
            
            
                | 192 |  |  |         # (True) started in the bright state (=False) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 193 |  |  |         num_flip_to_dark = len(np.where(next_filtered_bin_arr == True)[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 194 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 195 |  |  |         # flip probability: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 196 |  |  |         # In the array filtered_bin_arr all states are in bright state meaning | 
            
                                                                                                            
                            
            
                                    
            
            
                | 197 |  |  |         # that if you would perform for | 
            
                                                                                                            
                            
            
                                    
            
            
                | 198 |  |  |         #   filtered_bin_arr = bin_trace[index_arr] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 199 |  |  |         # the mean value with filtered_bin_arr.mean() then you should get 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 200 |  |  |         # since every entry in that array is False. By looking at the next index | 
            
                                                                                                            
                            
            
                                    
            
            
                | 201 |  |  |         # it might be that some entries turn to True, i.e. a flip from bright to | 
            
                                                                                                            
                            
            
                                    
            
            
                | 202 |  |  |         # dark occurred. Then you get a different mean value, which would | 
            
                                                                                                            
                            
            
                                    
            
            
                | 203 |  |  |         # indicate how many states are flipped from bright (False) to dark (True). | 
            
                                                                                                            
                            
            
                                    
            
            
                | 204 |  |  |         # If all the next states would be dark (True), then you would perform a | 
            
                                                                                                            
                            
            
                                    
            
            
                | 205 |  |  |         # perfect flip into the dark state, meaning a flip probability of 1. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 206 |  |  |         flip_prob = next_filtered_bin_arr.mean() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 207 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 208 |  |  |         # put all the calculated parameters in a proper dict: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 209 |  |  |         param = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 210 |  |  |         param['num_dark_state'] = num_dark_state  # Number of Dark States | 
            
                                                                                                            
                            
            
                                    
            
            
                | 211 |  |  |         param['num_bright_state'] = num_bright_state  # Number of Bright States | 
            
                                                                                                            
                            
            
                                    
            
            
                | 212 |  |  |         param['num_flip_to_dark'] = num_flip_to_dark  # Number of flips from bright to dark | 
            
                                                                                                            
                            
            
                                    
            
            
                | 213 |  |  |         param['fidelity'] = fidelity  # Fidelity of Double Poissonian Fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 214 |  |  |         param['threshold'] = threshold_fit  # Threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 215 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 216 |  |  |         # add the fit parameter to the output parameter: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 217 |  |  |         param.update(fit_param) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 218 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 219 |  |  |         return flip_prob, param | 
            
                                                                                                            
                            
            
                                    
            
            
                | 220 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 221 |  |  |     def analyze_flip_prob2(self, trace, threshold=1, analyze_mode='full'): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 222 |  |  |         """General method, which analysis how often a value was changed from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 223 |  |  |            one data point to another in relation to a certain threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 224 |  |  |         @param np.array trace: 1D trace of data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 225 |  |  |         @param int num_bins: optional, if a specific size for the histogram is | 
            
                                                                                                            
                            
            
                                    
            
            
                | 226 |  |  |                              desired, which is used to calculate the threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 227 |  |  |         @param float threshold: optional, if a specific threshold is going to be | 
            
                                                                                                            
                            
            
                                    
            
            
                | 228 |  |  |                                 used, otherwise the threshold is calculated from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 229 |  |  |                                 the data. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 230 |  |  |         @return tuple(flip_prop, param): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 231 |  |  |                       float flip_prop: the actual flip probability | 
            
                                                                                                            
                            
            
                                    
            
            
                | 232 |  |  |                       int num_of_flips: the total number of flips | 
            
                                                                                                            
                            
            
                                    
            
            
                | 233 |  |  |                       float fidelity: the fidelity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 234 |  |  |                       float threshold: the calculated or passed threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 235 |  |  |                       float lifetime_dark: the lifetime in the dark state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 236 |  |  |                       float lifetime_bright: lifetime in the bright state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 237 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 238 |  |  |         no_flip = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 239 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 240 |  |  |         if analyze_mode == 'full': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 241 |  |  |             for ii in range(len(trace) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 242 |  |  |                 if trace[ii] > threshold and trace[ii + 1] > threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 243 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 244 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 245 |  |  |                 elif trace[ii] < threshold and trace[ii + 1] < threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 246 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 247 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 248 |  |  |             probability = 1.0 - (no_flip / len(trace)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 249 |  |  |             lost_events = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 250 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 251 |  |  |         if analyze_mode == 'dark': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 252 |  |  |             dark_counter = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 253 |  |  |             for ii in range(len(trace) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 254 |  |  |                 if trace[ii] < threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 255 |  |  |                     dark_counter = dark_counter + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 256 |  |  |                     if trace[ii + 1] < threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 257 |  |  |                         no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 258 |  |  |             probability = 1.0 - (no_flip / dark_counter) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 259 |  |  |             lost_events = (1.0 - (dark_counter / len(trace))) * 100 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 260 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 261 |  |  |         if analyze_mode == 'bright': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 262 |  |  |             bright_counter = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 263 |  |  |             for ii in range(len(trace) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 264 |  |  |                 if trace[ii] > threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 265 |  |  |                     bright_counter = bright_counter + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 266 |  |  |                     if trace[ii + 1] > threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 267 |  |  |                         no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 268 |  |  |             probability = 1.0 - (no_flip / bright_counter) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 269 |  |  |             lost_events = (1.0 - (bright_counter / len(trace))) * 100 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 270 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 271 |  |  |         return probability, lost_events | 
            
                                                                                                            
                            
            
                                    
            
            
                | 272 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 273 |  |  |     def analyze_flip_prob3(self, trace, init_threshold=[1, 1], ana_threshold=[1, 1], analyze_mode='full'): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 274 |  |  |         """General method, which analysis how often a value was changed from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 275 |  |  |            one data point to another in relation to a certain threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 276 |  |  |         @param np.array trace: 1D trace of data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 277 |  |  |         @param float threshold: optional, if a specific threshold is going to be | 
            
                                                                                                            
                            
            
                                    
            
            
                | 278 |  |  |                                 used, otherwise the threshold is calculated from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 279 |  |  |                                 the data. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 280 |  |  |         @return tuple(flip_prop, param): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 281 |  |  |                       float flip_prop: the actual flip probability | 
            
                                                                                                            
                            
            
                                    
            
            
                | 282 |  |  |                       int num_of_flips: the total number of flips | 
            
                                                                                                            
                            
            
                                    
            
            
                | 283 |  |  |                       float fidelity: the fidelity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 284 |  |  |                       float threshold: the calculated or passed threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 285 |  |  |                       float lifetime_dark: the lifetime in the dark state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 286 |  |  |                       float lifetime_bright: lifetime in the bright state in s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 287 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 288 |  |  |         no_flip = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 289 |  |  |         flip = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 290 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 291 |  |  |         # find all indices in the trace-array, where the value is above init_threshold[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 292 |  |  |         init_high = np.where(trace[:-1] > init_threshold[1])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 293 |  |  |         # find all indices in the trace-array, where the value is below init_threshold[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 294 |  |  |         init_low = np.where(trace[:-1] < init_threshold[0])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 295 |  |  |         # find all indices in the trace-array, where the value is above ana_threshold[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 296 |  |  |         ana_high = np.where(trace > ana_threshold[1])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 297 |  |  |         # find all indices in the trace-array, where the value is below ana_threshold[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 298 |  |  |         ana_low = np.where(trace < ana_threshold[0])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 299 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 300 |  |  |         if analyze_mode == 'bright' or analyze_mode == 'full': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 301 |  |  |             # analyze the trace where the data were the nuclear was initalized into one direction | 
            
                                                                                                            
                            
            
                                    
            
            
                | 302 |  |  |             for index in init_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 303 |  |  |                 # check if the following data point is in the analysis array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 304 |  |  |                 if index + 1 in ana_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 305 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 306 |  |  |                 elif index + 1 in ana_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 307 |  |  |                     flip = flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 308 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 309 |  |  |         if analyze_mode == 'dark' or analyze_mode == 'full': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 310 |  |  |             # repeat the same if the nucleus was initalized into the other array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 311 |  |  |             for index in init_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 312 |  |  |                 # check if the following data point is in the analysis array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 313 |  |  |                 if index + 1 in ana_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 314 |  |  |                     flip = flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 315 |  |  |                 elif index + 1 in ana_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 316 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 317 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 318 |  |  |         # the flip probability is given by the number of flips divided by the total number of analyzed data points | 
            
                                                                                                            
                            
            
                                    
            
            
                | 319 |  |  |         if (flip + no_flip) == 0: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 320 |  |  |             self.log.error('There is not enough data to anaylsis SSR!') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 321 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 322 |  |  |             probability = flip / (flip + no_flip) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 323 |  |  |         # the number of lost events is given by the length of the time_trace minus the number of analyzed data points | 
            
                                                                                                            
                            
            
                                    
            
            
                | 324 |  |  |         lost_events = len(trace) - (flip + no_flip) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 325 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 326 |  |  |         return probability, lost_events | 
            
                                                                                                            
                            
            
                                    
            
            
                | 327 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 328 |  |  |     def analyze_flip_prob4(self, trace, bins=30, init_threshold = [1,1], ana_threshold = [1,1], analyze_mode='full'): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 329 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 330 |  |  |         Method which calculates the histogram, the fidelity and the flip probability of a time trace. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 331 |  |  |         :param trace: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 332 |  |  |         :param bins: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 333 |  |  |         :param init_margin: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 334 |  |  |         :param ana_margin: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 335 |  |  |         :param analyze_mode: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 336 |  |  |         :return: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 337 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 338 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 339 |  |  |         self.calculate_histogram(trace, bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 340 |  |  |         axis = self.hist_data[0][:-1] + (self.hist_data[0][1] - self.hist_data[0][0]) / 2. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 341 |  |  |         data = self.hist_data[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 342 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 343 |  |  |         try: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 344 |  |  |             hist_fit_x, hist_fit_y, param_dict, fit_result = self.do_doublegaussian_fit(axis, data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 345 |  |  |             fit_params = fit_result.best_values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 346 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 347 |  |  |             # calculate the fidelity for the left and right part from the threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 348 |  |  |             center1 = fit_params['g0_center'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 349 |  |  |             center2 = fit_params['g1_center'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 350 |  |  |             std1 = fit_params['g0_sigma'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 351 |  |  |             std2 = fit_params['g1_sigma'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 352 |  |  |             gaussian1 = lambda x: fit_params['g0_amplitude'] * np.exp(-(x - center1) ** 2 / (2 * std1 ** 2)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 353 |  |  |             gaussian2 = lambda x: fit_params['g1_amplitude'] * np.exp(-(x - center2) ** 2 / (2 * std2 ** 2)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 354 |  |  |             if center1 > center2: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 355 |  |  |                 gaussian = gaussian1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 356 |  |  |                 gaussian1 = gaussian2 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 357 |  |  |                 gaussian2 = gaussian | 
            
                                                                                                            
                            
            
                                    
            
            
                | 358 |  |  |             area_left1 = integrate.quad(gaussian1, -np.inf, init_threshold[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 359 |  |  |             area_left2 = integrate.quad(gaussian2, -np.inf, init_threshold[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 360 |  |  |             area_right1 = integrate.quad(gaussian1, init_threshold[1], np.inf) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 361 |  |  |             area_right2 = integrate.quad(gaussian2, init_threshold[1], np.inf) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 362 |  |  |             self.fidelity_left = area_left1[0] / (area_left1[0] + area_left2[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 363 |  |  |             self.fidelity_right = area_right2[0] / (area_right1[0] + area_right2[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 364 |  |  |         except: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 365 |  |  |             self.log.warning('Not enough data points yet!') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 366 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 367 |  |  |         # calculate the flip probability | 
            
                                                                                                            
                            
            
                                    
            
            
                | 368 |  |  |         no_flip = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 369 |  |  |         flip = 0.0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 370 |  |  |         # find all indices in the trace-array, where the value is above init_threshold[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 371 |  |  |         init_high = np.where(trace[:-1] > init_threshold[1])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 372 |  |  |         # find all indices in the trace-array, where the value is below init_threshold[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 373 |  |  |         init_low = np.where(trace[:-1] < init_threshold[0])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 374 |  |  |         # find all indices in the trace-array, where the value is above ana_threshold[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 375 |  |  |         ana_high = np.where(trace > ana_threshold[1])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 376 |  |  |         # find all indices in the trace-array, where the value is below ana_threshold[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 377 |  |  |         ana_low = np.where(trace < ana_threshold[0])[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 378 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 379 |  |  |         if analyze_mode == 'bright' or analyze_mode == 'full': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 380 |  |  |             # analyze the trace where the data were the nuclear was initalized into one direction | 
            
                                                                                                            
                            
            
                                    
            
            
                | 381 |  |  |             for index in init_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 382 |  |  |                 # check if the following data point is in the analysis array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 383 |  |  |                 if index + 1 in ana_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 384 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 385 |  |  |                 elif index + 1 in ana_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 386 |  |  |                     flip = flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 387 |  |  |         if analyze_mode == 'dark' or analyze_mode == 'full': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 388 |  |  |             # repeat the same if the nucleus was initalized into the other array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 389 |  |  |             for index in init_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 390 |  |  |                 # check if the following data point is in the analysis array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 391 |  |  |                 if index + 1 in ana_high: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 392 |  |  |                     flip = flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 393 |  |  |                 elif index + 1 in ana_low: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 394 |  |  |                     no_flip = no_flip + 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 395 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 396 |  |  |         # the flip probability is given by the number of flips divided by the total number of analyzed data points | 
            
                                                                                                            
                            
            
                                    
            
            
                | 397 |  |  |         if (flip + no_flip) == 0: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 398 |  |  |             self.log.error('There is not enough data to anaylsis SSR!') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 399 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 400 |  |  |             self.spin_flip_prob = flip / (flip + no_flip) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 401 |  |  |         # the number of lost events is given by the length of the time_trace minus the number of analyzed data points | 
            
                                                                                                            
                            
            
                                    
            
            
                | 402 |  |  |         lost_events = len(trace) - (flip + no_flip) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 403 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 404 |  |  |         results_dict = dict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 405 |  |  |         results_dict['fidelity_left'] = self.fidelity_left | 
            
                                                                                                            
                            
            
                                    
            
            
                | 406 |  |  |         results_dict['fidelity_right'] = self.fidelity_right | 
            
                                                                                                            
                            
            
                                    
            
            
                | 407 |  |  |         results_dict['flip_prob'] = self.spin_flip_prob | 
            
                                                                                                            
                            
            
                                    
            
            
                | 408 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 409 |  |  |         self.sigAnalysisResultsUpdated.emit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 410 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 411 |  |  |         return self.spin_flip_prob, lost_events, hist_fit_x, hist_fit_y, fit_result | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 412 |  |  |  | 
            
                                                                        
                            
            
                                    
            
            
                | 413 |  |  |     def analyze_flip_prob_postselect(self): | 
            
                                                                        
                            
            
                                    
            
            
                | 414 |  |  |         """ Post select the data trace so that the flip probability is only | 
            
                                                                        
                            
            
                                    
            
            
                | 415 |  |  |             calculated from a jump from below a threshold value to an value | 
            
                                                                        
                            
            
                                    
            
            
                | 416 |  |  |             above threshold. | 
            
                                                                        
                            
            
                                    
            
            
                | 417 |  |  |         @return: | 
            
                                                                        
                            
            
                                    
            
            
                | 418 |  |  |         """ | 
            
                                                                        
                            
            
                                    
            
            
                | 419 |  |  |         pass | 
            
                                                                                                            
                            
            
                                    
            
            
                | 420 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 421 |  |  |     def get_fit_functions(self): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 422 |  |  |         """ Return all fit functions, which are currently implemented for that module. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 423 |  |  |         @return list: with string entries denoting the name of the fit. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 424 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 425 |  |  |         return ['No Fit', 'Gaussian', 'Double Gaussian', 'Poisson', | 
            
                                                                                                            
                            
            
                                    
            
            
                | 426 |  |  |                 'Double Poisson'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 427 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 428 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 429 |  |  |     def do_fit(self, fit_function=None): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 430 |  |  |         """ Makes the a fit of the current fit function. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 431 |  |  |         @param str fit_function: name of the chosen fit function. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 432 |  |  |         @return tuple(x_val, y_val, fit_results): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 433 |  |  |                     x_val: a 1D numpy array containing the x values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 434 |  |  |                     y_val: a 1D numpy array containing the y values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 435 |  |  |                     fit_results: a string containing the information of the fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 436 |  |  |                                  results. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 437 |  |  |         You can obtain with get_fit_methods all implemented fit methods. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 438 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 439 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 440 |  |  |         if self.hist_data is None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 441 |  |  |             hist_fit_x = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 442 |  |  |             hist_fit_y = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 443 |  |  |             param_dict = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 444 |  |  |             fit_result = None | 
            
                                                                                                            
                            
            
                                    
            
            
                | 445 |  |  |             return hist_fit_x, hist_fit_y, param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 446 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 447 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 448 |  |  |             # self.log.debug((self.calculate_threshold(self.hist_data))) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 449 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 450 |  |  |             # shift x axis to middle of bin | 
            
                                                                                                            
                            
            
                                    
            
            
                | 451 |  |  |             axis = self.hist_data[0][:-1] + (self.hist_data[0][1] - self.hist_data[0][0]) / 2. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 452 |  |  |             data = self.hist_data[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 453 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 454 |  |  |             if fit_function == 'No Fit': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 455 |  |  |                 hist_fit_x, hist_fit_y, fit_param_dict, fit_result = self.do_no_fit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 456 |  |  |                 return hist_fit_x, hist_fit_y, fit_param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 457 |  |  |             elif fit_function == 'Gaussian': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 458 |  |  |                 hist_fit_x, hist_fit_y, fit_param_dict, fit_result = self.do_gaussian_fit(axis, data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 459 |  |  |                 return hist_fit_x, hist_fit_y, fit_param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 460 |  |  |             elif fit_function == 'Double Gaussian': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 461 |  |  |                 hist_fit_x, hist_fit_y, fit_param_dict, fit_result = self.do_doublegaussian_fit(axis, data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 462 |  |  |                 return hist_fit_x, hist_fit_y, fit_param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 463 |  |  |             elif fit_function == 'Poisson': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 464 |  |  |                 hist_fit_x, hist_fit_y, fit_param_dict, fit_result = self.do_possonian_fit(axis, data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 465 |  |  |                 return hist_fit_x, hist_fit_y, fit_param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 466 |  |  |             elif fit_function == 'Double Poisson': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 467 |  |  |                 hist_fit_x, hist_fit_y, fit_param_dict, fit_result = self.do_doublepossonian_fit(axis, data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 468 |  |  |                 return hist_fit_x, hist_fit_y, fit_param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 469 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 470 |  |  |     def do_no_fit(self): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 471 |  |  |         """ Perform no fit, basically return an empty array. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 472 |  |  |         @return tuple(x_val, y_val, fit_results): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 473 |  |  |                     x_val: a 1D numpy array containing the x values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 474 |  |  |                     y_val: a 1D numpy array containing the y values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 475 |  |  |                     fit_results: a string containing the information of the fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 476 |  |  |                                  results. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 477 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 478 |  |  |         hist_fit_x = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 479 |  |  |         hist_fit_y = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 480 |  |  |         param_dict = {} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 481 |  |  |         fit_result = None | 
            
                                                                                                            
                            
            
                                    
            
            
                | 482 |  |  |         return hist_fit_x, hist_fit_y, param_dict, fit_result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 483 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 484 |  |  |     def analyze_lifetime(self, trace, dt, method='postselect', | 
            
                                                                                                            
                            
            
                                    
            
            
                | 485 |  |  |                          distr='gaussian_normalized', state='|-1>', num_bins=50): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 486 |  |  |         """ Perform an lifetime analysis of a 1D time trace. The analysis is | 
            
                                                                                                            
                            
            
                                    
            
            
                | 487 |  |  |             based on the method provided ( for now only post select is implemented ). | 
            
                                                                                                            
                            
            
                                    
            
            
                | 488 |  |  |         @param numpy array trace: 1 D array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 489 |  |  |         @param string method: The method used for the lifetime analysis | 
            
                                                                                                            
                            
            
                                    
            
            
                | 490 |  |  |         @param string distr: distribution used for analysis | 
            
                                                                                                            
                            
            
                                    
            
            
                | 491 |  |  |         @param string state: State that the mw was applied to | 
            
                                                                                                            
                            
            
                                    
            
            
                | 492 |  |  |         @param int num_bins: number of bins used in the histogram to determine the threshold before digitalisation | 
            
                                                                                                            
                            
            
                                    
            
            
                | 493 |  |  |                              of data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 494 |  |  |         @return: dictionary containing the lifetimes of the different states |0>, |1>, |-1> in the case of the HMM method | 
            
                                                                                                            
                            
            
                                    
            
            
                | 495 |  |  |                  For the postselect method only lifetime for bright and darkstate is returned, keys are 'bright_state' and | 
            
                                                                                                            
                            
            
                                    
            
            
                | 496 |  |  |                  'dark_state' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 497 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 498 |  |  |         lifetime_dict = {} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 499 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 500 |  |  |         if method == 'postselect': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 501 |  |  |             if distr == 'gaussian_normalized': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 502 |  |  |                 hist_y_val, hist_x_val = np.histogram(trace, num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 503 |  |  |                 hist_data = np.array([hist_x_val, hist_y_val]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 504 |  |  |                 threshold_fit, fidelity, param_dict = self.calculate_threshold(hist_data=hist_data, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 505 |  |  |                                                                                distr='gaussian_normalized') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 506 |  |  |                 threshold = threshold_fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 507 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 508 |  |  |             # helper functions to get and analyze the timetrace | 
            
                                                                                                            
                            
            
                                    
            
            
                | 509 |  |  |             def analog_digitial_converter(cut_off, data): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 510 |  |  |                 digital_trace = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 511 |  |  |                 for data_point in data: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 512 |  |  |                     if data_point >= cut_off: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 513 |  |  |                         digital_trace.append(1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 514 |  |  |                     else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 515 |  |  |                         digital_trace.append(0) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 516 |  |  |                 return digital_trace | 
            
                                                                                                            
                            
            
                                    
            
            
                | 517 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 518 |  |  |             def time_in_high_low(digital_trace, dt): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 519 |  |  |                 """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 520 |  |  |                 What I need this function to do is to get all consecutive {1, ... , n} 1s or 0s and add | 
            
                                                                                                            
                            
            
                                    
            
            
                | 521 |  |  |                 them up and put into a list to later make a histogram from them. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 522 |  |  |                 """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 523 |  |  |                 occurances = [] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 524 |  |  |                 index = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 525 |  |  |                 index2 = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 526 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 527 |  |  |                 while (index < len(digital_trace)): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 528 |  |  |                     occurances.append(0) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 529 |  |  |                     # start following the consecutive 1s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 530 |  |  |                     while (digital_trace[index] == 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 531 |  |  |                         occurances[index2] += 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 532 |  |  |                         if index == (len(digital_trace) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 533 |  |  |                             occurances = np.array(occurances) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 534 |  |  |                             return occurances * dt | 
            
                                                                                                            
                            
            
                                    
            
            
                | 535 |  |  |                         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 536 |  |  |                             index += 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 537 |  |  |                     if digital_trace[index - 1] == 1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 538 |  |  |                         index2 += 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 539 |  |  |                         occurances.append(0) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 540 |  |  |                     # start following the consecutive 0s | 
            
                                                                                                            
                            
            
                                    
            
            
                | 541 |  |  |                     while (digital_trace[index] == 0): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 542 |  |  |                         occurances[index2] -= 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 543 |  |  |                         if index == (len(digital_trace) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 544 |  |  |                             occurances = np.array(occurances) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 545 |  |  |                             return occurances * dt | 
            
                                                                                                            
                            
            
                                    
            
            
                | 546 |  |  |                         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 547 |  |  |                             index += 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 548 |  |  |                     index2 += 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 549 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 550 |  |  |             digital_trace = analog_digitial_converter(threshold, trace) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 551 |  |  |             time_array = time_in_high_low(digital_trace, dt) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 552 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 553 |  |  |             # now we need to make a histogram as well as a fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 554 |  |  |             # what would be a good estimate for the number of bins | 
            
                                                                                                            
                            
            
                                    
            
            
                | 555 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 556 |  |  |             # longest = np.max(np.array(occurances)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 557 |  |  |             # number of steps in between, rather not use that for now | 
            
                                                                                                            
                            
            
                                    
            
            
                | 558 |  |  |             # est_bins = np.int(longest/dt) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 559 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 560 |  |  |             time_array_high = np.array([ii for ii in filter(lambda x: x > 0, time_array)]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 561 |  |  |             time_array_low = np.array([ii for ii in filter(lambda x: x < 0, time_array)]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 562 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 563 |  |  |             # get lifetime of bright state | 
            
                                                                                                            
                            
            
                                    
            
            
                | 564 |  |  |             time_hist_high = np.histogram(time_array_high, bins=num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 565 |  |  |             vals = [i for i in filter(lambda x: x[1] > 0, enumerate(time_hist_high[0][0:num_bins]))] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 566 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 567 |  |  |             indices = np.array([val[0] for val in vals]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 568 |  |  |             indices = np.array([np.int(indice) for indice in indices]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 569 |  |  |             self.log.debug('threshold {0}'.format(threshold)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 570 |  |  |             self.log.debug('time_array:{0}'.format(time_array)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 571 |  |  |             self.log.debug('time_array_high:{0}'.format(time_array_high)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 572 |  |  |             self.log.debug('time_hist_high:{0}'.format(time_hist_high)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 573 |  |  |             self.log.debug('indices: {0}'.format(indices)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 574 |  |  |             self.debug_lifetime_x = time_hist_high[1][indices] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 575 |  |  |             self.debug_lifetime_y = time_hist_high[0][indices] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 576 |  |  |             para = dict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 577 |  |  |             para['offset'] = {"value": 0.0, "vary": False} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 578 |  |  |             result = self._fit_logic.make_decayexponential_fit(time_hist_high[1][indices], | 
            
                                                                                                            
                            
            
                                    
            
            
                | 579 |  |  |                                                                time_hist_high[0][indices], | 
            
                                                                                                            
                            
            
                                    
            
            
                | 580 |  |  |                                                                self._fit_logic.estimate_decayexponential, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 581 |  |  |                                                                add_params=para) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 582 |  |  |             bright_liftime = result.params['lifetime'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 583 |  |  |             # for debug purposes give also the results back of the fits for now | 
            
                                                                                                            
                            
            
                                    
            
            
                | 584 |  |  |             lifetime_dict['result_bright'] = result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 585 |  |  |             # also give back the data used for the fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 586 |  |  |             lifetime_dict['bright_raw'] = np.array([time_hist_high[1][indices], time_hist_high[0][indices]]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 587 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 588 |  |  |             # get lifetime of dark state | 
            
                                                                                                            
                            
            
                                    
            
            
                | 589 |  |  |             time_hist_low = np.histogram(time_array_low, bins=num_bins) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 590 |  |  |             vals = [i for i in filter(lambda x: x[1] > 0, enumerate(time_hist_low[0][0:num_bins]))] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 591 |  |  |             indices = np.array([val[0] for val in vals]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 592 |  |  |             indices = np.array([np.int(indice) for indice in indices]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 593 |  |  |             values = np.array([val[1] for val in vals]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 594 |  |  |             # positive axis | 
            
                                                                                                            
                            
            
                                    
            
            
                | 595 |  |  |             mirror_axis = -time_hist_low[1][indices] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 596 |  |  |             result = self._fit_logic.make_decayexponential_fit(mirror_axis, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 597 |  |  |                                                                values, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 598 |  |  |                                                                self._fit_logic.estimate_decayexponential, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 599 |  |  |                                                                add_params=para) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 600 |  |  |             dark_liftime = result.params['lifetime'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 601 |  |  |             lifetime_dict['result_dark'] = result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 602 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 603 |  |  |             lifetime_dict['bright_state'] = bright_liftime.value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 604 |  |  |             lifetime_dict['dark_state'] = dark_liftime.value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 605 |  |  |             # also give back the data used for the fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 606 |  |  |             lifetime_dict['dark_raw'] = np.array([mirror_axis, values]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 607 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 608 |  |  |         return lifetime_dict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 609 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 610 |  |  |     def do_gaussian_fit(self, axis, data): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 611 |  |  |         """ Perform a gaussian fit. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 612 |  |  |         @param axis: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 613 |  |  |         @param data: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 614 |  |  |         @return: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 615 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 616 |  |  |         model, params = self._fit_logic.make_gaussian_model() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 617 |  |  |         if len(axis) < len(params): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 618 |  |  |             self.log.warning('Fit could not be performed because number of ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 619 |  |  |                              'parameters is larger than data points.') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 620 |  |  |             return self.do_no_fit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 621 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 622 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 623 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 624 |  |  |             parameters_to_substitute = dict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 625 |  |  |             update_dict = dict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 626 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 627 |  |  |             # TODO: move this to "gated counter" estimator in fitlogic | 
            
                                                                                                            
                            
            
                                    
            
            
                | 628 |  |  |             #      make the filter an extra function shared and usable for other | 
            
                                                                                                            
                            
            
                                    
            
            
                | 629 |  |  |             #      functions | 
            
                                                                                                            
                            
            
                                    
            
            
                | 630 |  |  |             gauss = gaussian(10, 10) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 631 |  |  |             data_smooth = filters.convolve1d(data, gauss / gauss.sum(), mode='mirror') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 632 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 633 |  |  |             # integral of data corresponds to sqrt(2) * Amplitude * Sigma | 
            
                                                                                                            
                            
            
                                    
            
            
                | 634 |  |  |             function = InterpolatedUnivariateSpline(axis, data_smooth, k=1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 635 |  |  |             Integral = function.integral(axis[0], axis[-1]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 636 |  |  |             amp = data_smooth.max() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 637 |  |  |             sigma = Integral / amp / np.sqrt(2 * np.pi) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 638 |  |  |             amplitude = amp * sigma * np.sqrt(2 * np.pi) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 639 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 640 |  |  |             update_dict['offset'] = {'min': 0, 'max': data.max(), 'value': 1e-15, 'vary': False} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 641 |  |  |             update_dict['center'] = {'min': axis.min(), 'max': axis.max(), 'value': axis[np.argmax(data)]} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 642 |  |  |             update_dict['sigma'] = {'min': -np.inf, 'max': np.inf, 'value': sigma} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 643 |  |  |             update_dict['amplitude'] = {'min': 0, 'max': np.inf, 'value': amplitude} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 644 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 645 |  |  |             result = self._fit_logic.make_gaussian_fit(x_axis=axis, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 646 |  |  |                                                        data=data, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 647 |  |  |                                                        estimator=self._fit_logic.estimate_gaussian_peak, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 648 |  |  |                                                        units=None,  # TODO | 
            
                                                                                                            
                            
            
                                    
            
            
                | 649 |  |  |                                                        add_params=update_dict) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 650 |  |  |             # 1000 points in x axis for smooth fit data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 651 |  |  |             hist_fit_x = np.linspace(axis[0], axis[-1], 1000) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 652 |  |  |             hist_fit_y = model.eval(x=hist_fit_x, params=result.params) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 653 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 654 |  |  |             param_dict = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 655 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 656 |  |  |             # create the proper param_dict with the values: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 657 |  |  |             param_dict['sigma_0'] = {'value': result.params['sigma'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 658 |  |  |                                      'error': result.params['sigma'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 659 |  |  |                                      'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 660 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 661 |  |  |             param_dict['FWHM'] = {'value': result.params['fwhm'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 662 |  |  |                                   'error': result.params['fwhm'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 663 |  |  |                                   'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 664 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 665 |  |  |             param_dict['Center'] = {'value': result.params['center'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 666 |  |  |                                     'error': result.params['center'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 667 |  |  |                                     'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 668 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 669 |  |  |             param_dict['Amplitude'] = {'value': result.params['amplitude'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 670 |  |  |                                        'error': result.params['amplitude'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 671 |  |  |                                        'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 672 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 673 |  |  |             param_dict['chi_sqr'] = {'value': result.chisqr, 'unit': ''} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 674 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 675 |  |  |             return hist_fit_x, hist_fit_y, param_dict, result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 676 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 677 |  |  |     def do_doublegaussian_fit(self, axis, data): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 678 |  |  |         model, params = self._fit_logic.make_gaussiandouble_model() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 679 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 680 |  |  |         update_dict = dict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 681 |  |  |         update_dict['offset'] = {'min': 0, 'max': data.max(), 'value': 1e-15, 'vary': False} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 682 |  |  |         #update_dict['g0_center'] = {'min': axis.min(), 'max': axis.max()} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 683 |  |  |         #update_dict['g1_center'] = {'min': axis.min(), 'max': axis.max()} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 684 |  |  |         #update_dict['g0_amplitude'] = {'min': 0, 'max': 2 * data.max()} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 685 |  |  |         #update_dict['g1_amplitude'] = {'min': 0, 'max': 2 * data.max()} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 686 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 687 |  |  |         if len(axis) < len(params): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 688 |  |  |             self.log.warning('Fit could not be performed because number of ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 689 |  |  |                              'parameters is larger than data points') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 690 |  |  |             return self.do_no_fit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 691 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 692 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 693 |  |  |             result = self._fit_logic.make_gaussiandouble_fit(axis, data, self._fit_logic.estimate_gaussiandouble_peak, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 694 |  |  |                                                              add_params=update_dict) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 695 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 696 |  |  |             # 1000 points in x axis for smooth fit data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 697 |  |  |             hist_fit_x = np.linspace(axis[0], axis[-1], 1000) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 698 |  |  |             hist_fit_y = model.eval(x=hist_fit_x, params=result.params) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 699 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 700 |  |  |             # this dict will be passed to the formatting method | 
            
                                                                                                            
                            
            
                                    
            
            
                | 701 |  |  |             param_dict = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 702 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 703 |  |  |             # create the proper param_dict with the values: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 704 |  |  |             param_dict['sigma_0'] = {'value': result.params['g0_sigma'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 705 |  |  |                                      'error': result.params['g0_sigma'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 706 |  |  |                                      'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 707 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 708 |  |  |             param_dict['FWHM_0'] = {'value': result.params['g0_fwhm'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 709 |  |  |                                     'error': result.params['g0_fwhm'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 710 |  |  |                                     'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 711 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 712 |  |  |             param_dict['Center_0'] = {'value': result.params['g0_center'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 713 |  |  |                                       'error': result.params['g0_center'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 714 |  |  |                                       'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 715 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 716 |  |  |             param_dict['Amplitude_0'] = {'value': result.params['g0_amplitude'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 717 |  |  |                                          'error': result.params['g0_amplitude'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 718 |  |  |                                          'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 719 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 720 |  |  |             param_dict['sigma_1'] = {'value': result.params['g1_sigma'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 721 |  |  |                                      'error': result.params['g1_sigma'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 722 |  |  |                                      'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 723 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 724 |  |  |             param_dict['FWHM_1'] = {'value': result.params['g1_fwhm'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 725 |  |  |                                     'error': result.params['g1_fwhm'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 726 |  |  |                                     'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 727 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 728 |  |  |             param_dict['Center_1'] = {'value': result.params['g1_center'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 729 |  |  |                                       'error': result.params['g1_center'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 730 |  |  |                                       'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 731 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 732 |  |  |             param_dict['Amplitude_1'] = {'value': result.params['g1_amplitude'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 733 |  |  |                                          'error': result.params['g1_amplitude'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 734 |  |  |                                          'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 735 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 736 |  |  |             param_dict['chi_sqr'] = {'value': result.chisqr, 'unit': ''} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 737 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 738 |  |  |             return hist_fit_x, hist_fit_y, param_dict, result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 739 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 740 |  |  |     def do_doublepossonian_fit(self, axis, data): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 741 |  |  |         model, params = self._fit_logic.make_multiplepoissonian_model(no_of_functions=2) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 742 |  |  |         if len(axis) < len(params): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 743 |  |  |             self.log.warning('Fit could not be performed because number of ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 744 |  |  |                              'parameters is smaller than data points') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 745 |  |  |             return self.do_no_fit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 746 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 747 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 748 |  |  |             result = self._fit_logic.make_doublepoissonian_fit(x_axis=axis, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 749 |  |  |                                                                data=data, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 750 |  |  |                                                                add_params=None) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 751 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 752 |  |  |             # 1000 points in x axis for smooth fit data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 753 |  |  |             hist_fit_x = np.linspace(axis[0], axis[-1], 1000) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 754 |  |  |             hist_fit_y = model.eval(x=hist_fit_x, params=result.params) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 755 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 756 |  |  |             # this dict will be passed to the formatting method | 
            
                                                                                                            
                            
            
                                    
            
            
                | 757 |  |  |             param_dict = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 758 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 759 |  |  |             # create the proper param_dict with the values: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 760 |  |  |             param_dict['lambda_0'] = {'value': result.params['p0_mu'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 761 |  |  |                                       'error': result.params['p0_mu'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 762 |  |  |                                       'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 763 |  |  |             param_dict['Amplitude_0'] = {'value': result.params['p0_amplitude'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 764 |  |  |                                          'error': result.params['p0_amplitude'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 765 |  |  |                                          'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 766 |  |  |             param_dict['lambda_1'] = {'value': result.params['p1_mu'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 767 |  |  |                                       'error': result.params['p1_mu'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 768 |  |  |                                       'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 769 |  |  |             param_dict['Amplitude_1'] = {'value': result.params['p1_amplitude'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 770 |  |  |                                          'error': result.params['p1_amplitude'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 771 |  |  |                                          'unit': 'Occurrences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 772 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 773 |  |  |             param_dict['chi_sqr'] = {'value': result.chisqr, 'unit': ''} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 774 |  |  |             # removed last return value <<result>> here, because function calculate_threshold only expected | 
            
                                                                                                            
                            
            
                                    
            
            
                | 775 |  |  |             # three return values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 776 |  |  |             return hist_fit_x, hist_fit_y, param_dict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 777 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 778 |  |  |     def do_possonian_fit(self, axis, data): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 779 |  |  |         model, params = self._fit_logic.make_poissonian_model() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 780 |  |  |         if len(axis) < len(params): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 781 |  |  |             self.log.error('Fit could not be performed because number of ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 782 |  |  |                            'parameters is smaller than data points') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 783 |  |  |             return self.do_no_fit() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 784 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 785 |  |  |             result = self._fit_logic.make_poissonian_fit(x_axis=axis, data=data, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 786 |  |  |                                                          estimator=self._fit_logic.estimate_poissonian, add_params=None) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 787 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 788 |  |  |             # 1000 points in x axis for smooth fit data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 789 |  |  |             hist_fit_x = np.linspace(axis[0], axis[-1], 1000) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 790 |  |  |             hist_fit_y = model.eval(x=hist_fit_x, params=result.params) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 791 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 792 |  |  |             # this dict will be passed to the formatting method | 
            
                                                                                                            
                            
            
                                    
            
            
                | 793 |  |  |             param_dict = OrderedDict() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 794 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 795 |  |  |             # create the proper param_dict with the values: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 796 |  |  |             param_dict['lambda'] = {'value': result.params['mu'].value, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 797 |  |  |                                     'error': result.params['mu'].stderr, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 798 |  |  |                                     'unit': 'Counts/s'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 799 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 800 |  |  |             param_dict['chi_sqr'] = {'value': result.chisqr, 'unit': ''} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 801 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 802 |  |  |             return hist_fit_x, hist_fit_y, param_dict, result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 803 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 804 |  |  |     def get_poissonian(self, x_val, mu, amplitude): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 805 |  |  |         """ Calculate, bases on the passed values a poisson distribution. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 806 |  |  |         @param float mu: expected value of poisson distribution | 
            
                                                                                                            
                            
            
                                    
            
            
                | 807 |  |  |         @param float amplitude: Amplitude to which is multiplied on distribution | 
            
                                                                                                            
                            
            
                                    
            
            
                | 808 |  |  |         @param int,float or np.array x_val: x values for poisson distribution, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 809 |  |  |                                             also works for numbers (int or float) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 810 |  |  |         @return np.array: a 1D array with the calculated poisson distribution, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 811 |  |  |                           corresponding to given parameters/ x values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 812 |  |  |         Calculate a Poisson distribution according to: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 813 |  |  |             P(k) =  mu^k * exp(-mu) / k! | 
            
                                                                                                            
                            
            
                                    
            
            
                | 814 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 815 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 816 |  |  |         model, params = self._fit_logic.make_poissonian_model() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 817 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 818 |  |  |         return model.eval(x=np.array(x_val), poissonian_mu=mu, poissonian_amplitude=amplitude) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 819 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 820 |  |  |     def guess_threshold(self, hist_val=None, trace=None, max_ratio_value=0.1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 821 |  |  |         """ Assume a distribution between two values and try to guess the threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 822 |  |  |         @param np.array hist_val: 1D array which represent the y values of a | 
            
                                                                                                            
                            
            
                                    
            
            
                | 823 |  |  |                                     histogram of a trace. Optional, if None | 
            
                                                                                                            
                            
            
                                    
            
            
                | 824 |  |  |                                     is passed here, the passed trace will be | 
            
                                                                                                            
                            
            
                                    
            
            
                | 825 |  |  |                                     used for calculations. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 826 |  |  |         @param np.array trace: optional, 1D array containing the y values of a | 
            
                                                                                                            
                            
            
                                    
            
            
                | 827 |  |  |                                meausured counter trace. If None is passed to | 
            
                                                                                                            
                            
            
                                    
            
            
                | 828 |  |  |                                hist_y_val then the threshold will be calculated | 
            
                                                                                                            
                            
            
                                    
            
            
                | 829 |  |  |                                from the trace. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 830 |  |  |         @param float max_ratio_value: the ratio how strong the lower y values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 831 |  |  |                                        will be cut off. For max_ratio_value=0.1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 832 |  |  |                                        all the data which are 10% or less in | 
            
                                                                                                            
                            
            
                                    
            
            
                | 833 |  |  |                                        amptitude compared to the maximal value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 834 |  |  |                                        are neglected. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 835 |  |  |         The guess procedure tries to find all values, which are | 
            
                                                                                                            
                            
            
                                    
            
            
                | 836 |  |  |         max_ratio_value * maximum value of the histogram of the trace and | 
            
                                                                                                            
                            
            
                                    
            
            
                | 837 |  |  |         selects those by indices. Then taking the first an the last might and | 
            
                                                                                                            
                            
            
                                    
            
            
                | 838 |  |  |         assuming that the threshold is in the middle, gives a first estimate | 
            
                                                                                                            
                            
            
                                    
            
            
                | 839 |  |  |         of the threshold value. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 840 |  |  |         FIXME: That guessing procedure can be improved! | 
            
                                                                                                            
                            
            
                                    
            
            
                | 841 |  |  |         @return float: a guessed threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 842 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 843 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 844 |  |  |         if hist_val is None and trace is not None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 845 |  |  |             hist_val = self.calculate_histogram(trace) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 846 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 847 |  |  |         hist_val = np.array(hist_val)  # just to be sure to have a np.array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 848 |  |  |         indices_arr = np.where(hist_val[1] > hist_val[1].max() * max_ratio_value)[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 849 |  |  |         guessed_threshold = hist_val[0][int((indices_arr[-1] + indices_arr[0]) / 2)] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 850 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 851 |  |  |         return guessed_threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 852 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 853 |  |  |     def calculate_threshold(self, hist_data=None, distr='poissonian'): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 854 |  |  |         """ Calculate the threshold by minimizing its overlap with the poissonian fits. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 855 |  |  |         @param np.array hist_data: 2D array which represent the x and y values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 856 |  |  |                                    of a histogram of a trace. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 857 |  |  |                string distr: tells the function on what distribution it should calculate | 
            
                                                                                                            
                            
            
                                    
            
            
                | 858 |  |  |                              the threshold ( Added because it might happen that one normalizes data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 859 |  |  |                              between (-1,1) and then a poissonian distribution won't work anymore. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 860 |  |  |         @return tuple(float, float): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 861 |  |  |                     threshold: the calculated threshold between two overlapping | 
            
                                                                                                            
                            
            
                                    
            
            
                | 862 |  |  |                                poissonian distributed peaks. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 863 |  |  |                     fidelity: the measure how good the two peaks are resolved | 
            
                                                                                                            
                            
            
                                    
            
            
                | 864 |  |  |                               according to the calculated threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 865 |  |  |         The calculation of the threshold relies on fitting two poissonian | 
            
                                                                                                            
                            
            
                                    
            
            
                | 866 |  |  |         distributions to the count histogram and minimize a threshold with | 
            
                                                                                                            
                            
            
                                    
            
            
                | 867 |  |  |         respect to the overlap area: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 868 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 869 |  |  |         # in any case calculate the hist data | 
            
                                                                                                            
                            
            
                                    
            
            
                | 870 |  |  |         x_axis = hist_data[0][:-1] + (hist_data[0][1] - hist_data[0][0]) / 2. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 871 |  |  |         y_data = hist_data[1] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 872 |  |  |         if distr == 'poissonian': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 873 |  |  |             # perform the fit | 
            
                                                                                                            
                            
            
                                    
            
            
                | 874 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 875 |  |  |             hist_fit_x, hist_fit_y, param_dict = self.do_doublepossonian_fit(x_axis, y_data) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 876 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 877 |  |  |             if param_dict.get('lambda_0') is None: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 878 |  |  |                 self.log.error('The double poissonian fit does not work! Take at ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 879 |  |  |                                'least a dummy value, in order not to break the ' | 
            
                                                                                                            
                            
            
                                    
            
            
                | 880 |  |  |                                'routine.') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 881 |  |  |                 amp0 = 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 882 |  |  |                 amp1 = 1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 883 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 884 |  |  |                 param_dict['Amplitude_0'] = {'value': amp0, 'unit': 'occurences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 885 |  |  |                 param_dict['Amplitude_1'] = {'value': amp0, 'unit': 'occurences'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 886 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 887 |  |  |                 # make them a bit different so that fit works. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 888 |  |  |                 mu0 = hist_data[0][:].mean() - 0.1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 889 |  |  |                 mu1 = hist_data[0][:].mean() + 0.1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 890 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 891 |  |  |                 param_dict['lambda_0'] = {'value': mu0, 'unit': 'counts'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 892 |  |  |                 param_dict['lambda_1'] = {'value': mu1, 'unit': 'counts'} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 893 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 894 |  |  |             else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 895 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 896 |  |  |                 mu0 = param_dict['lambda_0']['value'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 897 |  |  |                 mu1 = param_dict['lambda_1']['value'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 898 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 899 |  |  |                 amp0 = param_dict['Amplitude_0']['value'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 900 |  |  |                 amp1 = param_dict['Amplitude_1']['value'] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 901 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 902 |  |  |             if mu0 < mu1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 903 |  |  |                 first_dist = self.get_poissonian(x_val=hist_data[0], mu=mu0, amplitude=amp0) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 904 |  |  |                 sec_dist = self.get_poissonian(x_val=hist_data[0], mu=mu1, amplitude=amp1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 905 |  |  |             else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 906 |  |  |                 first_dist = self.get_poissonian(x_val=hist_data[0], mu=mu1, amplitude=amp1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 907 |  |  |                 sec_dist = self.get_poissonian(x_val=hist_data[0], mu=mu0, amplitude=amp0) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 908 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 909 |  |  |             # create a two poissonian array, where the second poissonian | 
            
                                                                                                            
                            
            
                                    
            
            
                | 910 |  |  |             # distribution is add as negative values. Now the transition from | 
            
                                                                                                            
                            
            
                                    
            
            
                | 911 |  |  |             # positive to negative values will get the threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 912 |  |  |             difference_poissonian = first_dist - sec_dist | 
            
                                                                                                            
                            
            
                                    
            
            
                | 913 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 914 |  |  |             trans_index = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 915 |  |  |             for i in range(len(difference_poissonian) - 1): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 916 |  |  |                 # go through the combined histogram array and the point which | 
            
                                                                                                            
                            
            
                                    
            
            
                | 917 |  |  |                 # changes the sign. The transition from positive to negative values | 
            
                                                                                                            
                            
            
                                    
            
            
                | 918 |  |  |                 # will get the threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 919 |  |  |                 if difference_poissonian[i] < 0 and difference_poissonian[i + 1] >= 0: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 920 |  |  |                     trans_index = i | 
            
                                                                                                            
                            
            
                                    
            
            
                | 921 |  |  |                     break | 
            
                                                                                                            
                            
            
                                    
            
            
                | 922 |  |  |                 elif difference_poissonian[i] > 0 and difference_poissonian[i + 1] <= 0: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 923 |  |  |                     trans_index = i | 
            
                                                                                                            
                            
            
                                    
            
            
                | 924 |  |  |                     break | 
            
                                                                                                            
                            
            
                                    
            
            
                | 925 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 926 |  |  |             threshold_fit = hist_data[0][trans_index] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 927 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 928 |  |  |             # Calculate also the readout fidelity, i.e. sum the area under the | 
            
                                                                                                            
                            
            
                                    
            
            
                | 929 |  |  |             # first peak before the threshold of the first and second distribution | 
            
                                                                                                            
                            
            
                                    
            
            
                | 930 |  |  |             # and take the ratio of that area. Do the same thing after the threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 931 |  |  |             # (of course with a reversed choice of the distribution). If the overlap | 
            
                                                                                                            
                            
            
                                    
            
            
                | 932 |  |  |             # in both cases is very small, then the fidelity is good, if the overlap | 
            
                                                                                                            
                            
            
                                    
            
            
                | 933 |  |  |             # is identical, then fidelity indicates a poor separation of the peaks. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 934 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 935 |  |  |             if mu0 < mu1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 936 |  |  |                 area0_low = self.get_poissonian(hist_data[0][0:trans_index], mu0, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 937 |  |  |                 area0_high = self.get_poissonian(hist_data[0][trans_index:], mu0, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 938 |  |  |                 area1_low = self.get_poissonian(hist_data[0][0:trans_index], mu1, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 939 |  |  |                 area1_high = self.get_poissonian(hist_data[0][trans_index:], mu1, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 940 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 941 |  |  |                 area0_low_amp = self.get_poissonian(hist_data[0][0:trans_index], mu0, amp0).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 942 |  |  |                 area0_high_amp = self.get_poissonian(hist_data[0][trans_index:], mu0, amp0).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 943 |  |  |                 area1_low_amp = self.get_poissonian(hist_data[0][0:trans_index], mu1, amp1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 944 |  |  |                 area1_high_amp = self.get_poissonian(hist_data[0][trans_index:], mu1, amp1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 945 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 946 |  |  |             else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 947 |  |  |                 area1_low = self.get_poissonian(hist_data[0][0:trans_index], mu0, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 948 |  |  |                 area1_high = self.get_poissonian(hist_data[0][trans_index:], mu0, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 949 |  |  |                 area0_low = self.get_poissonian(hist_data[0][0:trans_index], mu1, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 950 |  |  |                 area0_high = self.get_poissonian(hist_data[0][trans_index:], mu1, 1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 951 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 952 |  |  |                 area1_low_amp = self.get_poissonian(hist_data[0][0:trans_index], mu0, amp0).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 953 |  |  |                 area1_high_amp = self.get_poissonian(hist_data[0][trans_index:], mu0, amp0).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 954 |  |  |                 area0_low_amp = self.get_poissonian(hist_data[0][0:trans_index], mu1, amp1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 955 |  |  |                 area0_high_amp = self.get_poissonian(hist_data[0][trans_index:], mu1, amp1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 956 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 957 |  |  |             # Now calculate how big is the overlap relative to the sum of the other | 
            
                                                                                                            
                            
            
                                    
            
            
                | 958 |  |  |             # part of the area, that will give the normalized fidelity: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 959 |  |  |             fidelity = 1 - (area1_low / area0_low + area0_high / area1_high) / 2 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 960 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 961 |  |  |             area0 = self.get_poissonian(hist_data[0][:], mu0, amp0).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 962 |  |  |             area1 = self.get_poissonian(hist_data[0][:], mu1, amp1).sum() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 963 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 964 |  |  |             # try this new measure for the fidelity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 965 |  |  |             fidelity2 = 1 - ((area1_low_amp / area1) / (area0_low_amp / area0) + (area0_high_amp / area0) / ( | 
            
                                                                                                            
                            
            
                                    
            
            
                | 966 |  |  |             area1_high_amp / area1)) / 2 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 967 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 968 |  |  |             param_dict['normalized_fidelity'] = fidelity2 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 969 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 970 |  |  |             return threshold_fit, fidelity, param_dict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 971 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 972 |  |  |         # this works if your data is normalized to the interval (-1,1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 973 |  |  |         if distr == 'gaussian_normalized': | 
            
                                                                                                            
                            
            
                                    
            
            
                | 974 |  |  |             # first some helper functions | 
            
                                                                                                            
                            
            
                                    
            
            
                | 975 |  |  |             def two_gaussian_intersect(m1, m2, std1, std2, amp1, amp2): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 976 |  |  |                 """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 977 |  |  |                 function to calculate intersection of two gaussians | 
            
                                                                                                            
                            
            
                                    
            
            
                | 978 |  |  |                 """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 979 |  |  |                 a = 1 / (2 * std1 ** 2) - 1 / (2 * std2 ** 2) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 980 |  |  |                 b = m2 / (std2 ** 2) - m1 / (std1 ** 2) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 981 |  |  |                 c = m1 ** 2 / (2 * std1 ** 2) - m2 ** 2 / (2 * std2 ** 2) - np.log(amp2 / amp1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 982 |  |  |                 return np.roots([a, b, c]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 983 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 984 |  |  |             def gaussian(counts, amp, stdv, mean): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 985 |  |  |                 return amp * np.exp(-(counts - mean) ** 2 / (2 * stdv ** 2)) / (stdv * np.sqrt(2 * np.pi)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 986 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 987 |  |  |             try: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 988 |  |  |                 result = self._fit_logic.make_gaussiandouble_fit(x_axis, y_data, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 989 |  |  |                                                                  self._fit_logic.estimate_gaussiandouble_peak) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 990 |  |  |                 # calculating the threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 991 |  |  |                 # NOTE the threshold is taken as the intersection of the two gaussians, while this should give | 
            
                                                                                                            
                            
            
                                    
            
            
                | 992 |  |  |                 # a good approximation I doubt it is mathematical exact. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 993 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 994 |  |  |                 mu0 = result.params['g0_center'].value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 995 |  |  |                 mu1 = result.params['g1_center'].value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 996 |  |  |                 sigma0 = result.params['g0_sigma'].value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 997 |  |  |                 sigma1 = result.params['g1_sigma'].value | 
            
                                                                                                            
                            
            
                                    
            
            
                | 998 |  |  |                 amp0 = result.params['g0_amplitude'].value / (sigma0 * np.sqrt(2 * np.pi)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 999 |  |  |                 amp1 = result.params['g1_amplitude'].value / (sigma1 * np.sqrt(2 * np.pi)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1000 |  |  |                 candidates = two_gaussian_intersect(mu0, mu1, sigma0, sigma1, amp0, amp1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1001 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1002 |  |  |                 # we want to get the intersection that lies between the two peaks | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1003 |  |  |                 if mu0 < mu1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1004 |  |  |                     threshold = [i for i in filter(lambda x: (x > mu0) & (x < mu1), candidates)] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1005 |  |  |                 else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1006 |  |  |                     threshold = [i for i in filter(lambda x: (x < mu0) & (x > mu1), candidates)] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1007 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1008 |  |  |                 threshold = threshold[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1009 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1010 |  |  |                 # now we want to get the readout fidelity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1011 |  |  |                 # of the bigger peak ( most likely the two states that aren't driven by the mw pi pulse ) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1012 |  |  |                 if mu0 < mu1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1013 |  |  |                     gc0 = integrate.quad(lambda counts: gaussian(counts, amp1, sigma1, mu1), -1, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1014 |  |  |                     gp0 = integrate.quad(lambda counts: gaussian(counts, amp1, sigma1, mu1), -1, threshold) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1015 |  |  |                 else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1016 |  |  |                     gc0 = integrate.quad(lambda counts: gaussian(counts, amp0, sigma0, mu0), -1, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1017 |  |  |                     gp0 = integrate.quad(lambda counts: gaussian(counts, amp0, sigma0, mu0), -1, threshold) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1018 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1019 |  |  |                 # and then the same for the other peak ] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1020 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1021 |  |  |                 if mu0 > mu1: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1022 |  |  |                     gc1 = integrate.quad(lambda counts: gaussian(counts, amp1, sigma1, mu1), -1, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1023 |  |  |                     gp1 = integrate.quad(lambda counts: gaussian(counts, amp1, sigma1, mu1), threshold, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1024 |  |  |                 else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1025 |  |  |                     gc1 = integrate.quad(lambda counts: gaussian(counts, amp0, sigma0, mu0), -1, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1026 |  |  |                     gp1 = integrate.quad(lambda counts: gaussian(counts, amp0, sigma0, mu0), threshold, 1) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1027 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1028 |  |  |                 param_dict = {} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1029 |  |  |                 fidelity = 1 - (gp0[0] / gc0[0] + gp1[0] / gc1[0]) / 2 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1030 |  |  |                 fidelity1 = 1 - (gp0[0] / gc0[0]) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1031 |  |  |                 fidelity2 = 1 - gp1[0] / gc1[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1032 |  |  |                 threshold_fit = threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1033 |  |  |                 # if the fit worked, add also the result to the param_dict, which might be useful for debugging | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1034 |  |  |                 param_dict['result'] = result | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1035 |  |  |             except: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1036 |  |  |                 self.log.error('could not fit the data') | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1037 |  |  |                 error = True | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1038 |  |  |                 fidelity = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1039 |  |  |                 threshold_fit = 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1040 |  |  |                 param_dict = {} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1041 |  |  |                 new_dict = {} | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1042 |  |  |                 new_dict['value'] = np.inf | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1043 |  |  |                 param_dict['chi_sqr'] = new_dict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1044 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1045 |  |  |             return threshold_fit, fidelity, param_dict | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1046 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1047 |  |  |     def calculate_binary_trace(self, trace, threshold): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1048 |  |  |         """ Calculate for a given threshold all the trace values und output a | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1049 |  |  |             binary array, where | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1050 |  |  |                 True = Below or equal Threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1051 |  |  |                 False = Above Threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1052 |  |  |         @param np.array trace: a 1D array containing the y data, e.g. ccunts | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1053 |  |  |         @param float threshold: value to decide whether a point in the trace | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1054 |  |  |                                 is below/equal (True) or above threshold (False). | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1055 |  |  |         @return np.array: 1D trace of the length(trace) but now with boolean | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1056 |  |  |                           entries | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1057 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1058 |  |  |         return trace <= threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1059 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1060 |  |  |     def extract_filtered_values(self, trace, threshold, below=True): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1061 |  |  |         """ Extract only those values, which are below or equal a certain Threshold. | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1062 |  |  |         @param np.array trace: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1063 |  |  |         @param float threshold: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1064 |  |  |         @return tuple(index_array, filtered_array): | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1065 |  |  |                     np.array index_array: 1D integer array containing the | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1066 |  |  |                                           indices of the passed trace array | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1067 |  |  |                                           which are equal or below the threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1068 |  |  |                     np.array filtered_array: the actual values of the trace, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1069 |  |  |                                              which are equal or below threshold | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1070 |  |  |         """ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1071 |  |  |         if below: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1072 |  |  |             index_array = np.where(trace <= threshold)[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1073 |  |  |         else: | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1074 |  |  |             index_array = np.where(trace > threshold)[0] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1075 |  |  |         filtered_array = trace[index_array] | 
            
                                                                                                            
                            
            
                                    
            
            
                | 1076 |  |  |         return index_array, filtered_array | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 1077 |  |  |  | 
            
                                                        
            
                                    
            
            
                | 1078 |  |  |  |