source: sasview/guiframe/data_manager.py @ a3c96f7a

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

updating plot display

  • Property mode set to 100644
File size: 10.3 KB
Line 
1################################################################################
2#This software was developed by the University of Tennessee as part of the
3#Distributed Data Analysis of Neutron Scattering Experiments (DANSE)
4#project funded by the US National Science Foundation.
5#
6#See the license text in license.txt
7#
8#copyright 2010, University of Tennessee
9################################################################################
10"""
11This module manages all data loaded into the application. Data_manager makes
12available all data loaded  for the current perspective.
13
14All modules "creating Data" posts their data to data_manager .
15Data_manager  make these new data available for all other perspectives.
16"""
17import logging
18import os
19import copy 
20
21from sans.guiframe.data_state import DataState
22from sans.guiframe.utils import parse_name
23import DataLoader.data_info as DataInfo
24from sans.guiframe.dataFitting import Data1D
25from sans.guiframe.dataFitting import Data2D
26import time
27
28class DataManager(object):
29    """
30    Manage a list of data
31    """
32    def __init__(self):
33        """
34        Store opened path and data object created at the loading time
35        :param auto_plot: if True the datamanager sends data to plotting
36                            plugin.
37        :param auto_set_data: if True the datamanager sends to the current
38        perspective
39        """
40        self.stored_data = {}
41        self.message = ""
42        self.data_name_dict = {}
43        self.count = 0
44        self.list_of_id = []
45     
46    def __str__(self):
47        _str  = ""
48        _str += "No of states  is %s \n" % str(len(self.stored_data))
49        n_count = 0
50        for  value in self.stored_data.values():
51            n_count += 1 
52            _str += "State No %s \n"  % str(n_count)
53            _str += str(value) + "\n"
54        return _str
55       
56    def create_gui_data(self, data, path=None):
57        """
58        Receive data from loader and create a data to use for guiframe
59        """
60       
61        if issubclass(Data2D, data.__class__):
62            new_plot = Data2D(image=None, err_image=None) 
63        else: 
64            new_plot = Data1D(x=[], y=[], dx=None, dy=None)
65           
66        new_plot.copy_from_datainfo(data) 
67        data.clone_without_data(clone=new_plot) 
68        #creating a name for data
69        name = ""
70        title = ""
71        file_name = ""
72        if path is not None:
73            file_name = os.path.basename(path)
74        if data.run:
75            name = data.run[0]
76        if name == "":
77            name = file_name
78        name = self.rename(name)
79        #find title
80        if data.title.strip():
81            title = data.title
82        if title.strip() == "":
83            title = file_name
84       
85        if new_plot.filename.strip() == "":
86            new_plot.filename = file_name
87       
88        new_plot.name = name
89        new_plot.title = title
90        ## allow to highlight data when plotted
91        new_plot.interactive = True
92        ## when 2 data have the same id override the 1 st plotted
93        new_plot.id = time.time()
94        ##group_id specify on which panel to plot this data
95        new_plot.group_id = time.time()
96        new_plot.is_data = True
97        new_plot.path = path
98        new_plot.list_group_id = []
99        ##post data to plot
100        # plot data
101        return new_plot
102 
103    def rename(self, name):
104        """
105        rename data
106        """
107        ## name of the data allow to differentiate data when plotted
108        name = parse_name(name=name, expression="_")
109       
110        max_char = name.find("[")
111        if max_char < 0:
112            max_char = len(name)
113        name = name[0:max_char]
114       
115        if name not in self.data_name_dict:
116            self.data_name_dict[name] = 0
117        else:
118            self.data_name_dict[name] += 1
119            name = name + " [" + str(self.data_name_dict[name]) + "]"
120        return name
121   
122    def add_theory_data(self, data_list):
123        """
124        """
125        for id, data in data_list.iteritems():
126            if id  in self.stored_data:
127                msg = "Data manager already stores %s" % str(data.name)
128                msg += ""
129                logging.info(msg)
130                data_state = self.stored_data[id]
131                data_state.theory_data = data
132            else:
133                data_state = DataState(theory_data=data)
134                data_state.id = data.id
135                self.stored_data[id] = data_state
136               
137    def add_data(self, data_list):
138        """
139        receive a list of
140        """
141        for id, data in data_list.iteritems():
142            if id  in self.stored_data:
143                msg = "Data manager already stores %s" % str(data.name)
144                msg += ""
145                logging.info(msg)
146                data_state = self.stored_data[id]
147                data_state.data = data
148            else:
149                data_state = DataState(data)
150                data_state.id = id
151                self.stored_data[id] = data_state
152   
153       
154    def update_data(self, prev_data, new_data):
155        """
156        """
157        if prev_data.id not in self.stored_data.keys():
158            return None, {}
159        data_state = self.stored_data[prev_data.id] 
160        self.stored_data[new_data.id]  = data_state.clone()
161        self.stored_data[new_data.id].data = new_data
162        if prev_data.id in self.stored_data.keys():
163            del self.stored_data[prev_data.id] 
164        return prev_data.id, {new_data.id: self.stored_data[new_data.id]}
165   
166    def update_theory(self, data_id, theory, state=None):
167        """
168        """
169        if data_id in self.stored_data.keys():
170            data_state = self.stored_data[data_id] 
171            data_state.set_theory(theory_data=theory, theory_state=state)
172            return {data_id: self.stored_data[data_id]}
173        return {}
174   
175    def get_message(self):
176        """
177        return message
178        """
179        return self.message
180   
181    def get_by_id(self, id_list=None):
182        """
183        """
184        _selected_data = {}
185        _selected_theory_list = {}
186        if id_list is None:
187            return
188        for d_id in self.stored_data:
189            for search_id in id_list:
190                data_state = self.stored_data[d_id]
191                data = data_state.data
192                theory_list = data_state.get_theory()
193                if search_id == d_id:
194                    _selected_data[search_id] = data
195                if search_id in theory_list.keys():
196                     _selected_theory_list[search_id] = theory_list[search_id]
197                   
198        return _selected_data, _selected_theory_list
199   
200           
201    def freeze(self, theory_id):
202        """
203        """
204        return self.freeze_theory(self.stored_data.keys(), theory_id)
205       
206    def freeze_theory(self, data_id, theory_id):
207        """
208        """
209        selected_theory = {}
210        for d_id in data_id:
211            if d_id in self.stored_data:
212                data_state = self.stored_data[d_id]
213                theory_list = data_state.get_theory()
214                for t_id in theory_id:
215                    if t_id in theory_list.keys():
216                        theory_data, theory_state = theory_list[t_id]
217                        new_theory = copy.deepcopy(theory_data)
218                        new_theory.id  = time.time()
219                        new_theory.is_data = True
220                        selected_theory[new_theory.id] = DataState(new_theory)
221                        self.stored_data[new_theory.id] = selected_theory[new_theory.id]
222                    else:
223                        msg = "Theory with ID %s " % str(t_id)
224                        msg += "couldn't not be frozen" 
225                        raise ValueError, msg
226        return selected_theory
227                   
228           
229    def delete_data(self, data_id, theory_id=None, delete_all=False):
230        """
231        """
232        if data_id in self.stored_data.keys():
233            data_state = self.stored_data[data_id]
234            if data_state.data.name in self.data_name_dict:
235                del self.data_name_dict[data_state.data.name]
236            del self.stored_data[data_id]
237       
238        self.delete_theory(data_id, theory_id)
239        if delete_all:
240            self.stored_data = {}
241            self.data_name_dict = {}
242           
243    def delete_theory(self, data_id, theory_id):
244        """
245        """
246        for d_id in data_id:
247            if d_id in self.stored_data:
248                data_state = self.stored_data[d_id]
249                theory_list = data_state.get_theory()
250                if theory_id in theory_list.keys():
251                    del theory_list[theory_id]
252       
253           
254    def delete_by_id(self, id_list=None):
255        """
256        save data and path
257        """
258        for id in id_list:
259            if id in self.stored_data:
260                del self.stored_data[id]
261         
262   
263    def get_by_name(self, name_list=None):
264        """
265        return a list of data given a list of data names
266        """
267        _selected_data = {}
268        for selected_name in name_list:
269            for id, data_state in self.stored_data.iteritems():
270                if data_state.data.name == selected_name:
271                    _selected_data[id] = data_state.data
272        return _selected_data
273   
274    def delete_by_name(self, name_list=None):
275        """
276        save data and path
277        """
278        for selected_name in name_list:
279            for id, data_state in self.stored_data.iteritems():
280                if data_state.data.name == selected_name:
281                    del self._selected_data[id]
282                    del self.stored_data[data.id]
283
284    def get_data_state(self, data_id):
285        """
286        Send list of selected data
287        """
288        _selected_data_state = {}
289        for id in data_id:
290            if id in self.stored_data.keys():
291                _selected_data_state[id] = self.stored_data[id]
292        return _selected_data_state
293   
294    def get_all_data(self):
295        """
296        return list of all available data
297        """
298        return self.stored_data
299   
300
301       
Note: See TracBrowser for help on using the repository browser.