can now handle tiling of values (scalar [string,number] spread out to vector and such)

This commit is contained in:
Aritra Chakraborty 2015-10-09 14:22:41 +00:00
parent 196afb9b31
commit 723f135177
1 changed files with 21 additions and 16 deletions

View File

@ -1,7 +1,8 @@
#!/usr/bin/env python #!/usr/bin/env python
# -*- coding: UTF-8 no BOM -*- # -*- coding: UTF-8 no BOM -*-
import os,re,sys import os,re,sys,string,fnmatch,math,random
import numpy as np
from optparse import OptionParser from optparse import OptionParser
import damask import damask
@ -68,16 +69,11 @@ for name in filenames:
specials = { \ specials = { \
'_row_': 0, '_row_': 0,
} }
labels = []
positions = []
for position,label in enumerate(table.labels):
checker = [position in table.label_indexrange(needle) for needle in options.labels]
if any(checker) == True:
labels.append(label)
positions.append(position)
interpolator = [] interpolator = []
condition = options.condition # copy per file, might be altered condition = options.condition # copy per file, since might be altered inline
breaker = False
for position,operand in enumerate(set(re.findall(r'#(([s]#)?(.+?))#',condition))): # find three groups for position,operand in enumerate(set(re.findall(r'#(([s]#)?(.+?))#',condition))): # find three groups
condition = condition.replace('#'+operand[0]+'#', condition = condition.replace('#'+operand[0]+'#',
{ '': '{%i}'%position, { '': '{%i}'%position,
@ -88,9 +84,13 @@ for name in filenames:
try: try:
interpolator += ['%s(table.data[%i])'%({ '':'float', interpolator += ['%s(table.data[%i])'%({ '':'float',
's#':'str'}[operand[1]], 's#':'str'}[operand[1]],
table.labels.index(operand[2]))] table.labels.index(operand[2]))] # ccould be generalized to indexrange as array lookup
except: except:
parser.error('column %s not found...\n'%operand[2]) damask.util.croak('column %s not found.'%operand[2])
breaker = True
if breaker: continue # found mistake in condition evaluation --> next file
evaluator_condition = "'" + condition + "'.format(" + ','.join(interpolator) + ")" evaluator_condition = "'" + condition + "'.format(" + ','.join(interpolator) + ")"
#----------------------------------- Formula ------------------------------------------------------- #----------------------------------- Formula -------------------------------------------------------
@ -114,7 +114,9 @@ for name in filenames:
formula = formula.replace('#'+column+'#',replacement) formula = formula.replace('#'+column+'#',replacement)
if label not in brokenFormula: if label not in brokenFormula:
evaluator[label] = formula evaluator[label] = formula
# ------------------------------------------ assemble header --------------------------------------- # ------------------------------------------ assemble header ---------------------------------------
table.info_append(scriptID + '\t' + ' '.join(sys.argv[1:])) # read ASCII header info table.info_append(scriptID + '\t' + ' '.join(sys.argv[1:])) # read ASCII header info
table.labels # update with label set table.labels # update with label set
table.head_write() table.head_write()
@ -124,10 +126,13 @@ for name in filenames:
outputAlive = True outputAlive = True
while outputAlive and table.data_read(): # read next data line of ASCII table while outputAlive and table.data_read(): # read next data line of ASCII table
specials['_row_'] += 1 specials['_row_'] += 1
if condition == '' or eval(eval(evaluator_condition)): # location of change if condition == '' or eval(eval(evaluator_condition)): # test row for condition
for label in [x for x in options.labels if x not in set(brokenFormula)]: for label in [x for x in options.labels if x not in set(brokenFormula)]:
for i in xrange(len(positions)): indices = table.label_indexrange(label) # affected columns
table.data[positions[i]] = unravel(eval(evaluator[labels[i]])) probe = np.array(eval(evaluator[label])) # get formula result (scalar, array, etc.)
container = np.tile(probe,np.ceil(float(len(indices))/probe.size))[:len(indices)] # spread formula result into given number of columns
for i,ind in enumerate(indices): # copy one by one as table.data is NOT a numpy array
table.data[ind] = container[i]
outputAlive = table.data_write() # output processed line outputAlive = table.data_write() # output processed line