pymodaq 3.6.12__py3-none-any.whl → 4.0.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of pymodaq might be problematic. Click here for more details.
- pymodaq/__init__.py +13 -6
- pymodaq/control_modules/__init__.py +0 -7
- pymodaq/control_modules/daq_move.py +965 -2
- pymodaq/control_modules/daq_move_ui.py +319 -0
- pymodaq/control_modules/daq_viewer.py +1573 -3
- pymodaq/control_modules/daq_viewer_ui.py +393 -0
- pymodaq/control_modules/mocks.py +51 -0
- pymodaq/control_modules/move_utility_classes.py +709 -8
- pymodaq/control_modules/utils.py +256 -0
- pymodaq/control_modules/viewer_utility_classes.py +663 -6
- pymodaq/daq_utils.py +89 -0
- pymodaq/dashboard.py +91 -72
- pymodaq/examples/custom_app.py +12 -11
- pymodaq/examples/custom_viewer.py +10 -10
- pymodaq/examples/function_plotter.py +16 -13
- pymodaq/examples/nonlinearscanner.py +8 -6
- pymodaq/examples/parameter_ex.py +7 -7
- pymodaq/examples/preset_MockCamera.xml +1 -0
- pymodaq/extensions/__init__.py +16 -0
- pymodaq/extensions/console.py +76 -0
- pymodaq/{daq_logger.py → extensions/daq_logger.py} +115 -65
- pymodaq/extensions/daq_scan.py +1339 -0
- pymodaq/extensions/daq_scan_ui.py +240 -0
- pymodaq/extensions/h5browser.py +23 -0
- pymodaq/{pid → extensions/pid}/__init__.py +4 -2
- pymodaq/{pid → extensions/pid}/daq_move_PID.py +2 -2
- pymodaq/{pid → extensions/pid}/pid_controller.py +48 -36
- pymodaq/{pid → extensions/pid}/utils.py +52 -6
- pymodaq/extensions/utils.py +40 -0
- pymodaq/post_treatment/__init__.py +6 -0
- pymodaq/{daq_analysis → post_treatment/daq_analysis}/daq_analysis_main.py +17 -17
- pymodaq/{daq_measurement → post_treatment/daq_measurement}/daq_measurement_main.py +8 -14
- pymodaq/post_treatment/load_and_plot.py +219 -0
- pymodaq/post_treatment/process_to_scalar.py +263 -0
- pymodaq/resources/QtDesigner_Ressources/Icon_Library/run_all.png +0 -0
- pymodaq/resources/QtDesigner_Ressources/Icon_Library/stop_all.png +0 -0
- pymodaq/resources/QtDesigner_Ressources/QtDesigner_ressources.bat +1 -1
- pymodaq/resources/QtDesigner_Ressources/QtDesigner_ressources.qrc +1 -0
- pymodaq/resources/QtDesigner_Ressources/QtDesigner_ressources_rc.py +109784 -109173
- pymodaq/resources/QtDesigner_Ressources/icons.svg +142 -0
- pymodaq/resources/VERSION +1 -1
- pymodaq/resources/config_template.toml +32 -13
- pymodaq/resources/preset_default.xml +1 -1
- pymodaq/{daq_utils → utils}/Tuto innosetup/script_full_setup.iss +1 -1
- pymodaq/utils/__init__.py +0 -29
- pymodaq/utils/abstract/__init__.py +48 -0
- pymodaq/{daq_utils → utils}/abstract/logger.py +7 -3
- pymodaq/utils/array_manipulation.py +379 -8
- pymodaq/{daq_utils → utils}/calibration_camera.py +6 -6
- pymodaq/{daq_utils → utils}/chrono_timer.py +1 -1
- pymodaq/utils/config.py +448 -0
- pymodaq/utils/conftests.py +5 -0
- pymodaq/utils/daq_utils.py +828 -8
- pymodaq/utils/data.py +1873 -7
- pymodaq/{daq_utils → utils}/db/db_logger/db_logger.py +86 -47
- pymodaq/{daq_utils → utils}/db/db_logger/db_logger_models.py +31 -10
- pymodaq/{daq_utils → utils}/enums.py +12 -7
- pymodaq/utils/exceptions.py +37 -0
- pymodaq/utils/factory.py +82 -0
- pymodaq/{daq_utils → utils}/gui_utils/__init__.py +1 -1
- pymodaq/utils/gui_utils/custom_app.py +129 -0
- pymodaq/utils/gui_utils/file_io.py +66 -0
- pymodaq/{daq_utils → utils}/gui_utils/layout.py +2 -2
- pymodaq/{daq_utils → utils}/gui_utils/utils.py +13 -3
- pymodaq/{daq_utils → utils}/gui_utils/widgets/__init__.py +2 -2
- pymodaq/utils/gui_utils/widgets/label.py +24 -0
- pymodaq/{daq_utils → utils}/gui_utils/widgets/lcd.py +12 -7
- pymodaq/{daq_utils → utils}/gui_utils/widgets/push.py +66 -2
- pymodaq/{daq_utils → utils}/gui_utils/widgets/qled.py +6 -4
- pymodaq/utils/gui_utils/widgets/spinbox.py +24 -0
- pymodaq/{daq_utils → utils}/gui_utils/widgets/table.py +2 -2
- pymodaq/utils/h5modules/__init__.py +1 -0
- pymodaq/{daq_utils/h5backend.py → utils/h5modules/backends.py} +200 -112
- pymodaq/utils/h5modules/browsing.py +683 -0
- pymodaq/utils/h5modules/data_saving.py +839 -0
- pymodaq/utils/h5modules/h5logging.py +110 -0
- pymodaq/utils/h5modules/module_saving.py +350 -0
- pymodaq/utils/h5modules/saving.py +914 -0
- pymodaq/utils/h5modules/utils.py +85 -0
- pymodaq/utils/logger.py +64 -6
- pymodaq/utils/managers/action_manager.py +460 -0
- pymodaq/{daq_utils → utils}/managers/batchscan_manager.py +144 -112
- pymodaq/{daq_utils → utils}/managers/modules_manager.py +188 -114
- pymodaq/{daq_utils → utils}/managers/overshoot_manager.py +3 -3
- pymodaq/utils/managers/parameter_manager.py +110 -0
- pymodaq/{daq_utils → utils}/managers/preset_manager.py +17 -13
- pymodaq/{daq_utils → utils}/managers/preset_manager_utils.py +8 -7
- pymodaq/{daq_utils → utils}/managers/remote_manager.py +7 -6
- pymodaq/{daq_utils → utils}/managers/roi_manager.py +148 -57
- pymodaq/utils/math_utils.py +546 -10
- pymodaq/{daq_utils → utils}/messenger.py +5 -1
- pymodaq/utils/parameter/__init__.py +2 -15
- pymodaq/{daq_utils → utils}/parameter/ioxml.py +12 -6
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/__init__.py +1 -3
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/filedir.py +1 -1
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/itemselect.py +3 -0
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/led.py +1 -1
- pymodaq/utils/parameter/pymodaq_ptypes/pixmap.py +161 -0
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/slide.py +1 -1
- pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/table.py +1 -1
- pymodaq/utils/parameter/utils.py +206 -11
- pymodaq/utils/plotting/data_viewers/__init__.py +6 -0
- pymodaq/utils/plotting/data_viewers/viewer.py +393 -0
- pymodaq/utils/plotting/data_viewers/viewer0D.py +251 -0
- pymodaq/utils/plotting/data_viewers/viewer1D.py +574 -0
- pymodaq/{daq_utils → utils}/plotting/data_viewers/viewer1Dbasic.py +8 -3
- pymodaq/{daq_utils → utils}/plotting/data_viewers/viewer2D.py +292 -357
- pymodaq/{daq_utils → utils}/plotting/data_viewers/viewer2D_basic.py +58 -75
- pymodaq/utils/plotting/data_viewers/viewerND.py +738 -0
- pymodaq/{daq_utils → utils}/plotting/gant_chart.py +2 -2
- pymodaq/{daq_utils → utils}/plotting/items/axis_scaled.py +4 -2
- pymodaq/{daq_utils → utils}/plotting/items/image.py +8 -6
- pymodaq/utils/plotting/navigator.py +355 -0
- pymodaq/utils/plotting/scan_selector.py +480 -0
- pymodaq/utils/plotting/utils/axes_viewer.py +88 -0
- pymodaq/utils/plotting/utils/filter.py +538 -0
- pymodaq/utils/plotting/utils/lineout.py +224 -0
- pymodaq/{daq_utils → utils}/plotting/utils/plot_utils.py +196 -84
- pymodaq/{daq_utils → utils}/plotting/utils/signalND.py +21 -13
- pymodaq/utils/plotting/widgets.py +76 -0
- pymodaq/utils/scanner/__init__.py +10 -0
- pymodaq/utils/scanner/scan_factory.py +204 -0
- pymodaq/utils/scanner/scanner.py +271 -0
- pymodaq/utils/scanner/scanners/_1d_scanners.py +117 -0
- pymodaq/utils/scanner/scanners/_2d_scanners.py +293 -0
- pymodaq/utils/scanner/scanners/sequential.py +192 -0
- pymodaq/utils/scanner/scanners/tabular.py +294 -0
- pymodaq/utils/scanner/utils.py +83 -0
- pymodaq/utils/slicing.py +47 -0
- pymodaq/utils/svg/__init__.py +6 -0
- pymodaq/utils/svg/svg_renderer.py +20 -0
- pymodaq/utils/svg/svg_view.py +35 -0
- pymodaq/utils/svg/svg_viewer2D.py +51 -0
- pymodaq/{daq_utils → utils}/tcp_server_client.py +36 -37
- pymodaq/{daq_utils → utils}/tree_layout/tree_layout_main.py +50 -35
- pymodaq/utils/units.py +216 -0
- pymodaq-4.0.1.dist-info/METADATA +159 -0
- {pymodaq-3.6.12.dist-info → pymodaq-4.0.1.dist-info}/RECORD +167 -170
- {pymodaq-3.6.12.dist-info → pymodaq-4.0.1.dist-info}/WHEEL +1 -2
- pymodaq-4.0.1.dist-info/entry_points.txt +8 -0
- pymodaq/daq_move/daq_move_gui.py +0 -279
- pymodaq/daq_move/daq_move_gui.ui +0 -534
- pymodaq/daq_move/daq_move_main.py +0 -1042
- pymodaq/daq_move/process_from_QtDesigner_DAQ_Move_GUI.bat +0 -2
- pymodaq/daq_move/utility_classes.py +0 -671
- pymodaq/daq_scan.py +0 -2160
- pymodaq/daq_utils/array_manipulation.py +0 -386
- pymodaq/daq_utils/config.py +0 -273
- pymodaq/daq_utils/conftests.py +0 -7
- pymodaq/daq_utils/custom_parameter_tree.py +0 -9
- pymodaq/daq_utils/daq_enums.py +0 -133
- pymodaq/daq_utils/daq_utils.py +0 -1402
- pymodaq/daq_utils/exceptions.py +0 -71
- pymodaq/daq_utils/gui_utils/custom_app.py +0 -103
- pymodaq/daq_utils/gui_utils/file_io.py +0 -75
- pymodaq/daq_utils/gui_utils/widgets/spinbox.py +0 -9
- pymodaq/daq_utils/h5exporter_hyperspy.py +0 -115
- pymodaq/daq_utils/h5exporters.py +0 -242
- pymodaq/daq_utils/h5modules.py +0 -1559
- pymodaq/daq_utils/h5utils.py +0 -241
- pymodaq/daq_utils/managers/action_manager.py +0 -236
- pymodaq/daq_utils/managers/parameter_manager.py +0 -57
- pymodaq/daq_utils/math_utils.py +0 -705
- pymodaq/daq_utils/parameter/__init__.py +0 -1
- pymodaq/daq_utils/parameter/oldpymodaq_ptypes.py +0 -1626
- pymodaq/daq_utils/parameter/pymodaq_ptypes/pixmap.py +0 -85
- pymodaq/daq_utils/parameter/utils.py +0 -136
- pymodaq/daq_utils/plotting/data_viewers/__init__.py +0 -0
- pymodaq/daq_utils/plotting/data_viewers/process_from_QtDesigner_0DViewer_GUI.bat +0 -2
- pymodaq/daq_utils/plotting/data_viewers/viewer0D.py +0 -204
- pymodaq/daq_utils/plotting/data_viewers/viewer0D_GUI.py +0 -89
- pymodaq/daq_utils/plotting/data_viewers/viewer0D_GUI.ui +0 -131
- pymodaq/daq_utils/plotting/data_viewers/viewer1D.py +0 -781
- pymodaq/daq_utils/plotting/data_viewers/viewerND.py +0 -894
- pymodaq/daq_utils/plotting/data_viewers/viewerbase.py +0 -64
- pymodaq/daq_utils/plotting/items/__init__.py +0 -0
- pymodaq/daq_utils/plotting/navigator.py +0 -500
- pymodaq/daq_utils/plotting/scan_selector.py +0 -289
- pymodaq/daq_utils/plotting/utils/__init__.py +0 -0
- pymodaq/daq_utils/plotting/utils/filter.py +0 -236
- pymodaq/daq_utils/plotting/viewer0D/__init__.py +0 -0
- pymodaq/daq_utils/plotting/viewer0D/viewer0D_main.py +0 -4
- pymodaq/daq_utils/plotting/viewer1D/__init__.py +0 -0
- pymodaq/daq_utils/plotting/viewer1D/viewer1D_main.py +0 -4
- pymodaq/daq_utils/plotting/viewer1D/viewer1Dbasic.py +0 -4
- pymodaq/daq_utils/plotting/viewer2D/viewer_2D_basic.py +0 -4
- pymodaq/daq_utils/plotting/viewer2D/viewer_2D_main.py +0 -4
- pymodaq/daq_utils/plotting/viewerND/__init__.py +0 -0
- pymodaq/daq_utils/plotting/viewerND/viewerND_main.py +0 -4
- pymodaq/daq_utils/scanner.py +0 -1289
- pymodaq/daq_utils/tree_layout/__init__.py +0 -0
- pymodaq/daq_viewer/__init__.py +0 -0
- pymodaq/daq_viewer/daq_gui_settings.py +0 -237
- pymodaq/daq_viewer/daq_gui_settings.ui +0 -441
- pymodaq/daq_viewer/daq_viewer_main.py +0 -2225
- pymodaq/daq_viewer/process_from_QtDesigner_DAQ_GUI_settings.bat +0 -2
- pymodaq/daq_viewer/utility_classes.py +0 -673
- pymodaq/examples/logger_image/__init__.py +0 -0
- pymodaq/examples/logger_image/logger_displayer.py +0 -121
- pymodaq/examples/logger_image/setup.svg +0 -3119
- pymodaq/examples/logger_image/setup_svg.py +0 -114
- pymodaq/h5browser.py +0 -39
- pymodaq/utils/scanner.py +0 -15
- pymodaq-3.6.12.dist-info/METADATA +0 -39
- pymodaq-3.6.12.dist-info/entry_points.txt +0 -8
- pymodaq-3.6.12.dist-info/top_level.txt +0 -1
- /pymodaq/{daq_analysis → post_treatment/daq_analysis}/__init__.py +0 -0
- /pymodaq/{daq_measurement → post_treatment/daq_measurement}/__init__.py +0 -0
- /pymodaq/{daq_measurement → post_treatment/daq_measurement}/daq_measurement_GUI.py +0 -0
- /pymodaq/{daq_measurement → post_treatment/daq_measurement}/daq_measurement_GUI.ui +0 -0
- /pymodaq/{daq_measurement → post_treatment/daq_measurement}/process_from_QtDesigner_DAQ_Measurement_GUI.bat +0 -0
- /pymodaq/{daq_utils → utils}/Tuto innosetup/Tuto innosetup.odt +0 -0
- /pymodaq/{daq_utils → utils}/Tuto innosetup/Tuto innosetup.pdf +0 -0
- /pymodaq/{daq_move → utils/db}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils/db/db_logger}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils}/gui_utils/dock.py +0 -0
- /pymodaq/{daq_utils → utils}/gui_utils/list_picker.py +0 -0
- /pymodaq/{daq_utils/abstract → utils/managers}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/bool.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/date.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/list.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/numeric.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/tableview.py +0 -0
- /pymodaq/{daq_utils → utils}/parameter/pymodaq_ptypes/text.py +0 -0
- /pymodaq/{daq_utils/db → utils/plotting}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils}/plotting/image_viewer.py +0 -0
- /pymodaq/{daq_utils/db/db_logger → utils/plotting/items}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils}/plotting/items/crosshair.py +0 -0
- /pymodaq/{daq_utils/managers → utils/plotting/utils}/__init__.py +0 -0
- /pymodaq/{daq_utils → utils}/qvariant.py +0 -0
- /pymodaq/{daq_utils/plotting/viewer2D → utils/scanner/scanners}/__init__.py +0 -0
- /pymodaq/{daq_utils/plotting → utils/tree_layout}/__init__.py +0 -0
- {pymodaq-3.6.12.dist-info → pymodaq-4.0.1.dist-info/licenses}/LICENSE +0 -0
pymodaq/daq_utils/daq_enums.py
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
from enum import Enum
|
|
2
|
-
from pymodaq.daq_utils.daq_utils import find_index
|
|
3
|
-
from pymodaq.daq_utils.daq_utils import my_moment
|
|
4
|
-
import numpy as np
|
|
5
|
-
from scipy.optimize import curve_fit
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class Items_Lockin_SR830(Enum):
|
|
9
|
-
X = 0
|
|
10
|
-
Y = 1
|
|
11
|
-
R = 2
|
|
12
|
-
Theta = 3
|
|
13
|
-
Channel_1 = 4
|
|
14
|
-
Channel_2 = 5
|
|
15
|
-
Aux_In_1 = 6
|
|
16
|
-
Aux_In_2 = 7
|
|
17
|
-
Aux_In_3 = 8
|
|
18
|
-
Aux_In_4 = 9
|
|
19
|
-
|
|
20
|
-
def names(self):
|
|
21
|
-
names = Items_Lockin_SR830.__members__.items()
|
|
22
|
-
return [name for name, member in names]
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
class Measurement_type(Enum):
|
|
26
|
-
Cursor_Integration = 0
|
|
27
|
-
Max = 1
|
|
28
|
-
Min = 2
|
|
29
|
-
Gaussian_Fit = 3
|
|
30
|
-
Lorentzian_Fit = 4
|
|
31
|
-
Exponential_Decay_Fit = 5
|
|
32
|
-
|
|
33
|
-
def names(self):
|
|
34
|
-
names = Measurement_type.__members__.items()
|
|
35
|
-
return [name for name, member in names]
|
|
36
|
-
|
|
37
|
-
def update_measurement_subtype(self, mtype):
|
|
38
|
-
measurement_gaussian_subitems = ["amp", "dx", "x0", "offset"]
|
|
39
|
-
measurement_laurentzian_subitems = ["alpha", "gamma", "x0", "offset", "amplitude"]
|
|
40
|
-
measurement_decay_subitems = ["N0", "gamma", "offset"]
|
|
41
|
-
measurement_cursor_subitems = ["sum", "mean", "std"]
|
|
42
|
-
variables = ", "
|
|
43
|
-
formula = ""
|
|
44
|
-
subitems = []
|
|
45
|
-
if mtype == self.names()[0]: # "Cursor integration":
|
|
46
|
-
subitems = measurement_cursor_subitems
|
|
47
|
-
|
|
48
|
-
if mtype == self.names()[3]: # "Gaussian Fit":
|
|
49
|
-
subitems = measurement_gaussian_subitems
|
|
50
|
-
formula = "amp*exp(-2*ln(2)*(x-x0)^2/dx^2)+offset"
|
|
51
|
-
variables = variables.join(measurement_gaussian_subitems)
|
|
52
|
-
|
|
53
|
-
elif mtype == self.names()[4]: # "Lorentzian Fit":
|
|
54
|
-
subitems = measurement_laurentzian_subitems
|
|
55
|
-
variables = variables.join(measurement_laurentzian_subitems)
|
|
56
|
-
formula = "alpha/pi*gamma/2/((x-x0)^2+(gamma/2)^2)+offset"
|
|
57
|
-
elif mtype == self.names()[5]: # "Exponential Decay Fit":
|
|
58
|
-
subitems = measurement_decay_subitems
|
|
59
|
-
variables = variables.join(measurement_decay_subitems)
|
|
60
|
-
formula = "N0*exp(-gamma*x)+offset"
|
|
61
|
-
return [variables, formula, subitems]
|
|
62
|
-
|
|
63
|
-
def gaussian_func(self, x, amp, dx, x0, offset):
|
|
64
|
-
return amp * np.exp(-2 * np.log(2) * (x - x0) ** 2 / dx ** 2) + offset
|
|
65
|
-
|
|
66
|
-
def laurentzian_func(self, x, gamma, amp, dx, x0, offset):
|
|
67
|
-
return amp / np.pi * 1 / 2 * gamma / ((x - x0) ** 2 + (1 / 2 * gamma) ** 2) + offset
|
|
68
|
-
|
|
69
|
-
def decaying_func(self, x, N0, gamma, offset):
|
|
70
|
-
return N0 * np.exp(-gamma * x) + offset
|
|
71
|
-
|
|
72
|
-
def update_measurement(self, xmin, xmax, xaxis, data1D, msub_ind):
|
|
73
|
-
try:
|
|
74
|
-
mtype = self.name
|
|
75
|
-
names = self.names()
|
|
76
|
-
boundaries = find_index(xaxis, [xmin, xmax])
|
|
77
|
-
sub_xaxis = xaxis[boundaries[0][0]:boundaries[1][0]]
|
|
78
|
-
sub_data = data1D[boundaries[0][0]:boundaries[1][0]]
|
|
79
|
-
result_measurement = dict(Status=None, datafit=None, xaxis=None)
|
|
80
|
-
|
|
81
|
-
if mtype == names[0]: # Cursor integration:
|
|
82
|
-
if msub_ind == 0: # sum
|
|
83
|
-
result_measurement['value'] = np.sum(sub_data)
|
|
84
|
-
elif msub_ind == 1: # mean
|
|
85
|
-
result_measurement['value'] = np.mean(sub_data)
|
|
86
|
-
elif msub_ind == 2: # std
|
|
87
|
-
result_measurement['value'] = np.std(sub_data)
|
|
88
|
-
|
|
89
|
-
elif mtype == names[1]: # "Max":
|
|
90
|
-
result_measurement['value'] = np.max(sub_data)
|
|
91
|
-
|
|
92
|
-
elif mtype == names[2]: # "Min":
|
|
93
|
-
result_measurement['value'] = np.min(sub_data)
|
|
94
|
-
|
|
95
|
-
elif mtype == names[3]: # "Gaussian Fit":
|
|
96
|
-
offset = np.min(sub_data)
|
|
97
|
-
amp = np.max(sub_data) - np.min(sub_data)
|
|
98
|
-
m = my_moment(sub_xaxis, sub_data)
|
|
99
|
-
p0 = [amp, m[1], m[0], offset]
|
|
100
|
-
popt, pcov = curve_fit(self.gaussian_func, sub_xaxis, sub_data, p0=p0)
|
|
101
|
-
result_measurement['xaxis'] = sub_xaxis
|
|
102
|
-
result_measurement['datafit'] = self.gaussian_func(sub_xaxis, *popt)
|
|
103
|
-
result_measurement['value'] = popt[msub_ind]
|
|
104
|
-
|
|
105
|
-
elif mtype == names[4]: # "Lorentzian Fit":
|
|
106
|
-
offset = np.min(sub_data)
|
|
107
|
-
gamma = 1
|
|
108
|
-
amp = np.max(sub_data) - np.min(sub_data)
|
|
109
|
-
m = my_moment(sub_xaxis, sub_data)
|
|
110
|
-
p0 = [gamma, amp, m[1], m[0], offset]
|
|
111
|
-
popt, pcov = curve_fit(self.laurentzian_func, sub_xaxis, sub_data, p0=p0)
|
|
112
|
-
result_measurement['xaxis'] = sub_xaxis
|
|
113
|
-
result_measurement['datafit'] = self.laurentzian_func(sub_xaxis, *popt)
|
|
114
|
-
|
|
115
|
-
if msub_ind == 4: # amplitude
|
|
116
|
-
result_measurement['value'] = popt[0] * 2 / (np.pi * popt[1]) # 2*alpha/(pi*gamma)
|
|
117
|
-
else:
|
|
118
|
-
result_measurement['value'] = popt[msub_ind]
|
|
119
|
-
elif mtype == names[5]: # "Exponential Decay Fit":
|
|
120
|
-
offset = min([sub_data[0], sub_data[-1]])
|
|
121
|
-
N0 = np.max(sub_data) - offset
|
|
122
|
-
polynome = np.polyfit(sub_xaxis, -np.log((sub_data - 0.99 * offset) / N0), 1)
|
|
123
|
-
p0 = [N0, polynome[0], offset]
|
|
124
|
-
popt, pcov = curve_fit(self.decaying_func, sub_xaxis, sub_data, p0=p0)
|
|
125
|
-
self.curve_fitting_sig.emit([True, sub_xaxis, self.decaying_func(sub_xaxis, *popt)])
|
|
126
|
-
result_measurement['xaxis'] = sub_xaxis
|
|
127
|
-
result_measurement['datafit'] = self.decaying_func(sub_xaxis, *popt)
|
|
128
|
-
result_measurement['value'] = popt[msub_ind]
|
|
129
|
-
|
|
130
|
-
return (result_measurement)
|
|
131
|
-
except Exception as e:
|
|
132
|
-
result_measurement['Status'] = str(e)
|
|
133
|
-
return result_measurement
|