source: sasview/guiframe/data_manager.py @ 95b2bad

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

take file name as a data name

  • Property mode set to 100644
File size: 9.8 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        self.time_stamp = time.time()
46     
47    def __str__(self):
48        _str  = ""
49        _str += "No of states  is %s \n" % str(len(self.stored_data))
50        n_count = 0
51        for  value in self.stored_data.values():
52            n_count += 1 
53            _str += "State No %s \n"  % str(n_count)
54            _str += str(value) + "\n"
55        return _str
56       
57    def create_gui_data(self, data, path=None):
58        """
59        Receive data from loader and create a data to use for guiframe
60        """
61       
62        if issubclass(Data2D, data.__class__):
63            new_plot = Data2D(image=None, err_image=None) 
64        else: 
65            new_plot = Data1D(x=[], y=[], dx=None, dy=None)
66           
67        new_plot.copy_from_datainfo(data) 
68        data.clone_without_data(clone=new_plot) 
69        #creating a name for data
70        name = ""
71        title = ""
72        file_name = ""
73        if path is not None:
74            file_name = os.path.basename(path)
75        if data.run:
76            run_num = data.run[0]
77        name = file_name
78        if name == "":
79            name = run_num
80        name = self.rename(name)
81        #find title
82        if data.title.strip():
83            title = data.title
84        if title.strip() == "":
85            title = file_name
86       
87        if new_plot.filename.strip() == "":
88            new_plot.filename = file_name
89       
90        new_plot.name = name
91        new_plot.title = title
92        ## allow to highlight data when plotted
93        new_plot.interactive = True
94        ## when 2 data have the same id override the 1 st plotted
95        self.time_stamp += 1
96        new_plot.id = self.time_stamp
97        ##group_id specify on which panel to plot this data
98        new_plot.group_id = self.time_stamp
99        new_plot.is_data = True
100        new_plot.path = path
101        new_plot.list_group_id = []
102        ##post data to plot
103        # plot data
104        return new_plot
105 
106    def rename(self, name):
107        """
108        rename data
109        """
110        ## name of the data allow to differentiate data when plotted
111        name = parse_name(name=name, expression="_")
112       
113        max_char = name.find("[")
114        if max_char < 0:
115            max_char = len(name)
116        name = name[0:max_char]
117       
118        if name not in self.data_name_dict:
119            self.data_name_dict[name] = 0
120        else:
121            self.data_name_dict[name] += 1
122            name = name + " [" + str(self.data_name_dict[name]) + "]"
123        return name
124   
125 
126    def add_data(self, data_list):
127        """
128        receive a list of
129        """
130        for id, data in data_list.iteritems():
131            if id  in self.stored_data:
132                msg = "Data manager already stores %s" % str(data.name)
133                msg += ""
134                logging.info(msg)
135                data_state = self.stored_data[id]
136                data_state.data = data
137            else:
138                data_state = DataState(data)
139                data_state.id = id
140                self.stored_data[id] = data_state
141   
142    def update_data(self, prev_data, new_data):
143        """
144        """
145        if prev_data.id not in self.stored_data.keys():
146            return None, {}
147        data_state = self.stored_data[prev_data.id] 
148        self.stored_data[new_data.id]  = data_state.clone()
149        self.stored_data[new_data.id].data = new_data
150        if prev_data.id in self.stored_data.keys():
151            del self.stored_data[prev_data.id] 
152        return prev_data.id, {new_data.id: self.stored_data[new_data.id]}
153   
154    def update_theory(self, theory, data_id=None, state=None):
155        """
156        """
157        uid = data_id
158        if data_id is None and theory is not None:
159            uid = theory.id
160        if uid in self.stored_data.keys():
161             data_state = self.stored_data[uid] 
162        else:
163            data_state = DataState()
164        data_state.uid = uid
165        data_state.set_theory(theory_data=theory, theory_state=state)
166        self.stored_data[uid] = data_state
167        return {uid: self.stored_data[uid]}
168       
169   
170    def get_message(self):
171        """
172        return message
173        """
174        return self.message
175   
176    def get_by_id(self, id_list=None):
177        """
178        """
179        _selected_data = {}
180        _selected_theory_list = {}
181        if id_list is None:
182            return
183        for d_id in self.stored_data:
184            for search_id in id_list:
185                data_state = self.stored_data[d_id]
186                data = data_state.data
187                theory_list = data_state.get_theory()
188                if search_id == d_id:
189                    _selected_data[search_id] = data
190                if search_id in theory_list.keys():
191                     _selected_theory_list[search_id] = theory_list[search_id]
192                   
193        return _selected_data, _selected_theory_list
194   
195           
196    def freeze(self, theory_id):
197        """
198        """
199        return self.freeze_theory(self.stored_data.keys(), theory_id)
200       
201    def freeze_theory(self, data_id, theory_id):
202        """
203        """
204        selected_theory = {}
205        for d_id in data_id:
206            if d_id in self.stored_data:
207                data_state = self.stored_data[d_id]
208                theory_list = data_state.get_theory()
209                for t_id in theory_id:
210                    if t_id in theory_list.keys():
211                        theory_data, theory_state = theory_list[t_id]
212                        new_theory = copy.deepcopy(theory_data)
213                        new_theory.id  = time.time()
214                        new_theory.is_data = True
215                        selected_theory[new_theory.id] = DataState(new_theory)
216                        self.stored_data[new_theory.id] = selected_theory[new_theory.id]
217
218        return selected_theory
219                   
220           
221    def delete_data(self, data_id, theory_id=None, delete_all=False):
222        """
223        """
224        if data_id in self.stored_data.keys():
225            data_state = self.stored_data[data_id]
226            if data_state.data.name in self.data_name_dict:
227                del self.data_name_dict[data_state.data.name]
228            del self.stored_data[data_id]
229       
230        self.delete_theory(data_id, theory_id)
231        if delete_all:
232            self.stored_data = {}
233            self.data_name_dict = {}
234           
235    def delete_theory(self, data_id, theory_id):
236        """
237        """
238        for d_id in data_id:
239            if d_id in self.stored_data:
240                data_state = self.stored_data[d_id]
241                theory_list = data_state.get_theory()
242                if theory_id in theory_list.keys():
243                    del theory_list[theory_id]
244       
245           
246    def delete_by_id(self, id_list=None):
247        """
248        save data and path
249        """
250        for id in id_list:
251            if id in self.stored_data:
252                del self.stored_data[id]
253         
254   
255    def get_by_name(self, name_list=None):
256        """
257        return a list of data given a list of data names
258        """
259        _selected_data = {}
260        for selected_name in name_list:
261            for id, data_state in self.stored_data.iteritems():
262                if data_state.data.name == selected_name:
263                    _selected_data[id] = data_state.data
264        return _selected_data
265   
266    def delete_by_name(self, name_list=None):
267        """
268        save data and path
269        """
270        for selected_name in name_list:
271            for id, data_state in self.stored_data.iteritems():
272                if data_state.data.name == selected_name:
273                    del self._selected_data[id]
274                    del self.stored_data[data.id]
275
276    def get_data_state(self, data_id):
277        """
278        Send list of selected data
279        """
280        _selected_data_state = {}
281        for id in data_id:
282            if id in self.stored_data.keys():
283                _selected_data_state[id] = self.stored_data[id]
284        return _selected_data_state
285   
286    def get_all_data(self):
287        """
288        return list of all available data
289        """
290        return self.stored_data
291   
292
293       
Note: See TracBrowser for help on using the repository browser.