From: Florent Kermarrec Date: Mon, 17 Sep 2012 15:27:50 +0000 (+0200) Subject: improve truthtable tool X-Git-Tag: 24jan2021_ls180~2575^2~133 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=62bede5eeff4f71cc5fd9f70dcc25c30a2940a14;p=litex.git improve truthtable tool --- diff --git a/migScope/tools/truthtable.py b/migScope/tools/truthtable.py index d38316b9..14ce7969 100644 --- a/migScope/tools/truthtable.py +++ b/migScope/tools/truthtable.py @@ -2,14 +2,26 @@ import os import re import sys +def is_number(x): + try: + _ = float(x) + except ValueError: + return False + return True + +def remove_numbers(seq): + return [ x for x in seq if not is_number(x)] + def remove_duplicates(seq): - seen = set() - seen_add = seen.add - return [ x for x in seq if x not in seen and not seen_add(x)] + seen = set() + seen_add = seen.add + return [ x for x in seq if x not in seen and not seen_add(x)] def get_operands(s): - operands = remove_duplicates(sorted(re.findall("[A-z0-9_]+", s))) - return operands + operands = re.findall("[A-z0-9_]+", s) + operands = remove_duplicates(operands) + operands = remove_numbers(operands) + return sorted(operands) def gen_truth_table(s): operands = get_operands(s) @@ -30,6 +42,6 @@ def gen_truth_table(s): def main(): print(gen_truth_table("(A&B&C)|D")) - + if __name__ == '__main__': - main() + main()