Changes in src/sas/sascalc/dataloader/readers/cansas_reader_HDF5.py [c94280c:8dec7e7] in sasview
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/sas/sascalc/dataloader/readers/cansas_reader_HDF5.py
rc94280c r8dec7e7 13 13 TransmissionSpectrum, Detector 14 14 from sas.sascalc.dataloader.data_info import combine_data_info_with_plottable 15 16 17 class Reader(): 15 from sas.sascalc.dataloader.loader_exceptions import FileContentsException, DefaultReaderException 16 from sas.sascalc.dataloader.file_reader_base_class import FileReader 17 18 19 class Reader(FileReader): 18 20 """ 19 21 A class for reading in CanSAS v2.0 data files. The existing iteration opens … … 40 42 # Raw file contents to be processed 41 43 raw_data = None 42 # Data info currently being read in43 current_datainfo = None44 # SASdata set currently being read in45 current_dataset = None46 44 # List of plottable1D objects that should be linked to the current_datainfo 47 45 data1d = None … … 56 54 # Flag to bypass extension check 57 55 allow_all = True 58 # List of files to return 59 output = None 60 61 def read(self, filename): 56 57 def get_file_contents(self): 62 58 """ 63 59 This is the general read method that all SasView data_loaders must have. … … 68 64 # Reinitialize when loading a new data file to reset all class variables 69 65 self.reset_class_variables() 66 67 filename = self.f_open.name 68 self.f_open.close() # IO handled by h5py 69 70 70 # Check that the file exists 71 71 if os.path.isfile(filename): … … 75 75 if extension in self.ext or self.allow_all: 76 76 # Load the data file 77 self.raw_data = h5py.File(filename, 'r') 77 try: 78 self.raw_data = h5py.File(filename, 'r') 79 except Exception as e: 80 if extension not in self.ext: 81 msg = "CanSAS2.0 HDF5 Reader could not load file {}".format(basename + extension) 82 raise DefaultReaderException(msg) 83 raise FileContentsException(e.message) 78 84 # Read in all child elements of top level SASroot 79 85 self.read_children(self.raw_data, []) … … 427 433 Data1D and Data2D objects 428 434 """ 429 430 435 # Type cast data arrays to float64 431 436 if len(self.current_datainfo.trans_spectrum) > 0: … … 451 456 # Type cast data arrays to float64 and find min/max as appropriate 452 457 for dataset in self.data2d: 453 dataset.data = dataset.data.astype(np.float64)454 dataset.err_data = dataset.err_data.astype(np.float64)455 if dataset.qx_data is not None:456 dataset.xmin = np.min(dataset.qx_data)457 dataset.xmax = np.max(dataset.qx_data)458 dataset.qx_data = dataset.qx_data.astype(np.float64)459 if dataset.dqx_data is not None:460 dataset.dqx_data = dataset.dqx_data.astype(np.float64)461 if dataset.qy_data is not None:462 dataset.ymin = np.min(dataset.qy_data)463 dataset.ymax = np.max(dataset.qy_data)464 dataset.qy_data = dataset.qy_data.astype(np.float64)465 if dataset.dqy_data is not None:466 dataset.dqy_data = dataset.dqy_data.astype(np.float64)467 if dataset.q_data is not None:468 dataset.q_data = dataset.q_data.astype(np.float64)469 458 zeros = np.ones(dataset.data.size, dtype=bool) 470 459 try: … … 489 478 dataset.x_bins = dataset.qx_data[:n_cols] 490 479 dataset.data = dataset.data.flatten() 491 492 final_dataset = combine_data_info_with_plottable( 493 dataset, self.current_datainfo) 494 self.output.append(final_dataset) 480 self.current_dataset = dataset 481 self.send_to_output() 495 482 496 483 for dataset in self.data1d: 497 if dataset.x is not None: 498 dataset.x = dataset.x.astype(np.float64) 499 dataset.xmin = np.min(dataset.x) 500 dataset.xmax = np.max(dataset.x) 501 if dataset.y is not None: 502 dataset.y = dataset.y.astype(np.float64) 503 dataset.ymin = np.min(dataset.y) 504 dataset.ymax = np.max(dataset.y) 505 if dataset.dx is not None: 506 dataset.dx = dataset.dx.astype(np.float64) 507 if dataset.dxl is not None: 508 dataset.dxl = dataset.dxl.astype(np.float64) 509 if dataset.dxw is not None: 510 dataset.dxw = dataset.dxw.astype(np.float64) 511 if dataset.dy is not None: 512 dataset.dy = dataset.dy.astype(np.float64) 513 final_dataset = combine_data_info_with_plottable( 514 dataset, self.current_datainfo) 515 self.output.append(final_dataset) 484 self.current_dataset = dataset 485 self.send_to_output() 516 486 517 487 def add_data_set(self, key=""):
Note: See TracChangeset
for help on using the changeset viewer.