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
115
116
117
118
119
120
121
122
|
/*
* Revision Control Information
*
* $Source$
* $Author$
* $Revision$
* $Date$
*
*/
enum keys {
KEY_ESPRESSO, KEY_PLA_verify, KEY_check, KEY_contain, KEY_d1merge,
KEY_disjoint, KEY_dsharp, KEY_echo, KEY_essen, KEY_exact, KEY_expand,
KEY_gasp, KEY_intersect, KEY_irred, KEY_lexsort, KEY_make_sparse,
KEY_map, KEY_mapdc, KEY_minterms, KEY_opo, KEY_opoall,
KEY_pair, KEY_pairall, KEY_primes, KEY_qm, KEY_reduce, KEY_sharp,
KEY_simplify, KEY_so, KEY_so_both, KEY_stats, KEY_super_gasp, KEY_taut,
KEY_test, KEY_equiv, KEY_union, KEY_verify, KEY_MANY_ESPRESSO,
KEY_separate, KEY_xor, KEY_d1merge_in, KEY_fsm,
KEY_unknown
};
/* Lookup table for program options */
struct {
char *name;
enum keys key;
int num_plas;
bool needs_offset;
bool needs_dcset;
} option_table [] = {
/* ways to minimize functions */
"ESPRESSO", KEY_ESPRESSO, 1, TRUE, TRUE, /* must be first */
"many", KEY_MANY_ESPRESSO, 1, TRUE, TRUE,
"exact", KEY_exact, 1, TRUE, TRUE,
"qm", KEY_qm, 1, TRUE, TRUE,
"single_output", KEY_so, 1, TRUE, TRUE,
"so", KEY_so, 1, TRUE, TRUE,
"so_both", KEY_so_both, 1, TRUE, TRUE,
"simplify", KEY_simplify, 1, FALSE, FALSE,
"echo", KEY_echo, 1, FALSE, FALSE,
/* output phase assignment and assignment of inputs to two-bit decoders */
"opo", KEY_opo, 1, TRUE, TRUE,
"opoall", KEY_opoall, 1, TRUE, TRUE,
"pair", KEY_pair, 1, TRUE, TRUE,
"pairall", KEY_pairall, 1, TRUE, TRUE,
/* Ways to check covers */
"check", KEY_check, 1, TRUE, TRUE,
"stats", KEY_stats, 1, FALSE, FALSE,
"verify", KEY_verify, 2, FALSE, TRUE,
"PLAverify", KEY_PLA_verify, 2, FALSE, TRUE,
/* hacks */
"equiv", KEY_equiv, 1, TRUE, TRUE,
"map", KEY_map, 1, FALSE, FALSE,
"mapdc", KEY_mapdc, 1, FALSE, FALSE,
"fsm", KEY_fsm, 1, FALSE, TRUE,
/* the basic boolean operations on covers */
"contain", KEY_contain, 1, FALSE, FALSE,
"d1merge", KEY_d1merge, 1, FALSE, FALSE,
"d1merge_in", KEY_d1merge_in, 1, FALSE, FALSE,
"disjoint", KEY_disjoint, 1, TRUE, FALSE,
"dsharp", KEY_dsharp, 2, FALSE, FALSE,
"intersect", KEY_intersect, 2, FALSE, FALSE,
"minterms", KEY_minterms, 1, FALSE, FALSE,
"primes", KEY_primes, 1, FALSE, TRUE,
"separate", KEY_separate, 1, TRUE, TRUE,
"sharp", KEY_sharp, 2, FALSE, FALSE,
"union", KEY_union, 2, FALSE, FALSE,
"xor", KEY_xor, 2, TRUE, TRUE,
/* debugging only -- call each step of the espresso algorithm */
"essen", KEY_essen, 1, FALSE, TRUE,
"expand", KEY_expand, 1, TRUE, FALSE,
"gasp", KEY_gasp, 1, TRUE, TRUE,
"irred", KEY_irred, 1, FALSE, TRUE,
"make_sparse", KEY_make_sparse, 1, TRUE, TRUE,
"reduce", KEY_reduce, 1, FALSE, TRUE,
"taut", KEY_taut, 1, FALSE, FALSE,
"super_gasp", KEY_super_gasp, 1, TRUE, TRUE,
"lexsort", KEY_lexsort, 1, FALSE, FALSE,
"test", KEY_test, 1, TRUE, TRUE,
0, KEY_unknown, 0, FALSE, FALSE /* must be last */
};
struct {
char *name;
int value;
} debug_table[] = {
"", EXPAND + ESSEN + IRRED + REDUCE + SPARSE + GASP + SHARP + MINCOV,
"compl", COMPL, "essen", ESSEN,
"expand", EXPAND, "expand1", EXPAND1|EXPAND,
"irred", IRRED, "irred1", IRRED1|IRRED,
"reduce", REDUCE, "reduce1", REDUCE1|REDUCE,
"mincov", MINCOV, "mincov1", MINCOV1|MINCOV,
"sparse", SPARSE, "sharp", SHARP,
"taut", TAUT, "gasp", GASP,
"exact", EXACT,
0,
};
struct {
char *name;
int *variable;
int value;
} esp_opt_table[] = {
"eat", &echo_comments, FALSE,
"eatdots", &echo_unknown_commands, FALSE,
"fast", &single_expand, TRUE,
"kiss", &kiss, TRUE,
"ness", &remove_essential, FALSE,
"nirr", &force_irredundant, FALSE,
"nunwrap", &unwrap_onset, FALSE,
"onset", &recompute_onset, TRUE,
"pos", &pos, TRUE,
"random", &use_random_order, TRUE,
"strong", &use_super_gasp, TRUE,
0,
};
|