Changeset 6dbff18 in sasview for src/sas/qtgui/Perspectives/Fitting


Ignore:
Timestamp:
Sep 3, 2018 10:14:52 AM (6 years ago)
Author:
Piotr Rozyczko <rozyczko@…>
Branches:
ESS_GUI, ESS_GUI_batch_fitting, ESS_GUI_bumps_abstraction, ESS_GUI_iss1116, ESS_GUI_iss879, ESS_GUI_opencl, ESS_GUI_ordering, ESS_GUI_sync_sascalc
Children:
79bd268
Parents:
8274471e
git-author:
Piotr Rozyczko <rozyczko@…> (09/03/18 10:13:50)
git-committer:
Piotr Rozyczko <rozyczko@…> (09/03/18 10:14:52)
Message:

Restructure parameters to fit into three separate lists to enable proper processing. SASVIEW-1008

Location:
src/sas/qtgui/Perspectives/Fitting
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/sas/qtgui/Perspectives/Fitting/FittingWidget.py

    reef298d4 r6dbff18  
    226226        self.models = {} 
    227227        # Parameters to fit 
    228         self.parameters_to_fit = None 
     228        self.main_params_to_fit = [] 
     229        self.poly_params_to_fit = [] 
     230        self.magnet_params_to_fit = [] 
     231 
    229232        # Fit options 
    230233        self.q_range_min = 0.005 
     
    956959 
    957960        # Reset parameters to fit 
    958         self.parameters_to_fit = None 
     961        self.resetParametersToFit() 
    959962        self.has_error_column = False 
    960963        self.has_poly_error_column = False 
     
    980983 
    981984        # Reset parameters to fit 
    982         self.parameters_to_fit = None 
     985        self.resetParametersToFit() 
    983986        self.has_error_column = False 
    984987        self.has_poly_error_column = False 
    985988 
    986989        self.respondToModelStructure(model=model, structure_factor=structure) 
     990 
     991    def resetParametersToFit(self): 
     992        """ 
     993        Clears the list of parameters to be fitted 
     994        """ 
     995        self.main_params_to_fit = [] 
     996        self.poly_params_to_fit = [] 
     997        self.magnet_params_to_fit = [] 
    987998 
    988999    def onCustomModelChange(self): 
     
    11321143            parameter_name = parameter_name + '.width' 
    11331144            if value == QtCore.Qt.Checked: 
    1134                 self.parameters_to_fit.append(parameter_name) 
     1145                self.poly_params_to_fit.append(parameter_name) 
    11351146            else: 
    1136                 if parameter_name in self.parameters_to_fit: 
    1137                     self.parameters_to_fit.remove(parameter_name) 
    1138             self.cmdFit.setEnabled(self.parameters_to_fit != [] and self.logic.data_is_loaded) 
     1147                if parameter_name in self.poly_params_to_fit: 
     1148                    self.poly_params_to_fit.remove(parameter_name) 
     1149            self.cmdFit.setEnabled(self.haveParamsToFit()) 
    11391150 
    11401151        elif model_column in [delegate.poly_min, delegate.poly_max]: 
     
    11881199            value = item.checkState() 
    11891200            if value == QtCore.Qt.Checked: 
    1190                 self.parameters_to_fit.append(parameter_name) 
     1201                self.magnet_params_to_fit.append(parameter_name) 
    11911202            else: 
    1192                 if parameter_name in self.parameters_to_fit: 
    1193                     self.parameters_to_fit.remove(parameter_name) 
    1194             self.cmdFit.setEnabled(self.parameters_to_fit != [] and self.logic.data_is_loaded) 
     1203                if parameter_name in self.magnet_params_to_fit: 
     1204                    self.magnet_params_to_fit.remove(parameter_name) 
     1205            self.cmdFit.setEnabled(self.haveParamsToFit()) 
    11951206            # Update state stack 
    11961207            self.updateUndo() 
     
    14771488        qmin = self.q_range_min 
    14781489        qmax = self.q_range_max 
    1479         params_to_fit = self.parameters_to_fit 
     1490 
     1491        params_to_fit = self.main_params_to_fit 
     1492        if self.chkPolydispersity.isChecked(): 
     1493            params_to_fit += self.poly_params_to_fit 
     1494        if self.chkMagnetism.isChecked(): 
     1495            params_to_fit += self.magnet_params_to_fit 
    14801496        if not params_to_fit: 
    14811497            raise ValueError('Fitting requires at least one parameter to optimize.') 
     
    20462062        self._last_model_row = self._model_model.rowCount() 
    20472063 
     2064    def haveParamsToFit(self): 
     2065        """ 
     2066        Finds out if there are any parameters ready to be fitted 
     2067        """ 
     2068        return (self.main_params_to_fit!=[] 
     2069                or self.poly_params_to_fit!=[] 
     2070                or self.magnet_params_to_fit != []) and \ 
     2071                self.logic.data_is_loaded 
     2072 
    20482073    def onMainParamsChange(self, item): 
    20492074        """ 
     
    20542079        if model_column == 0: 
    20552080            self.checkboxSelected(item) 
    2056             self.cmdFit.setEnabled(self.parameters_to_fit != [] and self.logic.data_is_loaded) 
     2081            self.cmdFit.setEnabled(self.haveParamsToFit()) 
    20572082            # Update state stack 
    20582083            self.updateUndo() 
     
    21132138        # Convert to proper indices and set requested enablement 
    21142139        self.setParameterSelection(status) 
    2115         #[self._model_model.item(row, 0).setCheckState(status) for row in self.selectedParameters()] 
    21162140        self._model_model.blockSignals(False) 
    21172141 
    21182142        # update the list of parameters to fit 
    2119         main_params = self.checkedListFromModel(self._model_model) 
    2120         poly_params = self.checkedListFromModel(self._poly_model) 
    2121         magnet_params = self.checkedListFromModel(self._magnet_model) 
    2122  
    2123         # Retrieve poly params names 
    2124         poly_params = [param.rsplit()[-1] + '.width' for param in poly_params] 
    2125  
    2126         self.parameters_to_fit = main_params + poly_params + magnet_params 
     2143        self.main_params_to_fit = self.checkedListFromModel(self._model_model) 
    21272144 
    21282145    def checkedListFromModel(self, model): 
     
    27522769 
    27532770        fp.chi2 = self.chi2 
    2754         fp.parameters_to_fit = self.parameters_to_fit 
     2771        fp.main_params_to_fit = self.main_params_to_fit 
     2772        fp.poly_params_to_fit = self.poly_params_to_fit 
     2773        fp.magnet_params_to_fit = self.magnet_params_to_fit 
    27552774        fp.kernel_module = self.kernel_module 
    27562775 
  • src/sas/qtgui/Perspectives/Fitting/UnitTesting/FittingWidgetTest.py

    r3f5b901 r6dbff18  
    420420        #QtWidgets.QApplication(sys.argv).exec_() 
    421421 
    422  
    423422        # Set the checbox 
    424423        self.widget._poly_model.item(0,0).setCheckState(2) 
    425424        # Assure the parameter is added 
    426         self.assertEqual(self.widget.parameters_to_fit, ['radius_bell.width']) 
     425        self.assertEqual(self.widget.poly_params_to_fit, ['radius_bell.width']) 
    427426 
    428427        # Add another parameter 
    429428        self.widget._poly_model.item(2,0).setCheckState(2) 
    430429        # Assure the parameters are added 
    431         self.assertEqual(self.widget.parameters_to_fit, ['radius_bell.width', 'length.width']) 
     430        self.assertEqual(self.widget.poly_params_to_fit, ['radius_bell.width', 'length.width']) 
    432431 
    433432        # Change the min/max values 
     
    683682 
    684683        # Test no fitting params 
    685         self.widget.parameters_to_fit = [] 
     684        self.widget.main_params_to_fit = [] 
    686685 
    687686        logging.error = MagicMock() 
     
    709708 
    710709        # Test no fitting params 
    711         self.widget.parameters_to_fit = [] 
     710        self.widget.main_params_to_fit = [] 
    712711 
    713712        logging.error = MagicMock() 
     
    735734 
    736735        # Assing fitting params 
    737         self.widget.parameters_to_fit = ['scale'] 
     736        self.widget.main_params_to_fit = ['scale'] 
    738737 
    739738        # Spying on status update signal 
     
    748747 
    749748            # the fit button changed caption and got disabled 
    750             self.assertEqual(self.widget.cmdFit.text(), 'Stop fit') 
    751             self.assertFalse(self.widget.cmdFit.isEnabled()) 
     749            # could fail if machine fast enough to finish 
     750            #self.assertEqual(self.widget.cmdFit.text(), 'Stop fit') 
     751            #self.assertFalse(self.widget.cmdFit.isEnabled()) 
    752752 
    753753            # Signal pushed up 
     
    779779 
    780780        # Assing fitting params 
    781         self.widget.parameters_to_fit = ['scale'] 
     781        self.widget.main_params_to_fit = ['scale'] 
    782782 
    783783        # Spying on status update signal 
     
    792792 
    793793            # the fit button changed caption and got disabled 
    794             self.assertEqual(self.widget.cmdFit.text(), 'Stop fit') 
    795             self.assertFalse(self.widget.cmdFit.isEnabled()) 
     794            #self.assertEqual(self.widget.cmdFit.text(), 'Stop fit') 
     795            #self.assertFalse(self.widget.cmdFit.isEnabled()) 
    796796 
    797797            # Signal pushed up 
     
    857857        category_index = self.widget.cbCategory.findText('Sphere') 
    858858        self.widget.cbCategory.setCurrentIndex(category_index) 
    859         self.widget.parameters_to_fit = ['scale'] 
     859        self.widget.main_params_to_fit = ['scale'] 
    860860        # Invoke the tested method 
    861861        fp = self.widget.currentState() 
     
    905905 
    906906        # Test no fitting params 
    907         self.widget.parameters_to_fit = ['scale'] 
     907        self.widget.main_params_to_fit = ['scale'] 
    908908 
    909909        # Invoke the tested method 
     
    943943        category_index = self.widget.cbCategory.findText("Sphere") 
    944944        self.widget.cbCategory.setCurrentIndex(category_index) 
    945         self.widget.parameters_to_fit = ['scale'] 
     945        self.widget.main_params_to_fit = ['scale'] 
    946946 
    947947        # Invoke the tested method 
     
    954954        self.assertEqual(fp.current_category, "Sphere") 
    955955        self.assertEqual(fp.current_model, "adsorbed_layer") 
    956         self.assertListEqual(fp.parameters_to_fit, ['scale']) 
     956        self.assertListEqual(fp.main_params_to_fit, ['scale']) 
    957957 
    958958    def testPushFitPage(self): 
     
    974974        self.widget.undo_supported = True 
    975975        self.widget.cbCategory.setCurrentIndex(category_index) 
    976         self.widget.parameters_to_fit = ['scale'] 
     976        self.widget.main_params_to_fit = ['scale'] 
    977977 
    978978        # Check that the stack is updated 
Note: See TracChangeset for help on using the changeset viewer.