allow asciitable to use file handle instead of string (following e.g. numpy.genfromtxt)

This commit is contained in:
Martin Diehl 2015-09-16 19:44:11 +00:00
parent 24bd3a6eee
commit 6a3a0f3859
2 changed files with 29 additions and 20 deletions

View File

@ -37,11 +37,18 @@ class ASCIItable():
self.__IO__['inPlace'] = not outname and name and not readonly self.__IO__['inPlace'] = not outname and name and not readonly
if self.__IO__['inPlace']: outname = name + self.tmpext # transparently create tmp file if self.__IO__['inPlace']: outname = name + self.tmpext # transparently create tmp file
try:
self.__IO__['in'] = (open( name,'r') if os.access( name, os.R_OK) else None) if name else sys.stdin self.__IO__['in'] = (open( name,'r') if os.access( name, os.R_OK) else None) if name else sys.stdin
except TypeError:
self.__IO__['in'] = name
try:
self.__IO__['out'] = (open(outname,'w') if (not os.path.isfile(outname) \ self.__IO__['out'] = (open(outname,'w') if (not os.path.isfile(outname) \
or os.access(outname, os.W_OK)) \ or os.access(outname, os.W_OK)) \
and (not self.__IO__['inPlace'] \ and (not self.__IO__['inPlace'] \
or os.access(name, os.W_OK)) else None) if outname else sys.stdout or os.access(name, os.W_OK)) else None) if outname else sys.stdout
except TypeError:
self.__IO__['out'] = outname
self.info = [] self.info = []
self.labels = [] self.labels = []

View File

@ -92,7 +92,7 @@ class myThread (threading.Thread):
perturbedSeedsVFile = StringIO() perturbedSeedsVFile = StringIO()
myBestSeedsVFile.reset() myBestSeedsVFile.reset()
perturbedSeedsTable = damask.ASCIItable(myBestSeedsVFile,perturbedSeedsVFile,labels=True) # read current best fitting seed file and to perturbed seed file perturbedSeedsTable = damask.ASCIItable(myBestSeedsVFile,perturbedSeedsVFile,labeled=True) # read current best fitting seed file and to perturbed seed file
perturbedSeedsTable.head_read() perturbedSeedsTable.head_read()
perturbedSeedsTable.head_write() perturbedSeedsTable.head_write()
outputAlive=True outputAlive=True
@ -115,7 +115,7 @@ class myThread (threading.Thread):
' -g '+' '.join(map(str, options.grid)),streamIn=perturbedSeedsVFile)[0]) ' -g '+' '.join(map(str, options.grid)),streamIn=perturbedSeedsVFile)[0])
perturbedGeomVFile.reset() perturbedGeomVFile.reset()
#--- evaluate current seeds file ---------------------------------------------------------------------- #--- evaluate current seeds file ----------------------------------------------------------------------
perturbedGeomTable = damask.ASCIItable(perturbedGeomVFile,labels=False) perturbedGeomTable = damask.ASCIItable(perturbedGeomVFile,labeled=False,readonly=True)
perturbedGeomTable.head_read() perturbedGeomTable.head_read()
for i in perturbedGeomTable.info: for i in perturbedGeomTable.info:
if i.startswith('microstructures'): myNmicrostructures = int(i.split('\t')[1]) if i.startswith('microstructures'): myNmicrostructures = int(i.split('\t')[1])
@ -232,17 +232,19 @@ points = float(reduce(mul,options.grid))
# ----------- calculate target distribution and bin edges # ----------- calculate target distribution and bin edges
with open(os.path.splitext(os.path.basename(options.target))[0]+'.geom') as targetGeomFile: targetGeomFile = os.path.splitext(os.path.basename(options.target))[0]+'.geom'
targetGeomTable = damask.ASCIItable(targetGeomFile,labels=False) targetGeomTable = damask.ASCIItable(targetGeomFile,labeled=False,readonly=True)
targetGeomTable.head_read() targetGeomTable.head_read()
for i in targetGeomTable.info:
if i.startswith('microstructures'): nMicrostructures = int(i.split()[1])
if i.startswith('grid'): targetPoints = np.array(map(float,i.split()[2:7:2])).prod()
targetGeomTable.data_readArray() for i in targetGeomTable.info:
targetVolFrac = np.bincount(targetGeomTable.data.astype(int).ravel())[1:nMicrostructures+1]/targetPoints if i.startswith('microstructures'): nMicrostructures = int(i.split()[1])
target=[] if i.startswith('grid'): targetPoints = int(np.array(map(float,i.split()[2:7:2])).prod())
for i in xrange(1,nMicrostructures+1):
targetGeomTable.data_readArray()
targetVolFrac = np.bincount(targetGeomTable.data.astype(int).ravel())[1:nMicrostructures+1]/targetPoints
target=[]
for i in xrange(1,nMicrostructures+1):
targetHist,targetBins = np.histogram(targetVolFrac,bins=i) #bin boundaries targetHist,targetBins = np.histogram(targetVolFrac,bins=i) #bin boundaries
target.append({'histogram':targetHist,'bins':targetBins}) target.append({'histogram':targetHist,'bins':targetBins})
@ -264,7 +266,7 @@ initialGeomVFile = StringIO()
initialGeomVFile.write(execute('geom_fromVoronoiTessellation '+ initialGeomVFile.write(execute('geom_fromVoronoiTessellation '+
' -g '+' '.join(map(str, options.grid)),bestSeedsVFile)[0]) ' -g '+' '.join(map(str, options.grid)),bestSeedsVFile)[0])
initialGeomVFile.reset() initialGeomVFile.reset()
initialGeomTable = damask.ASCIItable(initialGeomVFile,labels=False) initialGeomTable = damask.ASCIItable(initialGeomVFile,labeled=False,readonly=True)
initialGeomTable.head_read() initialGeomTable.head_read()
for i in initialGeomTable.info: for i in initialGeomTable.info:
if i.startswith('microstructures'): initialMicrostructures = int(i.split('\t')[1]) if i.startswith('microstructures'): initialMicrostructures = int(i.split('\t')[1])