-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse.py
executable file
·114 lines (92 loc) · 4.13 KB
/
parse.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#!/usr/bin/env python
"""
Parse DAXM indexation results (xml) to instances of daxm voxel
objects.
The script can be envoked as individual programe via CMD or imported
as a parser func for interactive data analysis.
"""
import numpy as np
import xml.etree.cElementTree as ET
from daxmexplorer.voxel import DAXMvoxel
def parse_xml(xmlfile,
namespace={'step':'http://sector34.xray.aps.anl.gov/34ide:indexResult'},
autopair=False,
forceNaNtoZero=True,
h5file=None):
voxels = []
tree = ET.parse(xmlfile)
root = tree.getroot()
ns = namespace
for i in range(len(root)):
step = root[i]
# locate next indexed voxel in xml file
target_str = 'step:indexing/step:pattern/step:recip_lattice/step:astar'
astar = step.find(target_str, ns)
if astar is None:
continue
# get coords
xsample = float(step.find('step:Xsample', ns).text)
ysample = float(step.find('step:Ysample', ns).text)
zsample = float(step.find('step:Zsample', ns).text)
depth = float(step.find('step:depth', ns).text)
# for scans with no wire, depth will be nan, which should be consider as zero.
if forceNaNtoZero:
depth = 0.0 if np.isnan(depth) else depth
coords = np.array([-xsample, -ysample, -zsample+depth])
# get pattern image name
h5img = step.find('step:detector/step:inputImage', ns).text
voxelname = h5img.split("/")[-1].replace(".h5", "")
# get peaks
xpix = step.find('step:detector/step:peaksXY/step:Xpixel', ns).text
ypix = step.find('step:detector/step:peaksXY/step:Ypixel', ns).text
xpix = np.nan if xpix is None else list(map(float, xpix.split()))
ypix = np.nan if ypix is None else list(map(float, ypix.split()))
peaks = np.stack((xpix, ypix))
# get scattering vectors
qx = step.find('step:detector/step:peaksXY/step:Qx', ns).text
qy = step.find('step:detector/step:peaksXY/step:Qy', ns).text
qz = step.find('step:detector/step:peaksXY/step:Qz', ns).text
qx = list(map(float, qx.split()))
qy = list(map(float, qy.split()))
qz = list(map(float, qz.split()))
scatter_vecs = np.stack((qx, qy, qz))
# get reciprocal base (a*, b*, c*)
astar_str = 'step:indexing/step:pattern/step:recip_lattice/step:astar'
bstar_str = 'step:indexing/step:pattern/step:recip_lattice/step:bstar'
cstar_str = 'step:indexing/step:pattern/step:recip_lattice/step:cstar'
astar = list(map(float, step.find(astar_str, ns).text.split()))
bstar = list(map(float, step.find(bstar_str, ns).text.split()))
cstar = list(map(float, step.find(cstar_str, ns).text.split()))
recip_base = np.column_stack((astar, bstar, cstar))
# get plane index (hkl)
h = step.find('step:indexing/step:pattern/step:hkl_s/step:h', ns).text
k = step.find('step:indexing/step:pattern/step:hkl_s/step:k', ns).text
l = step.find('step:indexing/step:pattern/step:hkl_s/step:l', ns).text
h = list(map(float, h.split()))
k = list(map(float, k.split()))
l = list(map(float, l.split()))
plane = np.stack((h, k, l))
# create the DAXM voxel
tmpvoxel = DAXMvoxel(name=voxelname,
ref_frame='APS',
coords=coords,
pattern_image=h5img,
scatter_vec=scatter_vecs,
plane=plane,
recip_base=recip_base,
peak=peaks,
depth=depth,
)
# pair scattering vectors with plane index
if autopair:
tmpvoxel.pair_scattervec_plane()
if h5file is not None:
tmpvoxel.write(h5file=h5file)
voxels.append(tmpvoxel)
return voxels
if __name__ == "__main__":
import sys
xmlfile = sys.argv[1]
print("parsing xml file: {}".format(xmlfile))
h5file = xmlfile.replace(".xml", ".h5")
parse_xml(xmlfile, h5file=h5file)