-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUserInput.py
303 lines (269 loc) · 31.3 KB
/
UserInput.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
import os
import sys
sys.path.insert(1, os.path.join(os.curdir, os.pardir, os.pardir))
if os.path.basename(__file__) != "DefaultUserInput.py":
from DefaultUserInput import *
thisModuleObject = sys.modules[__name__]
if str(__name__) == "DefaultUserInput":
print("***This is in DefaultUserInput.py. DefaultUserInput gets loaded before UserInput to make sure all variables are initially populated with defaults.***")
#Everything below this point is the variables' new dictionary format
UserChoices = {} #initialize a dictionary to store all user choices
if str(__name__) != "DefaultUserInput":
print("***This is in the actual UserInput.py.***")
#//Input Files//
UserChoices['inputFiles'] = {} #initialize the inputFiles container
UserChoices['inputFiles']['referencePatternsFileNamesList'] = ['AcetaldehydeNISTRefMixed3.tsv'] #enter the file name of the file containing reference information. tsv is tab-separated, csv is comma separated. tsv supports commas in molecule names.
UserChoices['inputFiles']['referencePatternsFormsList'] = 'xyyy' #form is either 'xyyy' or 'xyxy' (if using reference pattern time chooser enter as list with forms for each individual reference file ['xyyy','xyyy','xyyy'])
UserChoices['inputFiles']['referencePatternTimeRanges'] = [] #Leave empty if not using reference pattern time chooser []
UserChoices['inputFiles']['dataToAnalyzeFileName'] = '2-CrotAcetExp#2.csv' #enter the file name with raw mass spectrometer data
UserChoices['inputFiles']['ionizationDataFileName'] = '181017ProvidedIonizationData.csv' #the name of the file containing the ionization data
#//Iterative Analysis//
UserChoices['iterativeAnalysis'] = {} #initialize the iterativeAnalysis container
#Options are True, False, or '<name of iteration>'
UserChoices['iterativeAnalysis']['on'] = False
#the chosenMoleculesNames argument is used for iterative analysis, so make sure that input is accurate
#the chosenMassFragments argument is also used for iterative analysis, so make sure that input is accurate as well
#Below are Only used in iterative analysis. Most are just initializing and should not be touched.
UserChoices['iterativeAnalysis']['TotalConcentrationsOutputName'] = 'TotalConcentrations.csv'
UserChoices['iterativeAnalysis']['iterationSuffix'] = ''
UserChoices['iterativeAnalysis']['unusedMolecules'] =''
UserChoices['iterativeAnalysis']['oldReferenceFileName'] = []
UserChoices['iterativeAnalysis']['oldDataToAnalyzeFileName'] =''
UserChoices['iterativeAnalysis']['nextRefFileName'] = []
UserChoices['iterativeAnalysis']['nextExpFileName'] = ''
UserChoices['iterativeAnalysis']['iterationNumber'] = None #just initializing.
#do you wish for the program to institute preproccessing and/or Data analysis?
#note that preproccesing must be done at least once before being bypassed
#options for preProcessing and dataAnalysis are 'yes', 'load', or 'skip'
UserChoices['preProcessing'] = {} #initialize the preProcessing container
UserChoices['preProcessing']['on'] = 'yes'
UserChoices['dataAnalysis'] = {} #initialize the dataAnalysis container
UserChoices['dataAnalysis']['on'] = 'yes'
#options for dataSimulation are 'yes' or 'no'
UserChoices['dataSimulation'] = {} #initialzie the dataSimulation container
UserChoices['dataSimulation']['on'] = 'yes'
#//Graphing//
UserChoices['grapher'] = {} #initialize grapher container
#option allowing you to view a graph of determined concentrations
UserChoices['grapher']['on'] = 'yes' #yes will graph function no will not
UserChoices['grapher']['stopAtGraphs'] = False #True will cause stopping at graphs.
#//Time Range//
UserChoices['timeRangeLimit'] = {} #initialize the timeRangeLimit container
#This function limits the data analyzed and proccessed to a certain subset of the total data
UserChoices['timeRangeLimit']['on'] = 'no' #if you wish to enable this function enter 'yes' otherwise 'no'
UserChoices['timeRangeLimit']['timeRangeStart'] = 450 #start time (-int)
UserChoices['timeRangeLimit']['timeRangeFinish'] = 650 #finish time (-int)
#//Chosen Molecules//
UserChoices['specificMolecules'] = {} #initialize the specificMolecules container
#To choose only specific molecules to solve, input in a list of strings below
UserChoices['specificMolecules']['on'] = 'no'
UserChoices['specificMolecules']['chosenMoleculesNames'] = ['Crotyl Alcohol'] #use commas to separate molecule names, such as ['hydrogen', 'acetone']
#//Chosen Mass Fragments//
UserChoices['specificMassFragments'] = {} #initialize the specificMassFragments container
#To choose only specific mass fragments from collected data, input below:
UserChoices['specificMassFragments']['on'] = 'no' #if you wish to enable this function enter 'yes' otherwise 'no'
UserChoices['specificMassFragments']['chosenMassFragments'] = [57] #enter the mass fragments you wish to include in calculations in the format [x,y,z...]
#//Molecule Likelihoods//
UserChoices['moleculeLikelihoods'] = {} #initialize the moleculeLikelihoods container
#To specify the percentage chance of detecting a particular molecule. This must be the same length as the number of molecules in the reference file, or have no value.
UserChoices['moleculeLikelihoods']['moleculeLikelihoods'] = [] #This should be like this [], or like this: [0.8, 1.0, 0.01,... 1.0] where the decimals are the user's guess of the likelihood of each molecule being present.
#//Sensivity Values//
UserChoices['sensitivityValues'] = {} #initialize the container
#Sensitivity values allow the user the specify the threshold of each molecule individually, or apply one threshold to all molecules
UserChoices['sensitivityValues']['sensitivityValues'] = []
#TODO 2/3/18:
# Change so that late baseline times are omitted with a blank list for that mass (or all masses) rather than with zeros,
# or allow "None, None".
#//Baseline Correction - Linear Semiautomatic//
UserChoices['linearBaselineCorrectionSemiAutomatic'] = {} #initialize the linearBaselineCorrectionSemiAutomatic container
#To change delete background average/slope based on time-interval, input below information below. 'yes' enables 'no' disables
UserChoices['linearBaselineCorrectionSemiAutomatic']['on'] = 'no' #selection can be 'yes' or 'no'
UserChoices['linearBaselineCorrectionSemiAutomatic']['baselineType'] = ['linear'] #baselineType may be either 'flat' or 'linear'
# if you would like to apply this correction to all fragments, leave below as []
UserChoices['linearBaselineCorrectionSemiAutomatic']['massesToBackgroundCorrect'] = [2, 18, 27, 28, 31, 39, 41, 44, 57, 70] #mflist: enter mass list delimited With commas [m1, m2, m3]. Leave blank for all masses.
# to apply a uniform time range to all fragments, only insert one time range as such [[x,y]]
UserChoices['linearBaselineCorrectionSemiAutomatic']['earlyBaselineTimes'] = [[177.0, 177.1]] # to apply different times for each fragment enter time pairs as such [[x,y],[z,w]..]
# to apply a uniform time range to all fragments, only insert one time range [[x,y]]
UserChoices['linearBaselineCorrectionSemiAutomatic']['lateBaselineTimes'] = [[901.0,902.0],[496.0,503.0],[901.0,902.0],[496.0,503.0],[901.0,902.0],[901.0,902.0],[901.0,902.0],[496.0,503.0],[901.0,902.0],[901.0,902.0]] #if you do not wish to enter a second time list enter 0's [[0,0],[0,0]...] or [[0,0]]
#//Baseline Correction - Linear Manual//
UserChoices['linearBaselineCorrectionManual'] = {} #initialize the linearBaselineCorrectionManual container
#To manually eliminate background slope/average, input below. If you do not wish to change any fragment leave function empty (like so [])
UserChoices['linearBaselineCorrectionManual']['backgroundMassFragment'] = []
UserChoices['linearBaselineCorrectionManual']['backgroundSlopes'] = []
UserChoices['linearBaselineCorrectionManual']['backgroundIntercepts'] = []
#//Data Solving Restrictions - Marginal Change Restrictor//
UserChoices['interpolateYorN'] = {} #initialize the interpolateYorN container
#To input data ranges for certain molecules, input below
UserChoices['interpolateYorN']['on'] = 'no'
#These factors are used to determine the search parameters for the brute force analysis method
# However, it is also needed for the interpolater which allows the data ranges to be small enough to be solvable by brute force
UserChoices['interpolateYorN']['marginalChangeRestriction'] = 2.0
UserChoices['interpolateYorN']['ignorableDeltaYThreshold'] = 0.01
#//Data Solving Restrictions - Brute Solving Restrictions
UserChoices['bruteSolvingRestrictions'] = {} #initialize the bruteSolvingRestrictions container
#dataLowerBound and dataUpperbound put absolute bounds on the values brute searches for across all time points.
#I believe (if I am not mistaken) that dataRangeSpecifier puts bounds for each time point.
UserChoices['bruteSolvingRestrictions']['dataLowerBound'] = []
UserChoices['bruteSolvingRestrictions']['dataUpperBound'] = []
#NOTE: This feature (dataRangeSpecifierYorN) may not be compatible with the
# "Load" pre-processing feature.
UserChoices['bruteSolvingRestrictions']['dataRangeSpecifierYorN'] = 'no'
UserChoices['bruteSolvingRestrictions']['signalOrConcentrationRange'] = 'signal' #'signal' or 'concentration'
UserChoices['bruteSolvingRestrictions']['csvFile'] = 'yes' #'yes' or 'no'
UserChoices['bruteSolvingRestrictions']['moleculesToRestrict'] = []
UserChoices['bruteSolvingRestrictions']['csvFileName'] = 'rangestemplate.csv'
#NOTE: The increment choice of the user is then possibly overridden based on
# the values of maxPermutations (the number of molecules and bruteIncrements might
# cause too large of a number of permutations, in which case larger bruteIncrements
# may be used).
#bruteIncrements sets the size of the increments for Brute (e.g., if we said 0.01 bar, it would make the
# separation between points 0.01 bar in the grid, for that axis).
UserChoices['bruteSolvingRestrictions']['bruteIncrements'] = []
UserChoices['bruteSolvingRestrictions']['permutationNum'] = 1000
UserChoices['bruteSolvingRestrictions']['maxPermutations'] = 100001
#//Scaling Raw Data Factor//
UserChoices['scaleRawDataYorN'] = {} #initialize the scaleRawDataYorN container
UserChoices['scaleRawDataYorN']['on'] = 'no' #This variable is currently unused, but later choosing "no" will set things to "manual" and change "scaleRawDataFactor" to 1.
UserChoices['scaleRawDataYorN']['scaleRawDataOption'] = 'manual' #Choices are 'manual' or 'auto'
#'auto' automatically scales the data so that the smallest value is equal to 1
#If manual is chosen above, this option allows the user to scale all raw data by a factor of their choosing
UserChoices['scaleRawDataYorN']['scaleRawDataFactor'] = 1
#Note that 1 is the default and will make no alteration to the data
#//Tuning Corrector - Reference Correction Coefficients//
UserChoices['tuningCorrection'] = {} #initialize the tuningCorrection container
#TODO Reference Correction Coefficients feature should be upgraded to enable separate coefficients for each molecule to allow mixing and matching of reference patterns
#TODO This can be tested by looking at the exported reference file and comparing it to the existing reference file
#To change reference data based on mass dependent 2nd degree polynomial fit, input polynomial below. If you do not wish to use this function, simply leave as default
UserChoices['tuningCorrection']['on'] ='no'
UserChoices['tuningCorrection']['tuningCorrectPatternInternalVsExternal'] = 'External' #the options are 'External' or 'Internal'. Typically, External with createMixedTuningPattern is used. With "External", the existing pattern is assumed to be an External pattern and is tuning corrected. With "Internal" the existing pattern is assumed to be an Internal pattern, and the analysis pattern is changed to match the tuning of the desired pattern. Another use of 'Internal' when applying reference Coefficients manually to the Reference Analysis pattern. As of Nov 2021, if "External" is used, then at least one of referenceFileStandardTuningAndForm and referenceFileExistingTuningAndForm must be filled.
UserChoices['tuningCorrection']['referenceFileStandardTuningAndForm'] = [] #optional: Provides tuningCorrectionIntensity feature. Must include csv file and form. Example: ['NISTRef.csv', 'xyyy'] . Will automatically be used for ReferenceFileExistingTuning if that variable is blank and if createMixedTuningPattern=True.
UserChoices['tuningCorrection']['createMixedTuningPattern'] = True #Users should normally never change this. If True, the external pattern gets changed, and a mixed reference pattern gets changded. If False, the *internal* pattern gets changed.
UserChoices['tuningCorrection']['referenceFileExistingTuningAndForm'] =[] #This is the pattern that will be pattern tuning corrected. Normally should be empty list, []. Otherwise, must include csv file and form. Example: ['NISTRef.csv', 'xyyy'] .
UserChoices['tuningCorrection']['referenceFileDesiredTuningAndForm'] =[] #This is what the pattern will look more like after everything is done. Normally should be empty, list, []. Otherwise, must include csv file and form. Example: ['OriginalRef.csv', 'xyyy'] .
UserChoices['tuningCorrection']['tuningCorrectorGasMixtureMoleculeNames'] =[] #Optional: Special case, When using tuning corrector with a measured gas mixture spectrum molecule names must be provided (along with filling the next two variables).
UserChoices['tuningCorrection']['tuningCorrectorGasMixtureConcentrations'] =[] #Optional: Special case, When using tuning corrector with a measured gas mixture spectrum concetrations must be provided
UserChoices['tuningCorrection']['tuningCorrectorGasMixtureSignals'] = [] #Optional: Special case, When using tuning corrector with a measured gas mixture spectrum, tuningCorrectorGasMixtureSignals must be provided or will be used to extract from the data. Leaving this unchanged will take the average of all of the data. If a pair of times is provided, that will be used to extract from the measured data. Alternatively, a single filename with an MSRESOLVE reference file and molecule name "GaxMixture".
#The reference correction coefficients are always used. If tuningCorrection is 'yes' then the coefficients are overwritten and a new reference pattern is also generated to look more like the "Literature" case.
UserChoices['tuningCorrection']['referenceCorrectionCoefficients'] = {'A': 0.0, 'B': 0.0, 'C': 1.0}
#default is 'A': 0.0, 'B': 0.0, 'C': 1.0. Used as.... Factor = A*X^2 + B*X + C, so A=0,B=0,C=1.0 means the final factor is 1.0 and independent of molecular weight.
UserChoices['tuningCorrection']['referenceCorrectionCoefficients_cov'] = [0,0,0] #Covariance for reference correction coefficients for tuning corrector. Default is 0,0,0. Can be 9 x 9 covariance.
#//Reference Pattern Changer // (rpc)
UserChoices['extractReferencePatternFromDataOption'] = {} #initialize the extractReferencePatternFromDataOption container
#To change reference data based on collected data at a certain time, enter mass fragments for the molecule and times below
UserChoices['extractReferencePatternFromDataOption']['on'] = 'no'
UserChoices['extractReferencePatternFromDataOption']['rpcMoleculesToChange'] = ['Crotyl Alcohol']
#rpcTimeRanges and rpcMoleculesToChangeMF are nested lists. Each nested list corresponds to a molecule in rpcMoleculesToChange
#To make this easier to visualize, each nested list is placed on its own line so the first line refers to the first molecule, second line refers to the second molecule and so on
UserChoices['extractReferencePatternFromDataOption']['rpcTimeRanges'] = [
[300,500], #For each molecule to be changed, a pair of times is required.
]
#The first mass fragment is the base fragment and it will not be changed. The fragments following the first one are all altered based on the signal of the first fragment from the collected data
UserChoices['extractReferencePatternFromDataOption']['rpcMoleculesToChangeMF'] = [
[70,57], #For each molecule for using the rpc on, make a new line with a list of masses (length of each should be greater than 1).
] #Make sure every mass you listed was collected otherwise there will be an error.
#//Reference Mass Fragmentation Threshold//
UserChoices['applyReferenceMassFragmentsThresholds'] = {} #initialize the applyReferenceMassFragmentsThresholds container
# if you want to exclude tiny fragmentation peaks
UserChoices['applyReferenceMassFragmentsThresholds']['on'] = 'auto' #'auto','yes', or 'no'. Auto will turn this on when solverChoice = 'sls' is used, and will turn this off when solverChoice = 'inverse'
UserChoices['applyReferenceMassFragmentsThresholds']['referenceMassFragmentFilterThreshold'] = [5.0] #typical values are between 1 and 5. Can be a list (one value for each molecule) or a single value across all molecules. The list case has not been tested with all features. This approximates smaller fragmentation peaks as '0', though implicitSLS will correct for the approximation.
UserChoices['applyReferenceMassFragmentsThresholds']['referenceSignificantFragmentThresholds'] = [6.0] #typical values are between 5 and 50. Can be a list (one value for each molecule) or a single value across all molecules. The list case has not been tested with all features. This setting causes MSRESOLVE to favor larger intensity reference peaks (above the number provided) during solving.
#//Data Threshold Filter//
UserChoices['lowerBoundThresholdChooser'] = {} #initialize the lowerBoundThresholdChooser container
#To change the lower bound below which data is eliminated, change below; lowerBoundThresholdChooser ='yes' or 'no'
#The idea is that below an absolute (or percent based) threshold the intensity will be set to 0.
UserChoices['lowerBoundThresholdChooser']['on'] = 'yes'
UserChoices['lowerBoundThresholdChooser']['massesToLowerBoundThresholdFilter'] = [] # leave as [ ] to apply identical percentages or absolute thresholds to all masses.
UserChoices['lowerBoundThresholdChooser']['lowerBoundThresholdPercentage'] = [0.02] # 1.0 is max value. leave as [ ] to only use the absolute threshold. Always include a decimal.
UserChoices['lowerBoundThresholdChooser']['lowerBoundThresholdAbsolute'] = [] # leave as [ ] to only use the percentage threshold. Always include a decimal.
#//Data Smoothing//
#TODO consider changing the name option from # point/timerange to # abscissaPointradius / abscissaDistanceRadius
UserChoices['dataSmootherYorN'] = {} #initialize the dataSmootherYorN container
#This section is for the data smoother function which, by default, is enabled.
#Data smoothing can be conducted by a time basis or by a data point basis
UserChoices['dataSmootherYorN']['on'] = 'yes'
UserChoices['dataSmootherYorN']['dataSmootherChoice'] = 'pointrange' #options are 'pointrange' or 'timerange'
# abscissaPointRadius and absc
UserChoices['dataSmootherYorN']['dataSmootherTimeRadius'] = 7
UserChoices['dataSmootherYorN']['dataSmootherPointRadius'] = 2
UserChoices['dataSmootherYorN']['dataSmootherHeadersToConfineTo'] = [] #Masses on which to perform smoothing.
#Should be a subset of 'choosenMassFragments' above.
# leave array empty [], to smooth all masses
UserChoices['dataSmootherYorN']['polynomialOrder'] = 1 #During the local smoothing, a linear fit (or polynomial fit) is applied.
#//Raw Signal Threshold//
#WARNING: This feature has not been maintained and should not be used. 7/18/17.
#The function is highly complex and is not trivial to make work with all other features.
UserChoices['applyRawSignalThresholds'] = {} #initialize the applyRawSignalThresholds container
#To change the threshold at which raw signals are not longer relevant, change below (similar to above function, but for rows instead of columns)
#We think the reference to the 'above function' in the previous line is referring to Data Threshold Filter
#These signals get converted into 0.
UserChoices['applyRawSignalThresholds']['on'] = 'no'
UserChoices['applyRawSignalThresholds']['rawSignalThresholdValue'] = [.0000001]
UserChoices['applyRawSignalThresholds']['sensitivityThresholdValue'] = [1] #this is the number in the Reference given the relative intensity of the signal of the mass fragment
UserChoices['applyRawSignalThresholds']['rawSignalThresholdDivider'] = []
#Part of previous entry function, but this function enables the user to change the sum of raw signals, allowing molecules with very high concentrations not to affect previous funciton
UserChoices['applyRawSignalThresholds']['rawSignalThresholdLimit'] = 'no'
UserChoices['applyRawSignalThresholds']['rawSignalThresholdLimitPercent'] = []
#//Uncertainties//
UserChoices['uncertainties'] = {} #initialize the uncertainties settings container
UserChoices['uncertainties']['calculateUncertaintiesInConcentrations'] = True #for Calculating Uncertainties in Concentrations
UserChoices['uncertainties']['referencePatterns_uncertainties'] = 2 #which can be a float/integer for absolute uncertainties or the value True (or the value 'File'. Will expect same file name as reference file with _absolute_uncertainties.tsv at end of file name) or the value None (False will also be set to None) . For example, the value 2 would mean a 2% uncertainty for the value 100, but a 50% uncertainty for the value of 4.
UserChoices['uncertainties']['dataToAnalyze_uncertainties'] = 'Auto' # Can be 'Auto' or 'File' or 'None' or an Integer like 3 (no quotation marks). Or, you can put in a list: one value for each mass, which will be used for all times. If 'File', will expect same file name as collected file with _absolute_uncertainties.csv after that). An integer defines a point radius. 'Auto' without dataSmoother simply uses a point radius of 5. If dataSmoother is being used, it is recommended to set this to 'auto', in which case the range used for each window will match that of dataSmoother.
UserChoices['uncertainties']['dataToAnalyze_uncertainties_radiusType'] = 'pointrange' #Can be 'pointrange' or 'timerange'. If dataToAnalyze_uncertainties is set to auto, then the radiustype will be forced to match datasmoother choice (if dataSmoother is being used), or will be forced to 'pointrange' (if dataSmoother is not being used).
UserChoices['uncertainties']['referenceCorrectionCoefficientsUncertainties'] = None #Else a dictionary of uncertainties for 'A', 'B', 'C'. Not yet implemented.
UserChoices['uncertainties']['referenceCorrectionCoefficientsIonizationUncertainties'] = None #Not yet implemented.
#//Negative Analyzer//
UserChoices['negativeAnalyzerYorN'] = {} #initialize the negativeAnalyzerYorN container
#if enabled ('yes') Negative Analyzer will prevernt negative valued concentrations from being compututed.
UserChoices['negativeAnalyzerYorN']['on'] = 'no'
UserChoices['negativeAnalyzerYorN']['NegativeAnalyzerTopNContributors'] = 5
UserChoices['negativeAnalyzerYorN']['NegativeAnalyzerBaseNumberOfGridIntervals'] = 5
#//Data Analysis Methods
UserChoices['dataAnalysisMethods'] = {} #initialize the dataAnalysisMethods container
#Below the path for the analysis of the data; sls or inverse
UserChoices['dataAnalysisMethods']['solverChoice'] = 'sls' #'inverse' or 'sls'; sls is suggested. 'autosolver' is in development.
UserChoices['dataAnalysisMethods']['uniqueOrCommon'] = 'unique' #'unique' or 'common'; unique is suggested when uncertainties will be used.
UserChoices['dataAnalysisMethods']['slsWeighting'] = [1,1,1,1] #The first includes uncertainties weighting. The second includes solved concentration weighting. The third includes reference fragment intensity weighitng. The fourth includes signal intensity weighting. All can be on at the same time.
UserChoices['dataAnalysisMethods']['slsFinish'] = 'inverse' #'brute' or 'inverse'; inverse is currently suggested if using the uncertainties feature.
UserChoices['dataAnalysisMethods']['slsUniquePositiveConcentrationsOnly'] = False #Can be true or false. This is faster but less accurate than NegativeAnalyzer
UserChoices['dataAnalysisMethods']['objectiveFunctionType'] = 'ssr' #objectiveFunctionType = 'ssr', 'sar', 'weightedSAR' or 'weightedSSR'
UserChoices['dataAnalysisMethods']['distinguished'] = 'yes'
UserChoices['dataAnalysisMethods']['fullBrute'] = 'yes'
UserChoices['dataAnalysisMethods']['SLSUniqueExport'] = 'yes'
UserChoices['dataAnalysisMethods']['implicitSLScorrection'] = False #recommended when doing SLS Unique with uncertainties.
UserChoices['dataAnalysisMethods']['implicitSLSRecursion'] = 0 #This variable is currently a work in progress. As of 3/17/2022, this input does nothing. In the future, it will be used as an input to control Implicit SLS Recursion
UserChoices['dataAnalysisMethods']['finalOptimization'] = 'None' #options are 'None' or... 'Nelder-Mead','Powell','CG','BFGS','Newton-CG','L-BFGS-B','TNC','COBYLA','SLSQP','dogleg','trust-ncg','trust-xact','trust-krylov' from scipy.optimize.minimze
#//Concentration Finder//
UserChoices['concentrationFinder'] = {} #initialize the concentrationFinder container
#this last set of inputs is where you enter your conversion factors from raw signal to concentration, unlike most rows, do not leave brackets around chosen numbers
#here you put in a known raw signal intensity and the known concentration it corresponds to.
#TODO Note: Concentration Finder is not compatible with simultaneous use of multiple reference files AND separate molecules' factors as of 181022. Currently, it a user may use either one or the other.
UserChoices['concentrationFinder']['on'] = 'no'
UserChoices['concentrationFinder']['TSC_List_Type'] = 'MultipleReferencePatterns' #Options are 'MultipleReferencePatterns' or 'SeparateMolecularFactors'
UserChoices['concentrationFinder']['moleculesTSC_List'] = ['Acetaldehyde'] #Default concentration factors will be calculated for each molecule to match the first moleculeTSC input
UserChoices['concentrationFinder']['massNumberTSC_List'] = [29]
UserChoices['concentrationFinder']['moleculeSignalTSC_List'] = [1.66945] #This is the list of intensity values that correspond to a known concentration to scale with for the same mass fragments
UserChoices['concentrationFinder']['moleculeConcentrationTSC_List'] = [0.05] #this is the concentration/pressure associated with the signal.
UserChoices['concentrationFinder']['unitsTSC'] = 'bar' #this string is the unit for the concentration. The unit will not be used in calculations so any units may be used
#//Output Files//
UserChoices['outputFiles'] = {} #initialize the outputFiles container
#the last section designates the various output files, all are suppose to be csv values
#If files do not exist they will be generated
UserChoices['outputFiles']['preProcessedDataOutputName'] = 'PreProcessedData.csv'
UserChoices['outputFiles']['resolvedScaledConcentrationsOutputName'] = 'ScaledConcentrations.tsv' #tsv makes a comma separated file, csv makes a comma separated file.
UserChoices['outputFiles']['scaledConcentrationsPercentages'] = 'ScaledConcentrationPercentages.tsv' #tsv makes a comma separated file, csv makes a comma separated file.
UserChoices['outputFiles']['concentrationsOutputName'] = 'ResolvedConcentrations.tsv' #tsv makes a comma separated file, csv makes a comma separated file.
UserChoices['outputFiles']['simulatedSignalsOutputName'] = 'SimulatedRawSignals.csv'
UserChoices['ExportAtEachStep'] = {} #initialize the ExportAtEachStep container
UserChoices['ExportAtEachStep']['on'] = 'yes'
UserChoices['generatePercentages'] = {} #initialize the generatePercentages container
UserChoices['generatePercentages']['on'] = 'no'
UserChoices['checkpoint'] = {} #initialize the container
UserChoices['checkpoint']['checkpoint'] = '' #just initializing, not really necessary to have here.
UserChoices['checkpoint']['start'] = '' #just initializing, not really necessary to have here.
UserChoices['checkpoint']['timeSinceLastCheckpoint'] = '' #just initializing, not really necessary to have here.
from userInputValidityFunctions import userInputValidityCheck
from userInputValidityFunctions import populateModuleVariablesFromDictionary
SettingsVDictionary = userInputValidityCheck(UserChoices)
populateModuleVariablesFromDictionary(thisModuleObject, SettingsVDictionary)
####End of temporary code####
__var_list__ = ['referencePatternsFileNamesList','referencePatternsFormsList','dataToAnalyzeFileName', 'referencePatternTimeRanges','ionizationDataFileName','iterativeAnalysis','iterationNumber','iterationSuffix','unusedMolecules','oldReferenceFileName', 'oldDataToAnalyzeFileName', 'nextRefFileName', 'nextExpFileName','preProcessing','dataAnalysis','dataSimulation','grapher','stopAtGraphs','timeRangeLimit','timeRangeStart','timeRangeFinish','specificMolecules','chosenMoleculesNames','specificMassFragments','chosenMassFragments','moleculeLikelihoods','sensitivityValues','linearBaselineCorrectionSemiAutomatic','baselineType','massesToBackgroundCorrect','earlyBaselineTimes','lateBaselineTimes','backgroundMassFragment','backgroundSlopes','backgroundIntercepts','interpolateYorN','marginalChangeRestriction','ignorableDeltaYThreshold','dataLowerBound','dataUpperBound','dataRangeSpecifierYorN','signalOrConcentrationRange','csvFile','moleculesToRestrict','csvFileName','bruteIncrements','permutationNum','maxPermutations','scaleRawDataOption','scaleRawDataFactor','tuningCorrection', 'tuningCorrectPatternInternalVsExternal', 'referenceFileStandardTuningAndForm', 'tuningCorrectorGasMixtureMoleculeNames', 'tuningCorrectorGasMixtureConcentrations', 'tuningCorrectorGasMixtureSignals', 'createMixedTuningPattern', 'referenceFileExistingTuningAndForm','referenceFileDesiredTuningAndForm','referenceCorrectionCoefficients','referenceCorrectionCoefficients_cov','extractReferencePatternFromDataOption','rpcMoleculesToChange','rpcMoleculesToChangeMF','rpcTimeRanges','applyReferenceMassFragmentsThresholds','referenceMassFragmentFilterThreshold','referenceSignificantFragmentThresholds','lowerBoundThresholdChooser','massesToLowerBoundThresholdFilter','lowerBoundThresholdPercentage','lowerBoundThresholdAbsolute','dataSmootherYorN','dataSmootherChoice','dataSmootherTimeRadius','dataSmootherPointRadius','dataSmootherHeadersToConfineTo','polynomialOrder','applyRawSignalThresholds','rawSignalThresholdValue','sensitivityThresholdValue','rawSignalThresholdDivider','rawSignalThresholdLimit','rawSignalThresholdLimitPercent','negativeAnalyzerYorN','NegativeAnalyzerTopNContributors','NegativeAnalyzerBaseNumberOfGridIntervals','calculateUncertaintiesInConcentrations' , 'referencePatterns_uncertainties' ,'dataToAnalyze_uncertainties', 'dataToAnalyze_uncertainties_radiusType','referenceCorrectionCoefficientsUncertainties', 'referenceCorrectionCoefficientsIonizationUncertainties' ,'solverChoice','uniqueOrCommon','slsWeighting','slsFinish','slsUniquePositiveConcentrationsOnly','objectiveFunctionType','distinguished','fullBrute','SLSUniqueExport', 'implicitSLScorrection', 'implicitSLSRecursion', 'finalOptimization', 'concentrationFinder','moleculesTSC_List','TSC_List_Type','moleculeSignalTSC_List','massNumberTSC_List','moleculeConcentrationTSC_List','unitsTSC','preProcessedDataOutputName','resolvedScaledConcentrationsOutputName','scaledConcentrationsPercentages','concentrationsOutputName','simulatedSignalsOutputName','TotalConcentrationsOutputName','ExportAtEachStep','generatePercentages','checkpoint','start','timeSinceLastCheckpoint', 'iterationNumber']