added possibility to read real numbers as microstructure indices (not only integers)
This commit is contained in:
parent
36c88cde02
commit
d42f8d5fd4
|
@ -517,21 +517,25 @@ class ASCIItable():
|
||||||
|
|
||||||
# ------------------------------------------------------------------
|
# ------------------------------------------------------------------
|
||||||
def microstructure_read(self,
|
def microstructure_read(self,
|
||||||
grid):
|
grid,
|
||||||
|
type = 'i'):
|
||||||
"""read microstructure data (from .geom format)"""
|
"""read microstructure data (from .geom format)"""
|
||||||
N = grid.prod() # expected number of microstructure indices in data
|
def datatype(item):
|
||||||
microstructure = np.zeros(N,'i') # initialize as flat array
|
return int(item) if type.lower() == 'i' else float(item)
|
||||||
|
|
||||||
|
N = grid.prod() # expected number of microstructure indices in data
|
||||||
|
microstructure = np.zeros(N,type) # initialize as flat array
|
||||||
|
|
||||||
i = 0
|
i = 0
|
||||||
while i < N and self.data_read():
|
while i < N and self.data_read():
|
||||||
items = self.data
|
items = self.data
|
||||||
if len(items) > 2:
|
if len(items) > 2:
|
||||||
if items[1].lower() == 'of': items = [int(items[2])]*int(items[0])
|
if items[1].lower() == 'of': items = np.ones(datatype(items[0]))*datatype(items[2])
|
||||||
elif items[1].lower() == 'to': items = range(int(items[0]),1+int(items[2]))
|
elif items[1].lower() == 'to': items = np.arange(datatype(items[0]),1+datatype(items[2]))
|
||||||
else: items = map(int,items)
|
else: items = map(datatype,items)
|
||||||
else: items = map(int,items)
|
else: items = map(datatype,items)
|
||||||
|
|
||||||
s = min(len(items), N-i) # prevent overflow of microstructure array
|
s = min(len(items), N-i) # prevent overflow of microstructure array
|
||||||
microstructure[i:i+s] = items[:s]
|
microstructure[i:i+s] = items[:s]
|
||||||
i += s
|
i += s
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue