Changeset 87dfca4 in sasview


Ignore:
Timestamp:
May 23, 2018 3:40:53 AM (7 months ago)
Author:
Piotr Rozyczko <rozyczko@…>
Branches:
ESS_GUI, ESS_GUI_Invariant, ESS_GUI_Pr_fixes, ESS_GUI_batch_fitting, ESS_GUI_iss879, ESS_GUI_iss959, ESS_GUI_ordering
Children:
c03692f
Parents:
db7d2c7
Message:

Fixed a bug where weighting options would not correctly update on data load

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

Legend:

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

    rd6e38661 r87dfca4  
    1616        self._data = data 
    1717        self.data_is_loaded = False 
     18        #dq data presence in the dataset 
     19        self.dq_flag = False 
     20        #di data presence in the dataset 
     21        self.di_flag = False 
    1822        if data is not None: 
    1923            self.data_is_loaded = True 
     24            self.setDataProperties() 
    2025 
    2126    @property 
     
    2833        self._data = value 
    2934        self.data_is_loaded = True 
     35        self.setDataProperties() 
    3036 
    3137    def isLoadedData(self): 
    3238        """ accessor """ 
    3339        return self.data_is_loaded 
     40 
     41    def setDataProperties(self): 
     42        """ 
     43        Analyze data and set up some properties important for 
     44        the Presentation layer 
     45        """ 
     46        if self._data.__class__.__name__ == "Data2D": 
     47            if self._data.err_data is not None and np.any(self._data.err_data): 
     48                self.di_flag = True 
     49            if self._data.dqx_data is not None and np.any(self._data.dqx_data): 
     50                self.dq_flag = True 
     51        else: 
     52            if self._data.dy is not None and np.any(self._data.dy): 
     53                self.di_flag = True 
     54            if self._data.dx is not None and np.any(self._data.dx): 
     55                self.dq_flag = True 
     56            elif self._data.dxl is not None and np.any(self._data.dxl): 
     57                self.dq_flag = True 
    3458 
    3559    def createDefault1dData(self, interval, tab_id=0): 
  • src/sas/qtgui/Perspectives/Fitting/FittingWidget.py

    r57be490 r87dfca4  
    177177 
    178178        # Create logics with data items 
    179         self._logic=[] 
    180179        # Logics.data contains only a single Data1D/Data2D object 
    181         for data_item in value: 
    182             self._logic.append(FittingLogic()) 
    183             self._logic[-1].data = GuiUtils.dataFromItem(data_item) 
     180        if len(value) == 1: 
     181            # single data logic is already defined, update data on it 
     182            self._logic[0].data = GuiUtils.dataFromItem(value[0]) 
     183        else: 
     184            # batch datasets 
     185            for data_item in value: 
     186                logic = FittingLogic(data=GuiUtils.dataFromItem(data_item)) 
     187                self._logic.append(logic) 
    184188 
    185189        # Overwrite data type descriptor 
  • src/sas/qtgui/Perspectives/Fitting/OptionsWidget.py

    r976978b r87dfca4  
    163163        self.chkLogData.setEnabled(False) 
    164164        # Weighting controls 
    165         if isinstance(self.logic.data, Data2D): 
    166             if self.logic.data.err_data is None or\ 
    167                     np.all(err == 1 for err in self.logic.data.err_data) or \ 
    168                     not np.any(self.logic.data.err_data): 
    169                 self.rbWeighting2.setEnabled(False) 
    170                 self.rbWeighting1.setChecked(True) 
    171             else: 
    172                 self.rbWeighting2.setEnabled(True) 
    173                 self.rbWeighting2.setChecked(True) 
     165        if self.logic.di_flag: 
     166            self.rbWeighting2.setEnabled(True) 
     167            self.rbWeighting2.setChecked(True) 
    174168        else: 
    175             if self.logic.data.dy is None or\ 
    176                     np.all(self.logic.data.dy == 1) or\ 
    177                     not np.any(self.logic.data.dy): 
    178                 self.rbWeighting2.setEnabled(False) 
    179                 self.rbWeighting1.setChecked(True) 
    180             else: 
    181                 self.rbWeighting2.setEnabled(True) 
    182                 self.rbWeighting2.setChecked(True) 
     169            self.rbWeighting2.setEnabled(False) 
     170            self.rbWeighting1.setChecked(True) 
    183171 
    184172    def updateQRange(self, q_range_min, q_range_max, npts): 
Note: See TracChangeset for help on using the changeset viewer.