source: sasview/sansview/perspectives/fitting/pagestate.py @ 138c139

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

working on saving customized dispersity

  • Property mode set to 100644
File size: 5.7 KB
RevLine 
[c77d859]1
2
[6f023e8]3import copy
[c77d859]4
[cfc0913]5class PageState(object):
[c77d859]6    """
7        Contains info to reconstruct a page
8    """
9    def __init__(self, parent,model=None, data=None):
10       
11        """
12            Initialization of the Panel
13        """
14        #TODO: remove this once the inheritence is cleaned up
15        ## Data member to store the dispersion object created
16        self._disp_obj_dict = {}
[cfc0913]17        ## reset True change the state of exsiting button
18        self.reset = False
[c77d859]19        #Data used for fitting
20        self.data = data
21        # flag to allow data2D plot
[cfc0913]22        self.enable2D = False
[c77d859]23        # model on which the fit would be performed
24        self.model = model
[dad49a0]25        if not hasattr(self.model, "_persistency_dict"):
26            self.model._persistency_dict = {}
[71f0373]27        self.model._persistency_dict = copy.deepcopy(model._persistency_dict)
[c77d859]28        #fit page manager
29        self.manager = None
30        #Store the parent of this panel parent
31        # For this application fitpanel is the parent
32        self.parent  = parent
33        # Event_owner is the owner of model event
34        self.event_owner = None
[c9a4377]35        ##page name
[cfc0913]36        self.page_name = ""
[c77d859]37        # Contains link between  model ,all its parameters, and panel organization
[cfc0913]38        self.parameters =[]
[c77d859]39        # Contains list of parameters that cannot be fitted and reference to
40        #panel objects
[cfc0913]41        self.fixed_param =[]
[c77d859]42        # Contains list of parameters with dispersity and reference to
43        #panel objects
[cfc0913]44        self.fittable_param =[]
[60132ef]45        ## orientation parameters
46        self.orientation_params=[]
[fc6ea43]47        ## orientation parmaters for gaussian dispersity
48        self.orientation_params_disp=[]
[3370922]49        ## smearer info
50        self.smearer=None
[c77d859]51        #list of dispersion paramaters
[cfc0913]52        self.disp_list =[]
[71f0373]53        if self.model !=None:
54            self.disp_list = self.model.getDispParamList()
[c477b31]55        self._disp_obj_dict={}
56        self.disp_cb_dict={}
[dad49a0]57        self.values=[]
58        self.weights=[]
59                   
[c77d859]60        #contains link between a model and selected parameters to fit
[cfc0913]61        self.param_toFit =[]
[a074145]62        ##dictionary of model type and model class
[cfc0913]63        self.model_list_box = None
[a074145]64        ## save the state of the context menu
65        self.saved_states={}
[c77d859]66        ## save  current value of combobox
67        self.formfactorcombobox = ""
68        self.structurecombobox  = ""
[b787e68c]69        ## the indice of the current selection
70        self.disp_box = 0
[c77d859]71        ## Qrange
[cfc0913]72        ## Q range
73        self.qmin= 0.001
74        self.qmax= 0.1
75        self.npts = None
76        ## enable smearering state
77        self.enable_smearer = False
[fc6ea43]78        self.disable_smearer = True
[cfc0913]79        ## disperity selection
80        self.enable_disp= False
[fc6ea43]81        self.disable_disp= True
[c477b31]82        ## plot 2D data
83        self.enable2D= False
[cfc0913]84        ## state of selected all check button
85        self.cb1 = False
[c9a4377]86       
[cfc0913]87   
88    def save_data(self, data):
[c77d859]89        """
[cfc0913]90            Save data
[c77d859]91        """
[cfc0913]92        self.data = copy.deepcopy(data)
[b787e68c]93
[cfc0913]94       
[6f023e8]95    def clone(self):
96        model=None
97        if self.model !=None:
98            model = self.model.clone()
99       
[cfc0913]100        obj          = PageState( self.parent,model= model )
[6f023e8]101        obj.data = copy.deepcopy(self.data)
[dcf29d7]102        obj.model_list_box = copy.deepcopy(self.model_list_box)
[71f0373]103     
[dcf29d7]104        obj.manager = self.manager
105        obj.event_owner = self.event_owner
[71f0373]106        obj.disp_list = copy.deepcopy(self.disp_list)
[fc6ea43]107       
[c477b31]108        obj.enable2D = copy.deepcopy(self.enable2D)
[cfc0913]109        obj.parameters = copy.deepcopy(self.parameters)
110        obj.fixed_param = copy.deepcopy(self.fixed_param)
111        obj.fittable_param = copy.deepcopy(self.fittable_param)
[60132ef]112        obj.orientation_params =  copy.deepcopy(self.orientation_params)
[fc6ea43]113        obj.orientation_params_disp =  copy.deepcopy(self.orientation_params_disp)
114       
[b787e68c]115        obj.enable_disp = copy.deepcopy(self.enable_disp)
[fc6ea43]116        obj.disable_disp = copy.deepcopy(self.disable_disp)
[71f0373]117        if self.model !=None and len(self.model._persistency_dict)>0:
[dad49a0]118            for k, v in self.model._persistency_dict.iteritems():
119                obj.model._persistency_dict[k] = copy.deepcopy(v)
[c477b31]120        if len(self._disp_obj_dict)>0:
121            for k , v in self._disp_obj_dict.iteritems():
122                obj._disp_obj_dict[k]= v
[dad49a0]123        if len(self.disp_cb_dict)>0:
124            for k , v in self.disp_cb_dict.iteritems():
125                obj.disp_cb_dict[k]= v
126        obj.values = copy.deepcopy(self.values)
127        obj.weights = copy.deepcopy(self.weights)
[b787e68c]128        obj.enable_smearer = copy.deepcopy(self.enable_smearer)
[fc6ea43]129        obj.disable_smearer = copy.deepcopy(self.disable_smearer)
130       
[b787e68c]131        obj.disp_box = copy.deepcopy(self.disp_box)
132        obj.qmin = copy.deepcopy(self.qmin)
133        obj.qmax = copy.deepcopy(self.qmax)
134        obj.npts = copy.deepcopy(self.npts )
135        obj.cb1 = copy.deepcopy(self.cb1)
[3370922]136        obj.smearer = copy.deepcopy(self.smearer)
137       
[a074145]138        for name, state in self.saved_states.iteritems():
139            copy_name = copy.deepcopy(name)
140            copy_state = state.clone()
141            obj.saved_states[copy_name]= copy_state
[6f023e8]142        return obj
[c77d859]143
[71f0373]144
[cfc0913]145class PageMemento(object):
146    """
147        Store the state of a fitpage or model page of fitpanel
148    """
149    def __init__(self, state):
150        """ Initialization"""
151        self.state = state
152       
153    def setState(self,state):
154        """
155            set current state
156            @param state: new state
157        """
158        self.state = state
159       
160    def getState(self):
161        """
162            @return state
163        """
164        return self.state
165       
166       
167       
[c77d859]168       
Note: See TracBrowser for help on using the repository browser.