Changes in / [e2b2473:f9ba422] in sasview
- Files:
-
- 7 added
- 9 edited
Legend:
- Unmodified
- Added
- Removed
-
src/sas/sascalc/dataloader/data_info.py
r17e257b5 ra1b8fee 1161 1161 final_dataset = None 1162 1162 if isinstance(data, plottable_1D): 1163 final_dataset = Data1D(data.x, data.y , isSesans=datainfo.isSesans)1163 final_dataset = Data1D(data.x, data.y) 1164 1164 final_dataset.dx = data.dx 1165 1165 final_dataset.dy = data.dy 1166 1166 final_dataset.dxl = data.dxl 1167 1167 final_dataset.dxw = data.dxw 1168 final_dataset.x_unit = data._xunit1169 final_dataset.y_unit = data._yunit1170 1168 final_dataset.xaxis(data._xaxis, data._xunit) 1171 1169 final_dataset.yaxis(data._yaxis, data._yunit) -
src/sas/sascalc/dataloader/file_reader_base_class.py
ra78a02f rdcb91cf 6 6 7 7 import os 8 import re9 8 import logging 10 9 import numpy as np … … 107 106 for data in self.output: 108 107 if isinstance(data, Data1D): 109 # Normalize the units for110 data.x_unit = self.format_unit(data.x_unit)111 data.y_unit = self.format_unit(data.y_unit)112 108 # Sort data by increasing x and remove 1st point 113 109 ind = np.lexsort((data.y, data.x)) … … 135 131 for dataset in self.output: 136 132 if isinstance(dataset, Data2D): 137 # Normalize the units for138 dataset.x_unit = self.format_unit(dataset.Q_unit)139 dataset.y_unit = self.format_unit(dataset.I_unit)140 133 dataset.data = dataset.data.astype(np.float64) 141 134 dataset.qx_data = dataset.qx_data.astype(np.float64) … … 162 155 dataset.data = dataset.data.flatten() 163 156 164 def format_unit(self, unit=None):165 """166 Format units a common way167 :param unit:168 :return:169 """170 if unit:171 split = unit.split("/")172 if len(split) == 1:173 return unit174 elif split[0] == '1':175 return "{0}^".format(split[1]) + "{-1}"176 else:177 return "{0}*{1}^".format(split[0], split[1]) + "{-1}"178 179 157 def set_all_to_none(self): 180 158 """ -
src/sas/sascalc/dataloader/readers/cansas_reader.py
ra78a02f rdcb91cf 299 299 self.current_dataset.dx = np.append(self.current_dataset.dx, data_point) 300 300 elif tagname == 'dQw': 301 if self.current_dataset.dxw is None: 302 self.current_dataset.dxw = np.empty(0) 301 if self.current_dataset.dqw is None: self.current_dataset.dqw = np.empty(0) 303 302 self.current_dataset.dxw = np.append(self.current_dataset.dxw, data_point) 304 303 elif tagname == 'dQl': 305 if self.current_dataset.dxl is None: 306 self.current_dataset.dxl = np.empty(0) 304 if self.current_dataset.dxl is None: self.current_dataset.dxl = np.empty(0) 307 305 self.current_dataset.dxl = np.append(self.current_dataset.dxl, data_point) 308 306 elif tagname == 'Qmean': -
src/sas/sascalc/dataloader/readers/danse_reader.py
ra78a02f r713a047 189 189 x_vals = np.tile(x_vals, (size_y, 1)).flatten() 190 190 y_vals = np.tile(y_vals, (size_x, 1)).T.flatten() 191 if (np.all(self.current_dataset.err_data == None) 192 or np.any(self.current_dataset.err_data <= 0)): 191 if self.current_dataset.err_data == np.all(np.array(None)) or np.any(self.current_dataset.err_data <= 0): 193 192 new_err_data = np.sqrt(np.abs(self.current_dataset.data)) 194 193 else: -
test/sasdataloader/test/utest_abs_reader.py
ra78a02f rce8c7bd 20 20 def setUp(self): 21 21 reader = AbsReader() 22 data = reader.read("jan08002.ABS") 23 self.data= data[0] 22 self.data = reader.read("jan08002.ABS") 24 23 25 24 def test_abs_checkdata(self): … … 48 47 self.assertEqual(self.data.detector[0].beam_center.y, center_y) 49 48 50 self.assertEqual(self.data.y_unit, ' cm^{-1}')49 self.assertEqual(self.data.y_unit, '1/cm') 51 50 self.assertEqual(self.data.x[0], 0.002618) 52 51 self.assertEqual(self.data.x[1], 0.007854) … … 70 69 # the generic loader should work as well 71 70 data = Loader().load("jan08002.ABS") 72 self.assertEqual(data [0].meta_data['loader'], "IGOR 1D")71 self.assertEqual(data.meta_data['loader'], "IGOR 1D") 73 72 74 73 class DanseReaderTests(unittest.TestCase): … … 76 75 def setUp(self): 77 76 reader = DANSEReader() 78 data = reader.read("MP_New.sans") 79 self.data = data[0] 77 self.data = reader.read("MP_New.sans") 80 78 81 79 def test_checkdata(self): … … 114 112 # the generic loader should work as well 115 113 data = Loader().load("MP_New.sans") 116 self.assertEqual(data [0].meta_data['loader'], "DANSE")114 self.assertEqual(data.meta_data['loader'], "DANSE") 117 115 118 116 … … 146 144 # Data 147 145 self.assertEqual(len(self.data.x), 2) 148 self.assertEqual(self.data.x_unit, ' A^{-1}')149 self.assertEqual(self.data.y_unit, ' cm^{-1}')146 self.assertEqual(self.data.x_unit, '1/A') 147 self.assertEqual(self.data.y_unit, '1/cm') 150 148 self.assertAlmostEqual(self.data.x[0], 0.02, 6) 151 149 self.assertAlmostEqual(self.data.y[0], 1000, 6) … … 259 257 self.assertTrue(item.date in ['04-Sep-2007 18:35:02', 260 258 '03-SEP-2006 11:42:47']) 259 print(item.term) 261 260 for t in item.term: 262 261 if (t['name'] == "ABS:DSTAND" … … 310 309 311 310 self.assertEqual(self.data.meta_data['loader'], "CanSAS XML 1D") 312 self.assertEqual(len(self.data.errors), 0) 311 print(self.data.errors) 312 self.assertEqual(len(self.data.errors), 1) 313 313 314 314 def test_slits(self): … … 324 324 # Data 325 325 self.assertEqual(len(self.data.x), 2) 326 self.assertEqual(self.data.x_unit, ' A^{-1}')327 self.assertEqual(self.data.y_unit, ' cm^{-1}')326 self.assertEqual(self.data.x_unit, '1/A') 327 self.assertEqual(self.data.y_unit, '1/cm') 328 328 self.assertEqual(self.data.x[0], 0.02) 329 329 self.assertEqual(self.data.y[0], 1000) … … 333 333 self.assertEqual(self.data.x[1], 0.03) 334 334 self.assertAlmostEquals(self.data.y[1], 1001.0) 335 self.assertEqual(self.data.dx [0], 0.0)335 self.assertEqual(self.data.dx, None) 336 336 self.assertEqual(self.data.dxl[1], 0.005) 337 337 self.assertEqual(self.data.dxw[1], 0.001) -
test/sasdataloader/test/utest_ascii.py
ra78a02f rad92c5a 32 32 self.assertEqual(self.f1.x[0],0.002618) 33 33 self.assertEqual(self.f1.x[9],0.0497) 34 self.assert True(self.f1.x_unit == 'A^{-1}')35 self.assert True(self.f1.y_unit == 'cm^{-1}')34 self.assertEqual(self.f1.x_unit, '1/A') 35 self.assertEqual(self.f1.y_unit, '1/cm') 36 36 37 37 self.assertEqual(self.f1.meta_data['loader'],"ASCII") -
test/sasdataloader/test/utest_cansas.py
r17e257b5 r1fc50fb2 20 20 21 21 from lxml import etree 22 from lxml.etree import XMLSyntaxError23 22 from xml.dom import minidom 24 23 … … 63 62 """ 64 63 invalid = StringIO.StringIO('<a><c></b></a>') 65 self.assertRaises(XMLSyntaxError, lambda: XMLreader(invalid))64 XMLreader(invalid) 66 65 67 66 def test_xml_validate(self): … … 303 302 self.assertTrue(data._yunit == "cm^{-1}") 304 303 self.assertTrue(data.y.size == 100) 305 self.assertAlmostEqual(data.y[ 40], 0.952749011516985)306 self.assertAlmostEqual(data.x[ 40], 0.3834415188257777)304 self.assertAlmostEqual(data.y[9], 0.952749011516985) 305 self.assertAlmostEqual(data.x[9], 0.3834415188257777) 307 306 self.assertAlmostEqual(len(data.meta_data), 0) 308 307 -
test/sasdataloader/test/utest_sesans.py
ra78a02f ra67c494 4 4 5 5 import unittest 6 from sas.sascalc.dataloader.loader_exceptions import FileContentsException,\7 DefaultReaderException8 6 from sas.sascalc.dataloader.readers.sesans_reader import Reader 9 7 from sas.sascalc.dataloader.loader import Loader … … 19 17 Test .SES in the full loader to make sure that the file type is correctly accepted 20 18 """ 21 file = Loader().load("sesans_examples/sphere2micron.ses") 22 f = file[0] 19 f = Loader().load("sesans_examples/sphere2micron.ses") 23 20 # self.assertEqual(f, 5) 24 21 self.assertEqual(len(f.x), 40) … … 37 34 Test .SES loading on a TOF dataset 38 35 """ 39 file = self.loader("sesans_examples/sphere_isis.ses") 40 f = file[0] 36 f = self.loader("sesans_examples/sphere_isis.ses") 41 37 self.assertEqual(len(f.x), 57) 42 38 self.assertEqual(f.x[-1], 19303.4) … … 52 48 """ 53 49 self.assertRaises( 54 FileContentsException,50 RuntimeError, 55 51 self.loader, 56 52 "sesans_examples/sesans_no_data.ses") … … 61 57 """ 62 58 self.assertRaises( 63 FileContentsException,59 RuntimeError, 64 60 self.loader, 65 61 "sesans_examples/no_spin_echo_unit.ses") 62 63 def test_sesans_no_version(self): 64 """ 65 Confirm that sesans files with no file format version raise an appropriate error 66 """ 67 self.assertRaises( 68 RuntimeError, 69 self.loader, 70 "sesans_examples/no_version.ses") 66 71 67 72 def test_sesans_future_version(self): … … 70 75 """ 71 76 self.assertRaises( 72 FileContentsException,77 RuntimeError, 73 78 self.loader, 74 79 "sesans_examples/next_gen.ses") … … 79 84 """ 80 85 self.assertRaises( 81 FileContentsException,86 RuntimeError, 82 87 self.loader, 83 88 "sesans_examples/no_wavelength.ses") … … 88 93 """ 89 94 self.assertRaises( 90 FileContentsException,95 RuntimeError, 91 96 self.loader, 92 97 "sesans_examples/too_many_headers.ses") -
test/utest_sasview.py
rb54440d raaf5e49 44 44 n_errors = 0 45 45 n_failures = 0 46 46 47 47 for d in (dirs if dirs else os.listdir(test_root)): 48 48 49 49 # Check for modules to be skipped 50 50 if d in SKIPPED_DIRS: 51 51 continue 52 52 53 53 54 54 # Go through modules looking for unit tests … … 64 64 #print std_out 65 65 #sys.exit() 66 has_failed = True 66 67 m = re.search("Ran ([0-9]+) test", std_out) 67 68 if m is not None: 69 has_failed = False 68 70 n_tests += int(m.group(1)) 69 has_tests = True70 else:71 has_tests = False72 71 73 has_failed = "FAILED (" in std_out 74 m = re.search("FAILED \(.*errors=([0-9]+)", std_out) 72 m = re.search("FAILED \(errors=([0-9]+)\)", std_out) 75 73 if m is not None: 74 has_failed = True 76 75 n_errors += int(m.group(1)) 77 m = re.search("FAILED \(.*failures=([0-9]+)", std_out) 76 77 m = re.search("FAILED \(failures=([0-9]+)\)", std_out) 78 78 if m is not None: 79 has_failed = True 79 80 n_failures += int(m.group(1)) 80 81 if has_failed or not has_tests:81 82 if has_failed: 82 83 failed += 1 83 84 print("Result for %s (%s): FAILED" % (module_name, module_dir)) … … 101 102 print(" Test errors: %d" % n_errors) 102 103 print("----------------------------------------------") 103 104 104 105 return failed 105 106 … … 109 110 if run_tests(dirs=dirs, all=all)>0: 110 111 sys.exit(1) 111 112
Note: See TracChangeset
for help on using the changeset viewer.