source: sasview/sansview/perspectives/fitting/fitpanel.py @ 8346667

ESS_GUIESS_GUI_DocsESS_GUI_batch_fittingESS_GUI_bumps_abstractionESS_GUI_iss1116ESS_GUI_iss879ESS_GUI_iss959ESS_GUI_openclESS_GUI_orderingESS_GUI_sync_sascalccostrafo411magnetic_scattrelease-4.1.1release-4.1.2release-4.2.2release_4.0.1ticket-1009ticket-1094-headlessticket-1242-2d-resolutionticket-1243ticket-1249ticket885unittest-saveload
Last change on this file since 8346667 was 6e659ae8, checked in by Gervaise Alina <gervyh@…>, 15 years ago

fix a small bug on fitting with error zero

  • Property mode set to 100644
File size: 9.4 KB
Line 
1import wx
2import wx.aui
3import wx.lib
4import numpy
5import string ,re
6#import models
7_BOX_WIDTH = 80
8
9(FitPageEvent, EVT_FIT_PAGE)   = wx.lib.newevent.NewEvent()
10class FitPanel(wx.aui.AuiNotebook):   
11#class FitPanel(wx.aui.AuiNotebook,wx.panel):
12    """
13        FitPanel class contains fields allowing to fit  models and  data
14        @note: For Fit to be performed the user should check at least one parameter
15        on fit Panel window.
16       
17    """
18    ## Internal name for the AUI manager
19    window_name = "Fit panel"
20    ## Title to appear on top of the window
21    window_caption = "Fit Panel "
22    CENTER_PANE = True
23    def __init__(self, parent, *args, **kwargs):
24       
25        wx.aui.AuiNotebook.__init__(self,parent,-1, style=wx.aui.AUI_NB_SCROLL_BUTTONS )
26        #wx.aui.AuiNotebook.__init__(self,parent,-1, style=wx.aui.AUI_NB_DEFAULT_STYLE  )
27       
28       
29        self.manager=None
30        self.parent=parent
31        self.event_owner=None
32       
33        pageClosedEvent = wx.aui.EVT_AUINOTEBOOK_PAGE_CLOSE
34        self.Bind(wx.aui.EVT_AUINOTEBOOK_PAGE_CLOSE, self.onClosePage)
35        #Creating the default page --welcomed page
36        from sans.guiframe.welcome_panel import PanelAbout
37        self.about_page = PanelAbout(self, -1)
38        self.AddPage(self.about_page,"welcome!")
39        #self.about_page.Disable()
40        #Creating a page for simultaneous fitting
41        from simfitpage import SimultaneousFitPage
42        self.sim_page = SimultaneousFitPage(self, id=-1)
43        self.AddPage(self.sim_page,"Simultaneous Fit")
44       
45        self._mgr = self.GetAuiManager()
46
47       
48        #dictionary of miodel {model class name, model class}
49        self.model_list_box={}
50        # save the title of the last page tab added
51        self.fit_page_name=[]
52        self.draw_model_name=None
53        #model page info
54        self.model_page_number=None
55       
56        self.model_page=None
57        # increment number for model name
58        self.count=0
59        #updating the panel
60        self.Update()
61        self.Center()
62       
63       
64    def onClosePage(self, event):
65        self.ToggleWindowStyle(wx.aui.AUI_NB_CLOSE_ON_ACTIVE_TAB)
66        #print "went here",self.get_current_page(), self.GetPage(0)
67        #event.Skip()
68        if self.GetPageCount() <= 2:
69            #print "wente here"
70           
71            # Prevent last tab from being closed
72            self.ToggleWindowStyle(~wx.aui.AUI_NB_CLOSE_ON_ACTIVE_TAB)
73           
74
75   
76
77
78       
79    def set_manager(self, manager):
80        """
81             set panel manager
82             @param manager: instance of plugin fitting
83        """
84        self.manager = manager
85        self.sim_page.set_manager(manager)
86       
87    def set_owner(self,owner):
88        """
89            set and owner for fitpanel
90            @param owner: the class responsible of plotting
91        """
92        self.event_owner=owner
93     
94       
95    def add_fit_page( self,data ):
96        """
97            Add a fitting page on the notebook contained by fitpanel
98            @param panel: contains in the page to add
99            @param name: title of the page tab
100            @return panel : page just added for futher used. is used by fitting module
101        """     
102        try:
103            name = data.name # item in Data1D
104        except:
105            name = 'Fit'
106       
107        #if self.fit_page_name != name and self.draw_model_name !=name:
108        if not name in self.fit_page_name :
109            #self.about_page.Disable()
110            from fitpage1D import FitPage1D
111            panel = FitPage1D(self,data, -1)
112            panel.name=name
113            #m_name= "M"+str(self.count) 
114            panel.set_manager(self.manager)
115            panel.set_owner(self.event_owner)
116           
117            self.AddPage(page=panel,caption=name,select=True)
118            panel.populate_box( self.model_list_box)
119            self.fit_page_name.append(name)
120   
121            return panel #,m_name
122        else:
123            return None #, None
124       
125    def _help_add_model_page(self,model,description,page_title, qmin=0, qmax=0.1, npts=50):
126        """
127            #TODO: fill in description
128           
129            @param qmin: mimimum Q
130            @param qmax: maximum Q
131            @param npts: number of Q points
132        """
133        from modelpage import ModelPage
134        #print "fitpanel model", model
135        panel = ModelPage(self,model,page_title, -1)
136        panel.set_manager(self.manager)
137        panel.set_owner(self.event_owner)
138        self.AddPage(page=panel,caption="Model",select=True)
139        panel.populate_box( self.model_list_box)
140        panel.name = page_title
141        self.draw_model_name=page_title
142        self.model_page_number=self.GetSelection()
143        self.model_page=self.GetPage(self.GetSelection())
144       
145       
146        # Set the range used to plot models
147        self.model_page.set_range(qmin, qmax, npts)
148       
149        # We just created a model page, we are ready to plot the model
150        #self.manager.draw_model(model, model.name)
151        #FOR PLUGIN  for somereason model.name is = BASEcomponent
152        self.manager.draw_model(model, page_title)
153       
154       
155    def add_model_page(self,model,description,page_title, qmin=0, qmax=0.1, npts=50, topmenu=False):
156        """
157            Add a model page only one  to display any model selected from the menu or the page combo box.
158            when this page is closed than the user will be able to open a new one
159           
160            @param model: the model for which paramters will be changed
161            @param page_title: the name of the page
162            @param description: [Coder: fill your description!]
163            @param page_title: [Coder: fill your description!]
164            @param qmin: mimimum Q
165            @param qmax: maximum Q
166            @param npts: number of Q points
167        """
168        print "self.draw_model_name none",self.draw_model_name
169        if topmenu==True:
170            if  self.draw_model_name ==None:
171                print "self.draw_model_name none"
172                self._help_add_model_page(model,description,page_title, qmin=qmin, qmax=qmax, npts=npts)
173            else:
174                #self.model_page.name=page_title
175                #self.draw_model_name=page_title
176                #print "wnent here self.draw_model_name ",self.draw_model_name,self.model_page.name,self.model_page
177               
178                self.model_page.select_model(model, page_title)
179         
180    def get_current_page(self):
181        """
182            @return the current page selected
183        """
184        #return self.nb.GetCurrentPage()
185        return self.GetPage(self.GetSelection() )
186 
187   
188    def onClose(self, page=None,page_number=None):
189        """
190             close the current page except the simpage. remove each check box link to the model
191             selected on that page. remove its reference into page_finder (fitting module)
192        """
193        print "model page", page_number, page, self.draw_model_name
194        if page!=None and page_number!=None:
195            i=self.DeletePage(page_number)
196            #self.nb.RemovePage(page_number)
197            #page.Destroy()
198            self.model_page_number=None
199            self.model_page=None
200            self.draw_model_name=None
201            print"self.draw_model_name",self.draw_model_name
202            return 
203        try:
204            sim_page = self.GetPage(1)
205            selected_page = self.GetPage(self.GetSelection())
206            #print "sim_page ",sim_page ,selected_page
207            if sim_page != selected_page:
208                #print "sim_page ",sim_page ,selected_page
209                # remove the check box link to the model name of this page (selected_page)
210                sim_page.remove_model(selected_page)
211                #remove that page from page_finder of fitting module
212                page_finder=self.manager.get_page_finder() 
213                for page, value in page_finder.iteritems():
214                    if page==selected_page:
215                        del page_finder[page]
216                        break
217                #Delete the page from notebook
218                page_number = self.GetSelection()
219                #print "on close",selected_page.name,self.GetPageText(page_number),self.draw_model_name
220               
221                if selected_page.name in self.fit_page_name:
222                    self.fit_page_name.remove(selected_page.name)
223                   
224                if selected_page.name== self.draw_model_name:
225                    #print "went here"
226                    self.draw_model_name=None
227                    self.model_page=None
228                if  page_number == 1:
229                    self.model_page=None
230                    self.draw_model_name=None
231                #selected_page.Destroy()
232                #self.RemovePage(page_number)
233                i=self.DeletePage(page_number)
234                #self.count =self.count -1
235               
236        except:
237            raise
238        #print "fitpanel", self.draw_model_name
239       
240    def set_model_list(self,dict):
241         """
242             copy a dictionary of model into its own dictionary
243             @param dict: dictionnary made of model name as key and model class
244             as value
245         """
246         self.model_list_box = dict
247 
Note: See TracBrowser for help on using the repository browser.