1 | """ |
---|
2 | Information relating to the CanSAS data format. These constants are used in |
---|
3 | the cansas_reader.py file to read in any version of the cansas format. |
---|
4 | """ |
---|
5 | class CansasConstants(object): |
---|
6 | """ |
---|
7 | The base class to define where all of the data is to be saved by |
---|
8 | cansas_reader.py. |
---|
9 | """ |
---|
10 | names = '' |
---|
11 | format = '' |
---|
12 | |
---|
13 | def __init__(self): |
---|
14 | self.names = self.CANSAS_NS |
---|
15 | self.format = self.CANSAS_FORMAT |
---|
16 | |
---|
17 | def iterate_namespace(self, namespace): |
---|
18 | """ |
---|
19 | Method to iterate through a cansas constants tree based on a list of |
---|
20 | names |
---|
21 | |
---|
22 | :param namespace: A list of names that match the tree structure of |
---|
23 | cansas_constants |
---|
24 | """ |
---|
25 | # The current level to look through in cansas_constants. |
---|
26 | return_me = CurrentLevel() |
---|
27 | return_me.current_level = self.CANSAS_FORMAT.get("SASentry") |
---|
28 | # Defaults for variable and datatype |
---|
29 | return_me.ns_variable = "{0}.meta_data[\"{2}\"] = \"{1}\"" |
---|
30 | return_me.ns_datatype = "content" |
---|
31 | return_me.ns_optional = True |
---|
32 | for name in namespace: |
---|
33 | try: |
---|
34 | if name != "SASentry": |
---|
35 | return_me.current_level = \ |
---|
36 | return_me.current_level.get("children").get(name, "") |
---|
37 | if return_me.current_level == "": |
---|
38 | return_me.current_level = \ |
---|
39 | return_me.current_level.get("<any>", "") |
---|
40 | cl_variable = return_me.current_level.get("variable", "") |
---|
41 | cl_datatype = return_me.current_level.get("storeas", "") |
---|
42 | cl_units_optional = \ |
---|
43 | return_me.current_level.get("units_required", "") |
---|
44 | # Where are how to store the variable for the given |
---|
45 | # namespace CANSAS_CONSTANTS tree is hierarchical, so |
---|
46 | # is no value, inherit |
---|
47 | return_me.ns_variable = cl_variable if cl_variable != "" \ |
---|
48 | else return_me.ns_variable |
---|
49 | return_me.ns_datatype = cl_datatype if cl_datatype != "" \ |
---|
50 | else return_me.ns_datatype |
---|
51 | return_me.ns_optional = cl_units_optional if \ |
---|
52 | cl_units_optional != return_me.ns_optional \ |
---|
53 | else return_me.ns_optional |
---|
54 | except AttributeError: |
---|
55 | return_me.ns_variable = "{0}.meta_data[\"{2}\"] = \"{1}\"" |
---|
56 | return_me.ns_datatype = "content" |
---|
57 | return_me.ns_optional = True |
---|
58 | return return_me |
---|
59 | |
---|
60 | def get_namespace_map(self): |
---|
61 | """ |
---|
62 | Helper method to get the names namespace list |
---|
63 | """ |
---|
64 | return self.names |
---|
65 | |
---|
66 | # CANSAS_NS holds the base namespace and default schema file information |
---|
67 | CANSAS_NS = {"1.0" : {"ns" : "cansas1d/1.0", |
---|
68 | "schema" : "cansas1d_v1_0.xsd" |
---|
69 | }, |
---|
70 | "1.1" : {"ns" : "urn:cansas1d:1.1", |
---|
71 | "schema" : "cansas1d_v1_1.xsd" |
---|
72 | } |
---|
73 | } |
---|
74 | |
---|
75 | # The constants below hold information on where to store the CanSAS data |
---|
76 | # when loaded in using sasview |
---|
77 | META_DATA = "{0}.meta_data[\"{2}\"] = \"{1}\"" |
---|
78 | ANY = {"variable" : "{0}.meta_data[\"{2}\"] = \'{1}\'", |
---|
79 | "storeas" : "content", |
---|
80 | } |
---|
81 | TITLE = {"variable" : "{0}.title = \"{1}\""} |
---|
82 | SASNOTE = {"variable" : "{0}.notes.append(\'{1}\')"} |
---|
83 | SASPROCESS_TERM = {"variable" : None, |
---|
84 | "attributes" : {"unit" : {"variable" : None}, |
---|
85 | "name" : {"variable" : None} |
---|
86 | } |
---|
87 | } |
---|
88 | SASPROCESS_SASPROCESSNOTE = {"variable" : None, |
---|
89 | "children" : {"<any>" : ANY} |
---|
90 | } |
---|
91 | SASPROCESS = {"variable" : None, |
---|
92 | "children" : {"name" : {"variable" : "{0}.name = \'{1}\'"}, |
---|
93 | "date" : {"variable" : "{0}.date = \'{1}\'"}, |
---|
94 | "description" : |
---|
95 | {"variable" : "{0}.description = \'{1}\'"}, |
---|
96 | "term" : SASPROCESS_TERM, |
---|
97 | "SASprocessnote" : SASPROCESS_SASPROCESSNOTE, |
---|
98 | "<any>" : ANY |
---|
99 | }, |
---|
100 | } |
---|
101 | RUN = {"variable" : "{0}.run.append(\"{1}\")", |
---|
102 | "attributes" : {"name" : |
---|
103 | {"variable" : "{0}.run_name[\"{3}\"] = \"{1}\""}} |
---|
104 | } |
---|
105 | SASDATA_IDATA_Q = {"variable" : "{0}.x = numpy.append({0}.x, {1})", |
---|
106 | "unit" : "x_unit", |
---|
107 | "attributes" : {"unit" : |
---|
108 | {"variable" : "{0}.xaxis(\"Q\", \'{1}\')", |
---|
109 | "storeas" : "content" |
---|
110 | } |
---|
111 | }, |
---|
112 | } |
---|
113 | SASDATA_IDATA_I = {"variable" : "{0}.y = numpy.append({0}.y, {1})", |
---|
114 | "unit" : "y_unit", |
---|
115 | "attributes" : {"unit" : |
---|
116 | {"variable" : "{0}.yaxis(\"Intensity\", \'{1}\')", |
---|
117 | "storeas" : "content" |
---|
118 | } |
---|
119 | }, |
---|
120 | } |
---|
121 | SASDATA_IDATA_IDEV = {"variable" : "{0}.dy = numpy.append({0}.dy, {1})", |
---|
122 | "unit" : "y_unit", |
---|
123 | "attributes" : {"unit" : |
---|
124 | {"variable" : META_DATA, |
---|
125 | "storeas" : "content" |
---|
126 | } |
---|
127 | }, |
---|
128 | } |
---|
129 | SASDATA_IDATA_QDEV = {"variable" : "{0}.dx = numpy.append({0}.dx, {1})", |
---|
130 | "unit" : "x_unit", |
---|
131 | "attributes" : {"unit" : |
---|
132 | {"variable" : META_DATA, |
---|
133 | "storeas" : "content" |
---|
134 | } |
---|
135 | }, |
---|
136 | } |
---|
137 | SASDATA_IDATA_DQL = {"variable" : "{0}.dxl = numpy.append({0}.dxl, {1})", |
---|
138 | "unit" : "x_unit", |
---|
139 | "attributes" : {"unit" : |
---|
140 | {"variable" : META_DATA, |
---|
141 | "storeas" : "content" |
---|
142 | } |
---|
143 | }, |
---|
144 | } |
---|
145 | SASDATA_IDATA_DQW = {"variable" : "{0}.dxw = numpy.append({0}.dxw, {1})", |
---|
146 | "unit" : "x_unit", |
---|
147 | "attributes" : {"unit" : |
---|
148 | {"variable" : META_DATA, |
---|
149 | "storeas" : "content" |
---|
150 | } |
---|
151 | }, |
---|
152 | } |
---|
153 | SASDATA_IDATA_QMEAN = {"storeas" : "content", |
---|
154 | "unit" : "x_unit", |
---|
155 | "variable" : META_DATA, |
---|
156 | "attributes" : {"unit" : {"variable" : META_DATA}}, |
---|
157 | } |
---|
158 | SASDATA_IDATA_SHADOWFACTOR = {"variable" : META_DATA, |
---|
159 | "storeas" : "content", |
---|
160 | } |
---|
161 | SASDATA_IDATA = {"storeas" : "float", |
---|
162 | "units_optional" : False, |
---|
163 | "variable" : None, |
---|
164 | "attributes" : {"name" : {"variable" : META_DATA, |
---|
165 | "storeas" : "content", |
---|
166 | }, |
---|
167 | "timestamp" : {"variable" : META_DATA, |
---|
168 | "storeas" : "timestamp", |
---|
169 | } |
---|
170 | }, |
---|
171 | "children" : {"Q" : SASDATA_IDATA_Q, |
---|
172 | "I" : SASDATA_IDATA_I, |
---|
173 | "Idev" : SASDATA_IDATA_IDEV, |
---|
174 | "Qdev" : SASDATA_IDATA_QDEV, |
---|
175 | "dQw" : SASDATA_IDATA_DQW, |
---|
176 | "dQl" : SASDATA_IDATA_DQL, |
---|
177 | "Qmean" : SASDATA_IDATA_QMEAN, |
---|
178 | "Shadowfactor" : SASDATA_IDATA_SHADOWFACTOR, |
---|
179 | "<any>" : ANY |
---|
180 | } |
---|
181 | } |
---|
182 | SASDATA = {"attributes" : {"name" : {"variable" : META_DATA,}}, |
---|
183 | "variable" : None, |
---|
184 | "children" : {"Idata" : SASDATA_IDATA, |
---|
185 | "<any>" : ANY |
---|
186 | } |
---|
187 | } |
---|
188 | SASTRANSSPEC_TDATA_LAMDBA = {"variable" : "{0}.wavelength.append({1})", |
---|
189 | "unit" : "wavelength_unit", |
---|
190 | "attributes" : |
---|
191 | {"unit" : |
---|
192 | {"variable" : "{0}.wavelength_unit = \"{1}\"", |
---|
193 | "storeas" : "content" |
---|
194 | } |
---|
195 | } |
---|
196 | } |
---|
197 | SASTRANSSPEC_TDATA_T = {"variable" : "{0}.transmission.append({1})", |
---|
198 | "unit" : "transmission_unit", |
---|
199 | "attributes" : |
---|
200 | {"unit" : |
---|
201 | {"variable" : "{0}.transmission_unit = \"{1}\"", |
---|
202 | "storeas" : "content" |
---|
203 | } |
---|
204 | } |
---|
205 | } |
---|
206 | SASTRANSSPEC_TDATA_TDEV = {"variable" : |
---|
207 | "{0}.transmission_deviation.append({1})", |
---|
208 | "unit" : "transmission_deviation_unit", |
---|
209 | "attributes" : |
---|
210 | {"unit" : |
---|
211 | {"variable" : |
---|
212 | "{0}.transmission_deviation_unit = \"{1}\"", |
---|
213 | "storeas" : "content" |
---|
214 | } |
---|
215 | } |
---|
216 | } |
---|
217 | SASTRANSSPEC_TDATA = {"storeas" : "float", |
---|
218 | "variable" : None, |
---|
219 | "children" : {"Lambda" : SASTRANSSPEC_TDATA_LAMDBA, |
---|
220 | "T" : SASTRANSSPEC_TDATA_T, |
---|
221 | "Tdev" : SASTRANSSPEC_TDATA_TDEV, |
---|
222 | "<any>" : ANY, |
---|
223 | } |
---|
224 | } |
---|
225 | SASTRANSSPEC = {"variable" : None, |
---|
226 | "children" : {"Tdata" : SASTRANSSPEC_TDATA, |
---|
227 | "<any>" : ANY, |
---|
228 | }, |
---|
229 | "attributes" : |
---|
230 | {"name" : |
---|
231 | {"variable" : "{0}.name = \"{1}\""}, |
---|
232 | "timestamp" : |
---|
233 | {"variable" : "{0}.timestamp = \"{1}\""}, |
---|
234 | } |
---|
235 | } |
---|
236 | SASSAMPLE_THICK = {"variable" : "{0}.sample.thickness = {1}", |
---|
237 | "unit" : "sample.thickness_unit", |
---|
238 | "storeas" : "float", |
---|
239 | "attributes" : |
---|
240 | {"unit" : |
---|
241 | {"variable" : "{0}.sample.thickness_unit = \"{1}\"", |
---|
242 | "storeas" : "content" |
---|
243 | } |
---|
244 | }, |
---|
245 | } |
---|
246 | SASSAMPLE_TRANS = {"variable" : "{0}.sample.transmission = {1}", |
---|
247 | "storeas" : "float", |
---|
248 | } |
---|
249 | SASSAMPLE_TEMP = {"variable" : "{0}.sample.temperature = {1}", |
---|
250 | "unit" : "sample.temperature_unit", |
---|
251 | "storeas" : "float", |
---|
252 | "attributes" : |
---|
253 | {"unit" : |
---|
254 | {"variable" : "{0}.sample.temperature_unit = \"{1}\"", |
---|
255 | "storeas" : "content" |
---|
256 | } |
---|
257 | }, |
---|
258 | } |
---|
259 | SASSAMPLE_POS_ATTR = {"unit" : {"variable" : |
---|
260 | "{0}.sample.position_unit = \"{1}\"", |
---|
261 | "storeas" : "content" |
---|
262 | } |
---|
263 | } |
---|
264 | SASSAMPLE_POS_X = {"variable" : "{0}.sample.position.x = {1}", |
---|
265 | "unit" : "sample.position_unit", |
---|
266 | "storeas" : "float", |
---|
267 | "attributes" : SASSAMPLE_POS_ATTR |
---|
268 | } |
---|
269 | SASSAMPLE_POS_Y = {"variable" : "{0}.sample.position.y = {1}", |
---|
270 | "unit" : "sample.position_unit", |
---|
271 | "storeas" : "float", |
---|
272 | "attributes" : SASSAMPLE_POS_ATTR |
---|
273 | } |
---|
274 | SASSAMPLE_POS_Z = {"variable" : "{0}.sample.position.z = {1}", |
---|
275 | "unit" : "sample.position_unit", |
---|
276 | "storeas" : "float", |
---|
277 | "attributes" : SASSAMPLE_POS_ATTR |
---|
278 | } |
---|
279 | SASSAMPLE_POS = {"children" : {"variable" : None, |
---|
280 | "x" : SASSAMPLE_POS_X, |
---|
281 | "y" : SASSAMPLE_POS_Y, |
---|
282 | "z" : SASSAMPLE_POS_Z, |
---|
283 | }, |
---|
284 | } |
---|
285 | SASSAMPLE_ORIENT_ATTR = {"unit" : |
---|
286 | {"variable" : |
---|
287 | "{0}.sample.orientation_unit = \"{1}\"", |
---|
288 | "storeas" : "content" |
---|
289 | } |
---|
290 | } |
---|
291 | SASSAMPLE_ORIENT_ROLL = {"variable" : "{0}.sample.orientation.x = {1}", |
---|
292 | "unit" : "sample.orientation_unit", |
---|
293 | "storeas" : "float", |
---|
294 | "attributes" : SASSAMPLE_ORIENT_ATTR |
---|
295 | } |
---|
296 | SASSAMPLE_ORIENT_PITCH = {"variable" : "{0}.sample.orientation.y = {1}", |
---|
297 | "unit" : "sample.orientation_unit", |
---|
298 | "storeas" : "float", |
---|
299 | "attributes" : SASSAMPLE_ORIENT_ATTR |
---|
300 | } |
---|
301 | SASSAMPLE_ORIENT_YAW = {"variable" : "{0}.sample.orientation.z = {1}", |
---|
302 | "unit" : "sample.orientation_unit", |
---|
303 | "storeas" : "float", |
---|
304 | "attributes" : SASSAMPLE_ORIENT_ATTR |
---|
305 | } |
---|
306 | SASSAMPLE_ORIENT = {"variable" : None, |
---|
307 | "children" : {"roll" : SASSAMPLE_ORIENT_ROLL, |
---|
308 | "pitch" : SASSAMPLE_ORIENT_PITCH, |
---|
309 | "yaw" : SASSAMPLE_ORIENT_YAW, |
---|
310 | }, |
---|
311 | } |
---|
312 | SASSAMPLE = {"attributes" : |
---|
313 | {"name" : {"variable" : "{0}.sample.name = \"{1}\""},}, |
---|
314 | "variable" : None, |
---|
315 | "children" : {"ID" : {"variable" : "{0}.sample.ID = \"{1}\""}, |
---|
316 | "thickness" : SASSAMPLE_THICK, |
---|
317 | "transmission" : SASSAMPLE_TRANS, |
---|
318 | "temperature" : SASSAMPLE_TEMP, |
---|
319 | "position" : SASSAMPLE_POS, |
---|
320 | "orientation" : SASSAMPLE_ORIENT, |
---|
321 | "details" : |
---|
322 | {"variable" : |
---|
323 | "{0}.sample.details.append(\"{1}\")"}, |
---|
324 | "<any>" : ANY |
---|
325 | }, |
---|
326 | } |
---|
327 | SASINSTR_SRC_BEAMSIZE_ATTR = {"unit" : |
---|
328 | "{0}.source.beam_size_unit = \"{1}\"", |
---|
329 | "storeas" : "content" |
---|
330 | } |
---|
331 | SASINSTR_SRC_BEAMSIZE_X = {"variable" : "{0}.source.beam_size.x = {1}", |
---|
332 | "unit" : "source.beam_size_unit", |
---|
333 | "storeas" : "float", |
---|
334 | "attributes" : SASINSTR_SRC_BEAMSIZE_ATTR |
---|
335 | } |
---|
336 | SASINSTR_SRC_BEAMSIZE_Y = {"variable" : "{0}.source.beam_size.y = {1}", |
---|
337 | "unit" : "source.beam_size_unit", |
---|
338 | "storeas" : "float", |
---|
339 | "attributes" : SASINSTR_SRC_BEAMSIZE_ATTR |
---|
340 | } |
---|
341 | SASINSTR_SRC_BEAMSIZE_Z = {"variable" : "{0}.source.beam_size.z = {1}", |
---|
342 | "unit" : "source.beam_size_unit", |
---|
343 | "storeas" : "float", |
---|
344 | "attributes" : SASINSTR_SRC_BEAMSIZE_ATTR |
---|
345 | } |
---|
346 | SASINSTR_SRC_BEAMSIZE = {"attributes" : |
---|
347 | {"name" : {"variable" : |
---|
348 | "{0}.source.beam_size_name = \"{1}\""}}, |
---|
349 | "variable" : None, |
---|
350 | "children" : {"x" : SASINSTR_SRC_BEAMSIZE_X, |
---|
351 | "y" : SASINSTR_SRC_BEAMSIZE_Y, |
---|
352 | "z" : SASINSTR_SRC_BEAMSIZE_Z, |
---|
353 | } |
---|
354 | } |
---|
355 | SASINSTR_SRC_WL = {"variable" : "{0}.source.wavelength = {1}", |
---|
356 | "unit" : "source.wavelength_unit", |
---|
357 | "storeas" : "float", |
---|
358 | "attributes" : |
---|
359 | {"unit" : |
---|
360 | {"variable" : "{0}.source.wavelength_unit = \"{1}\"", |
---|
361 | "storeas" : "content" |
---|
362 | }, |
---|
363 | } |
---|
364 | } |
---|
365 | SASINSTR_SRC_WL_MIN = {"variable" : "{0}.source.wavelength_min = {1}", |
---|
366 | "unit" : "source.wavelength_min_unit", |
---|
367 | "storeas" : "float", |
---|
368 | "attributes" : |
---|
369 | {"unit" : |
---|
370 | {"variable" : |
---|
371 | "{0}.source.wavelength_min_unit = \"{1}\"", |
---|
372 | "storeas" : "content" |
---|
373 | }, |
---|
374 | } |
---|
375 | } |
---|
376 | SASINSTR_SRC_WL_MAX = {"variable" : "{0}.source.wavelength_max = {1}", |
---|
377 | "unit" : "source.wavelength_max_unit", |
---|
378 | "storeas" : "float", |
---|
379 | "attributes" : |
---|
380 | {"unit" : |
---|
381 | {"variable" : |
---|
382 | "{0}.source.wavelength_max_unit = \"{1}\"", |
---|
383 | "storeas" : "content" |
---|
384 | }, |
---|
385 | } |
---|
386 | } |
---|
387 | SASINSTR_SRC_WL_SPR = {"variable" : "{0}.source.wavelength_spread = {1}", |
---|
388 | "unit" : "source.wavelength_spread_unit", |
---|
389 | "storeas" : "float", |
---|
390 | "attributes" : |
---|
391 | {"unit" : |
---|
392 | {"variable" : |
---|
393 | "{0}.source.wavelength_spread_unit = \"{1}\"", |
---|
394 | "storeas" : "content" |
---|
395 | }, |
---|
396 | } |
---|
397 | } |
---|
398 | SASINSTR_SRC = {"attributes" : {"name" : {"variable" : |
---|
399 | "{0}.source.name = \"{1}\""}}, |
---|
400 | "variable" : None, |
---|
401 | "children" : {"radiation" : |
---|
402 | {"variable" : |
---|
403 | "{0}.source.radiation = \"{1}\""}, |
---|
404 | "beam_size" : SASINSTR_SRC_BEAMSIZE, |
---|
405 | "beam_shape" : |
---|
406 | {"variable" : |
---|
407 | "{0}.source.beam_shape = \"{1}\""}, |
---|
408 | "wavelength" : SASINSTR_SRC_WL, |
---|
409 | "wavelength_min" : SASINSTR_SRC_WL_MIN, |
---|
410 | "wavelength_max" : SASINSTR_SRC_WL_MAX, |
---|
411 | "wavelength_spread" : SASINSTR_SRC_WL_SPR, |
---|
412 | }, |
---|
413 | } |
---|
414 | SASINSTR_COLL_APER_ATTR = {"unit" : {"variable" : "{0}.size_unit = \"{1}\"", |
---|
415 | "storeas" : "content" |
---|
416 | }, |
---|
417 | } |
---|
418 | SASINSTR_COLL_APER_X = {"variable" : "{0}.size.x = {1}", |
---|
419 | "unit" : "size_unit", |
---|
420 | "storeas" : "float", |
---|
421 | "attributes" : SASINSTR_COLL_APER_ATTR |
---|
422 | } |
---|
423 | SASINSTR_COLL_APER_Y = {"variable" : "{0}.size.y = {1}", |
---|
424 | "unit" : "size_unit", |
---|
425 | "storeas" : "float", |
---|
426 | "attributes" : SASINSTR_COLL_APER_ATTR |
---|
427 | } |
---|
428 | SASINSTR_COLL_APER_Z = {"variable" : "{0}.size.z = {1}", |
---|
429 | "unit" : "size_unit", |
---|
430 | "storeas" : "float", |
---|
431 | "attributes" : SASINSTR_COLL_APER_ATTR |
---|
432 | } |
---|
433 | SASINSTR_COLL_APER_SIZE = {"attributes" : |
---|
434 | {"unit" : {"variable" : |
---|
435 | "{0}.size_unit = \"{1}\""}}, |
---|
436 | "children" : {"storeas" : "float", |
---|
437 | "x" : SASINSTR_COLL_APER_X, |
---|
438 | "y" : SASINSTR_COLL_APER_Y, |
---|
439 | "z" : SASINSTR_COLL_APER_Z, |
---|
440 | } |
---|
441 | } |
---|
442 | SASINSTR_COLL_APER_DIST = {"storeas" : "float", |
---|
443 | "attributes" : |
---|
444 | {"storeas" : "content", |
---|
445 | "unit" : {"variable" : |
---|
446 | "{0}.distance_unit = \"{1}\""} |
---|
447 | }, |
---|
448 | "variable" : "{0}.distance = {1}", |
---|
449 | "unit" : "distance_unit", |
---|
450 | } |
---|
451 | SASINSTR_COLL_APER = {"variable" : None, |
---|
452 | "attributes" : {"name" : {"variable" : |
---|
453 | "{0}.name = \"{1}\""}, |
---|
454 | "type" : {"variable" : |
---|
455 | "{0}.type = \"{1}\""}, |
---|
456 | }, |
---|
457 | "children" : {"size" : SASINSTR_COLL_APER_SIZE, |
---|
458 | "distance" : SASINSTR_COLL_APER_DIST |
---|
459 | } |
---|
460 | } |
---|
461 | SASINSTR_COLL = {"attributes" : |
---|
462 | {"name" : {"variable" : "{0}.name = \"{1}\""}}, |
---|
463 | "variable" : None, |
---|
464 | "children" : |
---|
465 | {"length" : |
---|
466 | {"variable" : "{0}.length = {1}", |
---|
467 | "unit" : "length_unit", |
---|
468 | "storeas" : "float", |
---|
469 | "attributes" : |
---|
470 | {"storeas" : "content", |
---|
471 | "unit" : {"variable" : "{0}.length_unit = \"{1}\""} |
---|
472 | }, |
---|
473 | }, |
---|
474 | "aperture" : SASINSTR_COLL_APER, |
---|
475 | }, |
---|
476 | } |
---|
477 | SASINSTR_DET_SDD = {"variable" : "{0}.distance = {1}", |
---|
478 | "unit" : "distance_unit", |
---|
479 | "attributes" : |
---|
480 | {"unit" : |
---|
481 | {"variable" : "{0}.distance_unit = \"{1}\"", |
---|
482 | "storeas" : "content" |
---|
483 | } |
---|
484 | }, |
---|
485 | } |
---|
486 | SASINSTR_DET_OFF_ATTR = {"unit" : {"variable" : "{0}.offset_unit = \"{1}\"", |
---|
487 | "storeas" : "content" |
---|
488 | }, |
---|
489 | } |
---|
490 | SASINSTR_DET_OFF_X = {"variable" : "{0}.offset.x = {1}", |
---|
491 | "unit" : "offset_unit", |
---|
492 | "attributes" : SASINSTR_DET_OFF_ATTR |
---|
493 | } |
---|
494 | SASINSTR_DET_OFF_Y = {"variable" : "{0}.offset.y = {1}", |
---|
495 | "unit" : "offset_unit", |
---|
496 | "attributes" : SASINSTR_DET_OFF_ATTR |
---|
497 | } |
---|
498 | SASINSTR_DET_OFF_Z = {"variable" : "{0}.offset.z = {1}", |
---|
499 | "unit" : "offset_unit", |
---|
500 | "attributes" : SASINSTR_DET_OFF_ATTR |
---|
501 | } |
---|
502 | SASINSTR_DET_OFF = {"variable" : None, |
---|
503 | "children" : {"x" : SASINSTR_DET_OFF_X, |
---|
504 | "y" : SASINSTR_DET_OFF_Y, |
---|
505 | "z" : SASINSTR_DET_OFF_Z, |
---|
506 | } |
---|
507 | } |
---|
508 | SASINSTR_DET_OR_ATTR = {"unit" : "{0}.orientation_unit = \"{1}\"", |
---|
509 | "storeas" : "content" |
---|
510 | } |
---|
511 | SASINSTR_DET_OR_ROLL = {"variable" : "{0}.orientation.x = {1}", |
---|
512 | "unit" : "orientation_unit", |
---|
513 | "attributes" : SASINSTR_DET_OR_ATTR |
---|
514 | } |
---|
515 | SASINSTR_DET_OR_PITCH = {"variable" : "{0}.orientation.y = {1}", |
---|
516 | "unit" : "orientation_unit", |
---|
517 | "attributes" : SASINSTR_DET_OR_ATTR |
---|
518 | } |
---|
519 | SASINSTR_DET_OR_YAW = {"variable" : "{0}.orientation.z = {1}", |
---|
520 | "unit" : "orientation_unit", |
---|
521 | "attributes" : SASINSTR_DET_OR_ATTR |
---|
522 | } |
---|
523 | SASINSTR_DET_OR = {"variable" : None, |
---|
524 | "children" : {"roll" : SASINSTR_DET_OR_ROLL, |
---|
525 | "pitch" : SASINSTR_DET_OR_PITCH, |
---|
526 | "yaw" : SASINSTR_DET_OR_YAW, |
---|
527 | } |
---|
528 | } |
---|
529 | SASINSTR_DET_BC_X = {"variable" : "{0}.beam_center.x = {1}", |
---|
530 | "unit" : "beam_center_unit", |
---|
531 | "attributes" : |
---|
532 | {"unit" : "{0}.beam_center_unit = \"{1}\"", |
---|
533 | "storeas" : "content" |
---|
534 | } |
---|
535 | } |
---|
536 | SASINSTR_DET_BC_Y = {"variable" : "{0}.beam_center.y = {1}", |
---|
537 | "unit" : "beam_center_unit", |
---|
538 | "attributes" : |
---|
539 | {"unit" : "{0}.beam_center_unit = \"{1}\"", |
---|
540 | "storeas" : "content" |
---|
541 | } |
---|
542 | } |
---|
543 | SASINSTR_DET_BC_Z = {"variable" : "{0}.beam_center.z = {1}", |
---|
544 | "unit" : "beam_center_unit", |
---|
545 | "attributes" : |
---|
546 | {"unit" : "{0}.beam_center_unit = \"{1}\"", |
---|
547 | "storeas" : "content" |
---|
548 | } |
---|
549 | } |
---|
550 | SASINSTR_DET_BC = {"variable" : None, |
---|
551 | "children" : {"x" : SASINSTR_DET_BC_X, |
---|
552 | "y" : SASINSTR_DET_BC_Y, |
---|
553 | "z" : SASINSTR_DET_BC_Z, |
---|
554 | } |
---|
555 | } |
---|
556 | SASINSTR_DET_PIXEL_X = {"variable" : "{0}.pixel_size.x = {1}", |
---|
557 | "unit" : "pixel_size_unit", |
---|
558 | "attributes" : |
---|
559 | {"unit" : "{0}.pixel_size_unit = \"{1}\"", |
---|
560 | "storeas" : "content" |
---|
561 | } |
---|
562 | } |
---|
563 | SASINSTR_DET_PIXEL_Y = {"variable" : "{0}.pixel_size.y = {1}", |
---|
564 | "unit" : "pixel_size_unit", |
---|
565 | "attributes" : |
---|
566 | {"unit" : "{0}.pixel_size_unit = \"{1}\"", |
---|
567 | "storeas" : "content" |
---|
568 | } |
---|
569 | } |
---|
570 | SASINSTR_DET_PIXEL_Z = {"variable" : "{0}.pixel_size.z = {1}", |
---|
571 | "unit" : "pixel_size_unit", |
---|
572 | "attributes" : |
---|
573 | {"unit" : "{0}.pixel_size_unit = \"{1}\"", |
---|
574 | "storeas" : "content" |
---|
575 | } |
---|
576 | } |
---|
577 | SASINSTR_DET_PIXEL = {"variable" : None, |
---|
578 | "children" : {"x" : SASINSTR_DET_PIXEL_X, |
---|
579 | "y" : SASINSTR_DET_PIXEL_Y, |
---|
580 | "z" : SASINSTR_DET_PIXEL_Z, |
---|
581 | } |
---|
582 | } |
---|
583 | SASINSTR_DET_SLIT = {"variable" : "{0}.slit_length = {1}", |
---|
584 | "unit" : "slit_length_unit", |
---|
585 | "attributes" : |
---|
586 | {"unit" : |
---|
587 | {"variable" : "{0}.slit_length_unit = \"{1}\"", |
---|
588 | "storeas" : "content" |
---|
589 | } |
---|
590 | } |
---|
591 | } |
---|
592 | SASINSTR_DET = {"storeas" : "float", |
---|
593 | "variable" : None, |
---|
594 | "attributes" : {"name" : |
---|
595 | {"storeas" : "content", |
---|
596 | "variable" : "{0}.name = \"{1}\"", |
---|
597 | } |
---|
598 | }, |
---|
599 | "children" : {"name" : {"storeas" : "content", |
---|
600 | "variable" : "{0}.name = \"{1}\"", |
---|
601 | }, |
---|
602 | "SDD" : SASINSTR_DET_SDD, |
---|
603 | "offset" : SASINSTR_DET_OFF, |
---|
604 | "orientation" : SASINSTR_DET_OR, |
---|
605 | "beam_center" : SASINSTR_DET_BC, |
---|
606 | "pixel_size" : SASINSTR_DET_PIXEL, |
---|
607 | "slit_length" : SASINSTR_DET_SLIT, |
---|
608 | } |
---|
609 | } |
---|
610 | SASINSTR = {"variable" : None, |
---|
611 | "children" : |
---|
612 | {"variable" : None, |
---|
613 | "name" : {"variable" : "{0}.instrument = \"{1}\""}, |
---|
614 | "SASsource" : SASINSTR_SRC, |
---|
615 | "SAScollimation" : SASINSTR_COLL, |
---|
616 | "SASdetector" : SASINSTR_DET, |
---|
617 | }, |
---|
618 | } |
---|
619 | CANSAS_FORMAT = {"SASentry" : |
---|
620 | {"units_optional" : True, |
---|
621 | "variable" : None, |
---|
622 | "storeas" : "content", |
---|
623 | "attributes" : {"name" : |
---|
624 | {"variable" : |
---|
625 | "{0}.run_name[\"{3}\"] = \"{1}\""}}, |
---|
626 | "children" : {"Title" : TITLE, |
---|
627 | "Run" : RUN, |
---|
628 | "SASdata" : SASDATA, |
---|
629 | "SAStransmission_spectrum" : SASTRANSSPEC, |
---|
630 | "SASsample" : SASSAMPLE, |
---|
631 | "SASinstrument" : SASINSTR, |
---|
632 | "SASprocess" : SASPROCESS, |
---|
633 | "SASnote" : SASNOTE, |
---|
634 | "<any>" : ANY, |
---|
635 | } |
---|
636 | } |
---|
637 | } |
---|
638 | |
---|
639 | |
---|
640 | class CurrentLevel(object): |
---|
641 | """ |
---|
642 | A helper class to hold information on where you are in the constants tree |
---|
643 | """ |
---|
644 | |
---|
645 | current_level = '' |
---|
646 | ns_variable = '' |
---|
647 | ns_datatype = '' |
---|
648 | ns_optional = True |
---|
649 | |
---|
650 | def __init__(self): |
---|
651 | self.current_level = {} |
---|
652 | self.ns_variable = '' |
---|
653 | self.ns_datatype = "content" |
---|
654 | self.ns_optional = True |
---|
655 | |
---|
656 | def get_current_level(self): |
---|
657 | """ |
---|
658 | Helper method to get the current_level map |
---|
659 | """ |
---|
660 | return self.current_level |
---|
661 | |
---|
662 | def get_data_type(self): |
---|
663 | """ |
---|
664 | Helper method to get the ns_datatype label |
---|
665 | """ |
---|
666 | return self.ns_datatype |
---|
667 | |
---|
668 | def get_variable(self): |
---|
669 | """ |
---|
670 | Helper method to get the ns_variable label |
---|
671 | """ |
---|
672 | return self.ns_variable |
---|