-
Notifications
You must be signed in to change notification settings - Fork 8
/
RecipeParser.py
75 lines (62 loc) · 2.7 KB
/
RecipeParser.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
##############################################################
#
# RecipeParser:
# Contains a mixin to automatically parse
# and run phase retrieval recipe strings.
#
# Siddharth Maddali
# Argonne National Laboratory
# Sep 2019
# 6xlq96aeq@relay.firefox.com
#
##############################################################
class Mixin:
def generateAlgoDict( self ):
self._algodict = { # key = string, value = function handle
'BE':self.BinaryErosion,
'ER':self.ER,
'HIO':self.HIO,
'SF':self.SF,
'SR':self.Shrinkwrap
}
return
def _parseBlock( self, blockstr, show_progress ):
lst = blockstr.split( ':' )
conv = int if len( lst )==2 else float
if lst[0]=='SR':
arglist = [ conv( n ) for n in lst[1:] ] # no progress bar for shrinkwrap
else:
arglist = [ conv( n ) for n in lst[1:] ] + [ show_progress ]
self._algodict[ lst[0] ]( *tuple( arglist ) )
return
def runRecipe( self, recipestr, show_progress=False ):
'''
runRecipe( recipestr ):
Argument recipestr is a concatenation of smaller 'block' strings,
each of the form '<algo>:<iter>' and delimited by '+'. Here,
<algo> is the specific algorithm to be used and <iter> is the
number of desired iterations. For example, 'ER:30' denotes 30
iterations of ER.
For the special case of shrinkwrap, the block has the following
format: 'SR:<sigma>:<thresh>'. Please see Shrinkwrap documentation
for the meaning of sigma and thresh.
As an example, for a recipe of 40 iterations of ER followed by 25 HIO,
followed by 40 solvent flipping, with shrinkwrap (sigma=3, thresh=0.1)
after every 20 iterations of ER and SF, the recipe string is:
ER:20+SR:3:0.1+ER:20+SR:3:0.1+HIO:25+SF:20+SR:3:0.1+SF:20+SR:3:0.1
The above string is parsed and the recipe is automatically run by this
routine. Such recipe strings can easily be generated with Python's
fantastic string manipulation and list comprehension capabilities.
Full list of algorithm keys (TODO: make case-insensitive):
ER: error reduction
HIO: hybrid input/output
SF: solvent flipping
SR: shrinkwrap
BE: Binary erosion
PCC: Partial coherence correction (activated only when pcc==True)
'''
[
self._parseBlock( block, show_progress=show_progress )
for block in recipestr.split( '+' )
]; # Don't remove this semicolon!
return