source: sasview/guiframe/data_manager.py @ 67ae937

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 67ae937 was 248b918, checked in by Gervaise Alina <gervyh@…>, 14 years ago

working on remove data

  • Property mode set to 100644
File size: 9.9 KB
RevLine 
[3c44c66]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
[f444b20]14All modules "creating Data" posts their data to data_manager .
15Data_manager  make these new data available for all other perspectives.
[3c44c66]16"""
[f444b20]17import logging
[0348245]18import os
[c70eb7c]19import copy 
20
[c5e84fb]21from sans.guiframe.data_state import DataState
[75fbd17]22from sans.guiframe.utils import parse_name
[0348245]23import DataLoader.data_info as DataInfo
24from sans.guiframe.dataFitting import Data1D
25from sans.guiframe.dataFitting import Data2D
[5080cda]26import time
[a07e72f]27
[3c44c66]28class DataManager(object):
29    """
[f444b20]30    Manage a list of data
[3c44c66]31    """
[f444b20]32    def __init__(self):
[3c44c66]33        """
[aebc4cc]34        Store opened path and data object created at the loading time
[f444b20]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
[4e9583c]39        """
[f444b20]40        self.stored_data = {}
[aebc4cc]41        self.message = ""
[75fbd17]42        self.data_name_dict = {}
[5080cda]43        self.count = 0
44        self.list_of_id = []
[7ad8faa]45        self.time_stamp = time.time()
[f444b20]46     
[c70eb7c]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       
[0348245]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       
[5080cda]62        if issubclass(Data2D, data.__class__):
[0348245]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)
[e5c7052]75        if file_name == "":
76            file_name = data.filename
[0348245]77        if data.run:
[0c975ab]78            run_num = data.run[0]
79        name = file_name
[0348245]80        if name == "":
[0c975ab]81            name = run_num
[0348245]82        name = self.rename(name)
83        #find title
84        if data.title.strip():
85            title = data.title
86        if title.strip() == "":
87            title = file_name
88       
89        if new_plot.filename.strip() == "":
90            new_plot.filename = file_name
91       
92        new_plot.name = name
93        new_plot.title = title
94        ## allow to highlight data when plotted
95        new_plot.interactive = True
96        ## when 2 data have the same id override the 1 st plotted
[7ad8faa]97        self.time_stamp += 1
[248b918]98        new_plot.id = str(name) + str(self.time_stamp)
[0348245]99        ##group_id specify on which panel to plot this data
[248b918]100        new_plot.group_id = str(name) + str(self.time_stamp)
[0348245]101        new_plot.is_data = True
102        new_plot.path = path
[52d3fd1]103        new_plot.list_group_id = []
[0348245]104        ##post data to plot
105        # plot data
106        return new_plot
107 
[75fbd17]108    def rename(self, name):
109        """
110        rename data
111        """
112        ## name of the data allow to differentiate data when plotted
113        name = parse_name(name=name, expression="_")
114       
115        max_char = name.find("[")
116        if max_char < 0:
117            max_char = len(name)
118        name = name[0:max_char]
119       
120        if name not in self.data_name_dict:
121            self.data_name_dict[name] = 0
122        else:
123            self.data_name_dict[name] += 1
124            name = name + " [" + str(self.data_name_dict[name]) + "]"
125        return name
126   
[ec611aad]127 
[f444b20]128    def add_data(self, data_list):
129        """
130        receive a list of
131        """
[e88ebfd]132        for id, data in data_list.iteritems():
133            if id  in self.stored_data:
[f444b20]134                msg = "Data manager already stores %s" % str(data.name)
135                msg += ""
136                logging.info(msg)
[e88ebfd]137                data_state = self.stored_data[id]
[a3c96f7a]138                data_state.data = data
[5c4b674]139            else:
140                data_state = DataState(data)
[a3c96f7a]141                data_state.id = id
[e88ebfd]142                self.stored_data[id] = data_state
143   
[c70eb7c]144    def update_data(self, prev_data, new_data):
[f444b20]145        """
146        """
[c70eb7c]147        if prev_data.id not in self.stored_data.keys():
[ae83ad3]148            return None, {}
[c70eb7c]149        data_state = self.stored_data[prev_data.id] 
150        self.stored_data[new_data.id]  = data_state.clone()
151        self.stored_data[new_data.id].data = new_data
152        if prev_data.id in self.stored_data.keys():
153            del self.stored_data[prev_data.id] 
154        return prev_data.id, {new_data.id: self.stored_data[new_data.id]}
155   
[ec611aad]156    def update_theory(self, theory, data_id=None, state=None):
[e88ebfd]157        """
158        """
[ec611aad]159        uid = data_id
160        if data_id is None and theory is not None:
161            uid = theory.id
162        if uid in self.stored_data.keys():
163             data_state = self.stored_data[uid] 
164        else:
165            data_state = DataState()
166        data_state.uid = uid
167        data_state.set_theory(theory_data=theory, theory_state=state)
168        self.stored_data[uid] = data_state
169        return {uid: self.stored_data[uid]}
170       
[e88ebfd]171   
[aebc4cc]172    def get_message(self):
[3c44c66]173        """
[aebc4cc]174        return message
[3c44c66]175        """
[aebc4cc]176        return self.message
[3c44c66]177   
[df22224]178    def get_by_id(self, id_list=None):
[f444b20]179        """
180        """
[df22224]181        _selected_data = {}
182        _selected_theory_list = {}
183        if id_list is None:
[e88ebfd]184            return
[df22224]185        for d_id in self.stored_data:
186            for search_id in id_list:
[e88ebfd]187                data_state = self.stored_data[d_id]
188                data = data_state.data
189                theory_list = data_state.get_theory()
[df22224]190                if search_id == d_id:
191                    _selected_data[search_id] = data
192                if search_id in theory_list.keys():
193                     _selected_theory_list[search_id] = theory_list[search_id]
194                   
[e88ebfd]195        return _selected_data, _selected_theory_list
196   
[e6a93df]197           
198    def freeze(self, theory_id):
199        """
200        """
201        return self.freeze_theory(self.stored_data.keys(), theory_id)
202       
[c70eb7c]203    def freeze_theory(self, data_id, theory_id):
204        """
205        """
[ee2b492]206        selected_theory = {}
[c70eb7c]207        for d_id in data_id:
208            if d_id in self.stored_data:
209                data_state = self.stored_data[d_id]
210                theory_list = data_state.get_theory()
211                for t_id in theory_id:
212                    if t_id in theory_list.keys():
[ee2b492]213                        theory_data, theory_state = theory_list[t_id]
214                        new_theory = copy.deepcopy(theory_data)
[5080cda]215                        new_theory.id  = time.time()
[e6a93df]216                        new_theory.is_data = True
[ee2b492]217                        selected_theory[new_theory.id] = DataState(new_theory)
218                        self.stored_data[new_theory.id] = selected_theory[new_theory.id]
[bffa3d0]219
[ee2b492]220        return selected_theory
[c70eb7c]221                   
222           
223    def delete_data(self, data_id, theory_id=None, delete_all=False):
224        """
225        """
[248b918]226        for d_id in data_id:
227            if d_id in self.stored_data.keys():
228                data_state = self.stored_data[d_id]
229                if data_state.data.name in self.data_name_dict:
230                    del self.data_name_dict[data_state.data.name]
231                del self.stored_data[d_id]
[c70eb7c]232       
[665c083]233        self.delete_theory(data_id, theory_id)
[c70eb7c]234        if delete_all:
235            self.stored_data = {}
236            self.data_name_dict = {}
[213892bc]237           
[c70eb7c]238    def delete_theory(self, data_id, theory_id):
[213892bc]239        """
240        """
[665c083]241        for d_id in data_id:
242            if d_id in self.stored_data:
243                data_state = self.stored_data[d_id]
244                theory_list = data_state.get_theory()
245                if theory_id in theory_list.keys():
246                    del theory_list[theory_id]
[e88ebfd]247       
[6db811e]248           
[f444b20]249    def delete_by_id(self, id_list=None):
[3c44c66]250        """
[aebc4cc]251        save data and path
[3c44c66]252        """
[f444b20]253        for id in id_list:
254            if id in self.stored_data:
255                del self.stored_data[id]
[e88ebfd]256         
[aebc4cc]257   
[f444b20]258    def get_by_name(self, name_list=None):
[3c44c66]259        """
[f444b20]260        return a list of data given a list of data names
[3c44c66]261        """
[e88ebfd]262        _selected_data = {}
[f444b20]263        for selected_name in name_list:
[584c4c4]264            for id, data_state in self.stored_data.iteritems():
265                if data_state.data.name == selected_name:
[e88ebfd]266                    _selected_data[id] = data_state.data
267        return _selected_data
[f444b20]268   
269    def delete_by_name(self, name_list=None):
270        """
271        save data and path
272        """
273        for selected_name in name_list:
[584c4c4]274            for id, data_state in self.stored_data.iteritems():
275                if data_state.data.name == selected_name:
276                    del self._selected_data[id]
277                    del self.stored_data[data.id]
[f444b20]278
[e88ebfd]279    def get_data_state(self, data_id):
[f444b20]280        """
281        Send list of selected data
282        """
[e88ebfd]283        _selected_data_state = {}
284        for id in data_id:
285            if id in self.stored_data.keys():
286                _selected_data_state[id] = self.stored_data[id]
287        return _selected_data_state
[f444b20]288   
289    def get_all_data(self):
290        """
291        return list of all available data
292        """
[584c4c4]293        return self.stored_data
[f444b20]294   
295
[3c44c66]296       
Note: See TracBrowser for help on using the repository browser.