source: sasview/sansview/perspectives/fitting/simfitpage.py @ ca7a626

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 ca7a626 was ca7a626, checked in by Gervaise Alina <gervyh@…>, 15 years ago

combine single fit and simultaneous fit

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