source: sasview/fittingview/src/sans/perspectives/fitting/simfitpage.py @ 4133316

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 4133316 was 4133316, checked in by Jae Cho <jhjcho@…>, 13 years ago

solved the updating problem due to changes in fitpages after the simulpage created.

  • Property mode set to 100644
File size: 24.8 KB
RevLine 
[d89f09b]1
[2140e68]2import sys,re,string, wx 
3import wx.lib.newevent 
[4ce74917]4from sans.guiframe.events import StatusEvent
[4bd492f]5from sans.guiframe.panel_base import PanelBase
6from wx.lib.scrolledpanel import ScrolledPanel
[c99a6c5]7#Control panel width
[6e9976b]8if sys.platform.count("darwin")==0:
[c99a6c5]9    PANEL_WID = 420
[f1aa385]10    FONT_VARIANT = 0
[c99a6c5]11else:
12    PANEL_WID = 490
[f1aa385]13    FONT_VARIANT = 1
[8bd4dc0]14           
15def get_fittableParam( model):
[2140e68]16    """
[5062bbf]17    return list of fittable parameters name of a model
18   
19    :param model: the model used
20   
[2140e68]21    """
[8bd4dc0]22    fittable_param=[]
23   
24    for item in model.getParamList():
25        if not item  in model.getDispParamList():
[fb59ed9]26            if not item in model.non_fittable:
27                fittable_param.append(item)
[8bd4dc0]28           
29    for item in model.fixed:
30        fittable_param.append(item)
[2140e68]31       
[8bd4dc0]32    return fittable_param
[2140e68]33
[4bd492f]34class SimultaneousFitPage(ScrolledPanel, PanelBase):
[d89f09b]35    """
[5062bbf]36    Simultaneous fitting panel
37    All that needs to be defined are the
38    two data members window_name and window_caption
[d89f09b]39    """
[925a30e]40    ## Internal name for the AUI manager
[d89f09b]41    window_name = "simultaneous Fit page"
42    ## Title to appear on top of the window
43    window_caption = "Simultaneous Fit Page"
44   
45   
[2140e68]46    def __init__(self, parent,page_finder ={}, *args, **kwargs):
[4bd492f]47        ScrolledPanel.__init__(self, parent,style= wx.FULL_REPAINT_ON_RESIZE )
48        PanelBase.__init__(self, parent)
[d89f09b]49        """
[5062bbf]50        Simultaneous page display
[d89f09b]51        """
[f1aa385]52        ##Font size
53        self.SetWindowVariant(variant = FONT_VARIANT)
[922497f]54        self.uid = wx.NewId()
[d89f09b]55        self.parent = parent
[2140e68]56        ## store page_finder
[b28717b]57        self.page_finder = page_finder
[2140e68]58        ## list contaning info to set constraint
[6bbeacd4]59        ## look like self.constraint_dict[page_id]= page
[2140e68]60        self.constraint_dict={}
61        ## item list  self.constraints_list=[combobox1, combobox2,=,textcrtl, button ]
62        self.constraints_list=[]
63        ## list of current model
64        self.model_list=[]
65        ## selected mdoel to fit
66        self.model_toFit=[]
[b28717b]67        ## number of constraint
68        self.nb_constraint= 0
[dc613d6]69        self.uid = wx.NewId()
[b28717b]70        ## draw page
[2140e68]71        self.define_page_structure()
[b28717b]72        self.draw_page()
[2140e68]73        self.set_layout()
74       
75    def define_page_structure(self):
76        """
[5062bbf]77        Create empty sizer for a panel
[2140e68]78        """
[d89f09b]79        self.vbox  = wx.BoxSizer(wx.VERTICAL)
[2140e68]80        self.sizer1 = wx.BoxSizer(wx.VERTICAL)
81        self.sizer2 = wx.BoxSizer(wx.VERTICAL)
[8bd4dc0]82        self.sizer3 = wx.BoxSizer(wx.VERTICAL)
[c99a6c5]83
84        self.sizer1.SetMinSize((PANEL_WID,-1))
85        self.sizer2.SetMinSize((PANEL_WID,-1))
86        self.sizer3.SetMinSize((PANEL_WID,-1))
[d89f09b]87        self.vbox.Add(self.sizer1)
88        self.vbox.Add(self.sizer2)
[8bd4dc0]89        self.vbox.Add(self.sizer3)
[51d47b5]90       
[2140e68]91    def set_scroll(self):
[5062bbf]92        """
93        """
[c99a6c5]94        self.SetScrollbars(20,20,25,65)
[2140e68]95        self.Layout() 
96         
97    def set_layout(self):
98        """
[5062bbf]99        layout
[2140e68]100        """
[d89f09b]101        self.vbox.Layout()
102        self.vbox.Fit(self) 
103        self.SetSizer(self.vbox)
[2140e68]104        self.set_scroll()
[d89f09b]105        self.Centre()
106       
[8bd4dc0]107    def onRemove(self, event):
108        """
[5062bbf]109        Remove constraint fields
[8bd4dc0]110        """
[a911b48]111        if len(self.constraints_list)==1:
112            self.hide_constraint.SetValue(True)
113            self._hide_constraint()
114            return 
115        if len(self.constraints_list)==0:
[8bd4dc0]116            return 
117        for item in self.constraints_list:
118            length= len(item)
119            if event.GetId()==item[length-2].GetId():
120                sizer= item[length-1]
[bb7d8a4]121                sizer.Clear(True)
[8bd4dc0]122                self.sizer_constraints.Remove(sizer)
[998b6b8]123             
[8bd4dc0]124                self.sizer2.Layout()
[c99a6c5]125                self.SetScrollbars(20,20,25,65)
[8bd4dc0]126                self.constraints_list.remove(item)
127                self.nb_constraint -= 1
128                break
129               
[922497f]130    def onFit(self, event):
[5062bbf]131        """
132        signal for fitting
133       
134        """
[2140e68]135        ## making sure all parameters content a constraint
136        ## validity of the constraint expression is own by fit engine
[ac11e40]137        if self.show_constraint.GetValue():
138            self._set_constraint()
[2140e68]139        ## model was actually selected from this page to be fit
[3215d32]140        if len(self.model_toFit) >= 1 :
[66ff250]141            self.manager._reset_schedule_problem(value=0)
[6f023e8]142            for item in self.model_list:
143                if item[0].GetValue():
[c647377]144                    self.manager.schedule_for_fit(value=1, uid=item[2]) 
[922497f]145            self.manager.onFit(uid=self.uid)
[1b07935d]146        else:
[2140e68]147            msg= "Select at least one model to fit "
[c647377]148            wx.PostEvent(self.parent.Parent, StatusEvent(status=msg))
[f343069]149           
[d89f09b]150    def set_manager(self, manager):
151        """
[5062bbf]152        set panel manager
153       
154        :param manager: instance of plugin fitting
155       
[d89f09b]156        """
157        self.manager = manager
[b28717b]158       
[2140e68]159    def check_all_model_name(self,event):
[d89f09b]160        """
[5062bbf]161        check all models names
[d89f09b]162        """
[6bbeacd4]163        self.model_toFit = [] 
164        if self.cb1.GetValue()== True:
[d89f09b]165            for item in self.model_list:
[6c08ba5]166                if item[0].IsEnabled():
167                    item[0].SetValue(True)
168                    self.model_toFit.append(item)
[2140e68]169               
170            ## constraint info
171            self._store_model()
172            ## display constraint fields
173            if self.show_constraint.GetValue():
174                self._show_constraint()
175                return
[d89f09b]176        else:
177            for item in self.model_list:
178                item[0].SetValue(False) 
[948add7]179               
[d89f09b]180            self.model_toFit=[]
[2140e68]181            ##constraint info
182            self._hide_constraint()
[925a30e]183       
[2140e68]184    def check_model_name(self,event):
[d89f09b]185        """
[5062bbf]186        Save information related to checkbox and their states
[d89f09b]187        """
188        self.model_toFit=[]
189        for item in self.model_list:
190            if item[0].GetValue()==True:
191                self.model_toFit.append(item)
192            else:
193                if item in self.model_toFit:
194                    self.model_toFit.remove(item)
195                    self.cb1.SetValue(False)
[b28717b]196       
[2140e68]197        ## display constraint fields
[b28717b]198        if len(self.model_toFit)==2:
[2140e68]199            self._store_model()
[b28717b]200            if self.show_constraint.GetValue() and len(self.constraints_list)==0:
[2140e68]201                self._show_constraint()
[b28717b]202        elif len(self.model_toFit)< 2:
203            ##constraint info
204            self._hide_constraint()             
[2140e68]205       
206        ## set the value of the main check button         
[d89f09b]207        if len(self.model_list)==len(self.model_toFit):
208            self.cb1.SetValue(True)
[b28717b]209            return
[d89f09b]210        else:
211            self.cb1.SetValue(False)
[948add7]212       
[b28717b]213    def draw_page(self):     
[2140e68]214        """
[5062bbf]215        Draw a sizer containing couples of data and model
[b28717b]216        """ 
[2140e68]217        self.model_list=[]
218        self.model_toFit=[]
[8bd4dc0]219        self.constraints_list=[]
[1d2782d]220        self.constraint_dict={}
221        self.nb_constraint= 0
222       
[2140e68]223        if len(self.model_list)>0:
224            for item in self.model_list:
225                item[0].SetValue(False) 
[c647377]226                self.manager.schedule_for_fit(value=0, uid=item[2])
[2140e68]227               
[5062bbf]228        self.sizer1.Clear(True)   
[8bd4dc0]229        box_description= wx.StaticBox(self, -1,"Fit Combinations")
[2140e68]230        boxsizer1 = wx.StaticBoxSizer(box_description, wx.VERTICAL)
231        sizer_title = wx.BoxSizer(wx.HORIZONTAL)
232        sizer_couples = wx.GridBagSizer(5,5)
233        #------------------------------------------------------
234        if len(self.page_finder)==0:
[2296316]235            msg = " No fit combinations are found! \n\n"
236            msg += " Please load data and set up at least two fit panels first..."
237            sizer_title.Add(wx.StaticText(self, -1, msg))
[2140e68]238        else:
239            ## store model 
240            self._store_model()
241       
[8bd4dc0]242            self.cb1 = wx.CheckBox(self, -1,'Select all')
[2140e68]243            self.cb1.SetValue(False)
244            wx.EVT_CHECKBOX(self, self.cb1.GetId(), self.check_all_model_name)
245           
[8bd4dc0]246            sizer_title.Add((10,10),0,
247                wx.TOP|wx.BOTTOM|wx.EXPAND|wx.ADJUST_MINSIZE,border=5)
248            sizer_title.Add(self.cb1,0,
249                wx.TOP|wx.BOTTOM|wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE,border=5)
250           
251            ## draw list of model and data name
[2140e68]252            self._fill_sizer_model_list(sizer_couples)
253            ## draw the sizer containing constraint info
254            self._fill_sizer_constraint()
[8bd4dc0]255            ## draw fit button
256            self._fill_sizer_fit()
[2140e68]257        #--------------------------------------------------------
[8bd4dc0]258        boxsizer1.Add(sizer_title, flag= wx.TOP|wx.BOTTOM,border=5) 
259        boxsizer1.Add(sizer_couples, flag= wx.TOP|wx.BOTTOM,border=5)
[2140e68]260       
[8bd4dc0]261        self.sizer1.Add(boxsizer1,1, wx.EXPAND | wx.ALL, 10)
[2140e68]262        self.sizer1.Layout()
[c99a6c5]263        self.SetScrollbars(20,20,25,65)
[2140e68]264        self.AdjustScrollbars()
265       
266    def _store_model(self):
[d89f09b]267        """
[5062bbf]268         Store selected model
[d89f09b]269        """
[2140e68]270        if len(self.model_toFit) < 2:
271            return
[1d2782d]272        for item in self.model_toFit:
273            model = item[3]
[6bbeacd4]274            page_id= item[2]
275            self.constraint_dict[page_id] = model
[2140e68]276                   
277    def _display_constraint(self, event):
278        """
[5062bbf]279        Show fields to add constraint
[2140e68]280        """
281        if len(self.model_toFit)< 2:
282            msg= "Select at least 2 models to add constraint "
283            wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
284            ## hide button
285            self._hide_constraint()
286            return
287        if self.show_constraint.GetValue():
288            self._show_constraint()
289            return
290        else:
291           self._hide_constraint()
292           return 
293           
294    def _show_constraint(self):
295        """
[5062bbf]296        Show constraint fields
[2140e68]297        """
[77e23a2]298        self.btAdd.Show(True)
[2140e68]299        if len(self.constraints_list)!= 0:
300            nb_fit_param = 0
[1d2782d]301            for model in self.constraint_dict.values():
[8bd4dc0]302                nb_fit_param += len(get_fittableParam(model))
[2140e68]303            ##Don't add anymore
304            if len(self.constraints_list) == nb_fit_param:
[ac11e40]305                msg= "Cannot add another constraint .Maximum of number "
306                msg += "Parameters name reached %s"%str(nb_fit_param)
307                wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
[b28717b]308                self.sizer_constraints.Layout()
[ac11e40]309                self.sizer2.Layout()
[c99a6c5]310                self.SetScrollbars(20,20,25,65)
[ac11e40]311                return
312           
313        if len(self.model_toFit) < 2 :
[2140e68]314            msg= "Select at least 2 model to add constraint "
315            wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
[b28717b]316            self.sizer_constraints.Layout()
[2140e68]317            self.sizer2.Layout()
[c99a6c5]318            self.SetScrollbars(20,20,25,65)
[2140e68]319            return
320           
321        sizer_constraint =  wx.BoxSizer(wx.HORIZONTAL)
[8bd4dc0]322        model_cbox = wx.ComboBox(self, -1,style=wx.CB_READONLY)
[2140e68]323        model_cbox.Clear()
[8bd4dc0]324        param_cbox = wx.ComboBox(self, -1,style=wx.CB_READONLY)
[b28717b]325        param_cbox.Hide()
[8dfe0fd]326       
327        #This is for GetCLientData() _on_select_param: Was None return on MAC.
328        self.param_cbox = param_cbox
329       
[2140e68]330        wx.EVT_COMBOBOX(param_cbox,-1, self._on_select_param)
331        ctl2 = wx.TextCtrl(self, -1)
332        egal_txt= wx.StaticText(self,-1," = ")
[8bd4dc0]333        btRemove = wx.Button(self,wx.NewId(),'Remove')
334        btRemove.Bind(wx.EVT_BUTTON, self.onRemove,id= btRemove.GetId())
335        btRemove.SetToolTipString("Remove constraint.")
[2140e68]336       
[6bbeacd4]337        for id,model in self.constraint_dict.iteritems():
[2140e68]338            ## check if all parameters have been selected for constraint
339            ## then do not allow add constraint on parameters
[ac11e40]340            model_cbox.Append( str(model.name), model)
[2140e68]341           
[8dfe0fd]342        #This is for GetCLientData() passing to self._on_select_param: Was None return on MAC.
343        self.model_cbox = model_cbox
[2140e68]344           
345        wx.EVT_COMBOBOX(model_cbox,-1, self._on_select_model)
[5062bbf]346   
[b28717b]347        sizer_constraint.Add(model_cbox, flag= wx.RIGHT|wx.EXPAND,border=10)
348        sizer_constraint.Add(param_cbox, flag= wx.RIGHT|wx.EXPAND,border=5)
349        sizer_constraint.Add(egal_txt, flag= wx.RIGHT|wx.EXPAND,border=5)
350        sizer_constraint.Add(ctl2, flag= wx.RIGHT|wx.EXPAND,border=10)
[8bd4dc0]351        sizer_constraint.Add(btRemove, flag= wx.RIGHT|wx.EXPAND,border=10)
[b28717b]352     
353        self.sizer_constraints.Insert(before=self.nb_constraint,
354                                      item=sizer_constraint, flag= wx.TOP|wx.BOTTOM|wx.EXPAND,
[8bd4dc0]355                                   border=5)
356        ##[combobox1, combobox2,=,textcrtl, remove button ]
357        self.constraints_list.append([model_cbox, param_cbox, egal_txt, ctl2,btRemove,sizer_constraint])
[5062bbf]358   
[b28717b]359        self.nb_constraint += 1
360        self.sizer_constraints.Layout()
[2140e68]361        self.sizer2.Layout()
[c99a6c5]362        self.SetScrollbars(20,20,25,65)
[2140e68]363       
364    def _hide_constraint(self): 
365        """
[5062bbf]366        hide buttons related constraint
[ac11e40]367        """ 
[6bbeacd4]368        for id in  self.page_finder.iterkeys():
369            self.page_finder[id].clear_model_param()
[b28717b]370               
371        self.nb_constraint =0     
[ac11e40]372        self.constraint_dict={}
[69bee6d]373        if hasattr(self,"btAdd"):
374            self.btAdd.Hide()
[ac11e40]375        self._store_model()
[2140e68]376        self.constraints_list=[]         
[b28717b]377        self.sizer_constraints.Clear(True) 
378        self.sizer_constraints.Layout()   
[2140e68]379        self.sizer2.Layout()
[c99a6c5]380        self.SetScrollbars(20,20,25,65)
[2140e68]381        self.AdjustScrollbars()   
[5062bbf]382           
[2140e68]383    def _on_select_model(self, event):
384        """
[5062bbf]385        fill combox box with list of parameters
[2140e68]386        """
[8dfe0fd]387        ##This way PC/MAC both work, instead of using event.GetClientData().
388        n = self.model_cbox.GetCurrentSelection()
389        model = self.model_cbox.GetClientData(n)
390       
[8bd4dc0]391        param_list= get_fittableParam(model)
[2140e68]392        length = len(self.constraints_list)
393        if length < 1:
394            return 
395        param_cbox = self.constraints_list[length-1][1]
396        param_cbox.Clear()
397        ## insert only fittable paramaters
398        for param in param_list:
[ac11e40]399            param_cbox.Append( str(param), model)
400           
[2140e68]401        param_cbox.Show(True)
402        self.sizer2.Layout()
[c99a6c5]403        self.SetScrollbars(20,20,25,65)
[2140e68]404       
405    def _on_select_param(self, event):
406        """
[5062bbf]407        Store the appropriate constraint in the page_finder
[2140e68]408        """
[8dfe0fd]409        ##This way PC/MAC both work, instead of using event.GetClientData().
410        n = self.param_cbox.GetCurrentSelection()
411        model = self.param_cbox.GetClientData(n)
[2140e68]412        param = event.GetString()
[ac11e40]413     
[2140e68]414        length = len(self.constraints_list)
415        if length < 1:
416            return 
417        egal_txt = self.constraints_list[length-1][2]
418        egal_txt.Show(True)       
419       
420        ctl2 = self.constraints_list[length-1][3]
421        ctl2.Show(True)
[6e9976b]422        #self.sizer2.Layout()
[c99a6c5]423        self.SetScrollbars(20,20,25,65)
[2140e68]424       
425    def _onAdd_constraint(self, event): 
426        """
[5062bbf]427        Add another line for constraint
[2140e68]428        """
[8bd4dc0]429        if not self.show_constraint.GetValue():
430            msg= " Select Yes to add Constraint "
431            wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
432            return 
[2140e68]433        ## check that a constraint is added before allow to add another cosntraint
434        for item in self.constraints_list:
435            model_cbox = item[0]
436            if model_cbox.GetString(0)=="":
437                msg= " Select a model Name! "
438                wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
439                return 
440            param_cbox = item[1]
441            if param_cbox.GetString(0)=="":
442                msg= " Select a parameter Name! "
443                wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
444                return 
445            ctl2 = item[3]
446            if ctl2.GetValue().lstrip().rstrip()=="":
[b28717b]447                model= param_cbox.GetClientData(param_cbox.GetCurrentSelection())
448                msg= " Enter a constraint for %s.%s! "%(model.name,param_cbox.GetString(0))           
449                wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
450                return 
[2140e68]451        ## some model or parameters can be constrained
452        self._show_constraint()
453       
[8bd4dc0]454    def _fill_sizer_fit(self):
455        """
[5062bbf]456        Draw fit button
[8bd4dc0]457        """
458        self.sizer3.Clear(True)
459        box_description= wx.StaticBox(self, -1,"Fit ")
460        boxsizer1 = wx.StaticBoxSizer(box_description, wx.VERTICAL)
461        sizer_button = wx.BoxSizer(wx.HORIZONTAL)
462         
463        self.btFit = wx.Button(self,wx.NewId(),'Fit')
464        self.btFit.Bind(wx.EVT_BUTTON, self.onFit,id= self.btFit.GetId())
465        self.btFit.SetToolTipString("Perform fit.")
[2140e68]466       
[8bd4dc0]467        text= "Hint: Park fitting engine will be selected \n"
468        text+= "automatically for more than 2 combinations checked"
469        text_hint = wx.StaticText(self,-1,text)
470       
471        sizer_button.Add(text_hint,  wx.RIGHT|wx.EXPAND, 10)
472        sizer_button.Add(self.btFit, 0, wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 10)
473       
474        boxsizer1.Add(sizer_button, flag= wx.TOP|wx.BOTTOM,border=10)
475        self.sizer3.Add(boxsizer1,0, wx.EXPAND | wx.ALL, 10)
476        self.sizer3.Layout()
[c99a6c5]477        self.SetScrollbars(20,20,25,65)
[2140e68]478       
479    def _fill_sizer_constraint(self):
480        """
[5062bbf]481        Fill sizer containing constraint info
[2140e68]482        """
[5062bbf]483        msg = "Select at least 2 model to add constraint "
[2140e68]484        wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
485       
486        self.sizer2.Clear(True)
487        box_description= wx.StaticBox(self, -1,"Fit Constraints")
488        boxsizer1 = wx.StaticBoxSizer(box_description, wx.VERTICAL)
489        sizer_title = wx.BoxSizer(wx.HORIZONTAL)
[b28717b]490        self.sizer_constraints = wx.BoxSizer(wx.VERTICAL)
[2140e68]491        sizer_button = wx.BoxSizer(wx.HORIZONTAL)
492       
493        self.hide_constraint = wx.RadioButton(self, -1, 'No', (10, 10), style=wx.RB_GROUP)
494        self.show_constraint = wx.RadioButton(self, -1, 'Yes', (10, 30))
495        self.Bind( wx.EVT_RADIOBUTTON, self._display_constraint,
496                    id= self.hide_constraint.GetId() )
497        self.Bind(  wx.EVT_RADIOBUTTON, self._display_constraint,
498                         id= self.show_constraint.GetId()    )
[17c5868]499        self.hide_constraint.SetValue(True)
[2140e68]500        sizer_title.Add( wx.StaticText(self,-1," Model") )
501        sizer_title.Add(( 10,10) )
502        sizer_title.Add( wx.StaticText(self,-1," Parameter") )
503        sizer_title.Add(( 10,10) )
504        sizer_title.Add( wx.StaticText(self,-1," Add Constraint?") )
505        sizer_title.Add(( 10,10) )
506        sizer_title.Add( self.show_constraint )
507        sizer_title.Add( self.hide_constraint )
508        sizer_title.Add(( 10,10) )
509       
510        self.btAdd =wx.Button(self,wx.NewId(),'Add')
511        self.btAdd.Bind(wx.EVT_BUTTON, self._onAdd_constraint,id= self.btAdd.GetId())
512        self.btAdd.SetToolTipString("Add another constraint?")
[77e23a2]513        self.btAdd.Hide()
[8bd4dc0]514     
[d5fd5ce]515        text_hint = wx.StaticText(self,-1,"Example: [M0][paramter] = M1.parameter") 
[2140e68]516        sizer_button.Add(text_hint, 0 , wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 10)
517        sizer_button.Add(self.btAdd, 0, wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 10)
518       
[8bd4dc0]519        boxsizer1.Add(sizer_title, flag= wx.TOP|wx.BOTTOM,border=10)
520        boxsizer1.Add(self.sizer_constraints, flag= wx.TOP|wx.BOTTOM,border=10)
521        boxsizer1.Add(sizer_button, flag= wx.TOP|wx.BOTTOM,border=10)
[2140e68]522       
523        self.sizer2.Add(boxsizer1,0, wx.EXPAND | wx.ALL, 10)
524        self.sizer2.Layout()
[c99a6c5]525        self.SetScrollbars(20,20,25,65)
[5062bbf]526   
[2140e68]527    def _set_constraint(self):
[d89f09b]528        """
[5062bbf]529        get values from the constrainst textcrtl ,parses them into model name
530        parameter name and parameters values.
531        store them in a list self.params .when when params is not empty set_model
532        uses it to reset the appropriate model and its appropriates parameters
[d89f09b]533        """
[2140e68]534        for item in self.constraints_list:
[ac11e40]535            model = item[0].GetClientData(item[0].GetCurrentSelection())
536            param = item[1].GetString(item[1].GetCurrentSelection())
[2140e68]537            constraint = item[3].GetValue().lstrip().rstrip()
[bb7d8a4]538            if param.lstrip().rstrip()=="":
539                param= None
540                msg= " Constraint will be ignored!. missing parameters in combobox"
541                msg+= " to set constraint! "
542                wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
[6bbeacd4]543            for id, value in self.constraint_dict.iteritems():
[1f57dfd]544                if model == value:
545                    if constraint == "":
546                        msg= " Constraint will be ignored!. missing value in textcrtl"
547                        msg+= " to set constraint! "
548                        wx.PostEvent(self.parent.Parent, StatusEvent(status= msg ))
549                        constraint = None
[c647377]550                    for fid in self.page_finder[id].iterkeys():
551                        self.page_finder[id].set_model_param(param,
552                                                        constraint, fid=fid)
[1f57dfd]553                    break
[5062bbf]554   
[2140e68]555    def _fill_sizer_model_list(self,sizer):
[d89f09b]556        """
[5062bbf]557        Receive a dictionary containing information to display model name
558       
559        :param page_finder: the dictionary containing models information
560       
[d89f09b]561        """
[2140e68]562        ix = 0
563        iy = 0
564        list=[]
565        sizer.Clear(True)
566       
567        new_name = wx.StaticText(self, -1, 'New Model Name', style=wx.ALIGN_CENTER)
568        new_name.SetBackgroundColour('orange')
569        sizer.Add(new_name,(iy, ix),(1,1),
570                            wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 15)
[5062bbf]571        ix += 2 
[2140e68]572        model_type = wx.StaticText(self, -1, '  Model Type')
573        model_type.SetBackgroundColour('grey')
574        sizer.Add(model_type,(iy, ix),(1,1),
575                            wx.EXPAND|wx.ADJUST_MINSIZE, 0) 
[5062bbf]576        ix += 1 
[2140e68]577        data_used = wx.StaticText(self, -1, '  Used Data')
578        data_used.SetBackgroundColour('grey')
579        sizer.Add(data_used,(iy, ix),(1,1),
580                            wx.EXPAND|wx.ADJUST_MINSIZE, 0) 
[6bbeacd4]581        ix += 1 
582        tab_used = wx.StaticText(self, -1, '  Fit Tab')
583        tab_used.SetBackgroundColour('grey')
584        sizer.Add(tab_used,(iy, ix),(1,1),
585                            wx.EXPAND|wx.ADJUST_MINSIZE, 0) 
586        for id, value in self.page_finder.iteritems():
[2140e68]587            try:
588                ix = 0
589                iy += 1 
[c647377]590                for fitproblem in value.get_fit_problem():
[6c08ba5]591                    data = fitproblem.get_fit_data()
[c647377]592                    model = fitproblem.get_model()
593                    name = '_'
594                    if model is not None:
595                        name = str(model.name)
596                    cb = wx.CheckBox(self, -1, name)
597                    cb.SetValue(False)
[6c08ba5]598                    cb.Enable(model is not None and data.is_data)
[c647377]599                    sizer.Add(cb, (iy, ix), (1, 1), 
600                               wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 15)
601                    wx.EVT_CHECKBOX(self, cb.GetId(), self.check_model_name)
602                    ix += 2 
603                    type = model.__class__.__name__
604                    model_type = wx.StaticText(self, -1, str(type))
605                    sizer.Add(model_type, (iy, ix), (1, 1), 
606                              wx.EXPAND|wx.ADJUST_MINSIZE, 0)
607                    name = '-'
[6c08ba5]608                    if data is not None and data.is_data:
[c647377]609                        name = str(data.name)
610                    data_used = wx.StaticText(self, -1, name)
611                    ix += 1 
612                    sizer.Add(data_used, (iy, ix), (1, 1), 
613                              wx.EXPAND|wx.ADJUST_MINSIZE, 0)
614                    ix += 1 
615                    caption = value.get_fit_tab_caption()
616                    tab_caption_used= wx.StaticText(self, -1, str(caption))
617                    sizer.Add(tab_caption_used, (iy, ix), (1, 1), 
618                              wx.EXPAND|wx.ADJUST_MINSIZE, 0)
[6bbeacd4]619                   
620                self.model_list.append([cb,value,id,model])
[2140e68]621               
622            except:
[6bbeacd4]623                raise
624                #pass
[5062bbf]625        iy += 1
[c647377]626        sizer.Add((20, 20), (iy, ix), (1, 1), 
627                  wx.LEFT|wx.EXPAND|wx.ADJUST_MINSIZE, 15)
[2140e68]628        sizer.Layout()   
[c647377]629
[4133316]630    def on_set_focus(self, event=None):
631        """
632        The  derivative class is on focus if implemented
633        """
634        if self.parent is not None:
635            wx.PostEvent(self.parent, PanelOnFocusEvent(panel=self))
636        self.page_finder = self.parent.get_page_finder()
637       
Note: See TracBrowser for help on using the repository browser.