Skip to content

common

Util #

Utilization class.

Source code in src/common/util.py
 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
class Util:
    """Utilization class."""

    @staticmethod
    def ambiguous_equals(s: str, comparison: str) -> bool:
        return s.lower().replace(" ", "") == comparison.lower().replace(" ", "")

    @staticmethod
    def convert_to_property(param_name: str) -> str:
        return param_name.lower().replace(" ", "_").replace("-", "_")

    @staticmethod
    def random_choice(target: Union[Any, list]):
        if isinstance(target, list):
            return random.choice(target)
        else:
            return target

    @staticmethod
    def true_or_false() -> bool:
        if random.choice([0, 1]) == 1:
            return True
        else:
            return False

    @staticmethod
    def get_entry_nodes(dag: nx.DiGraph) -> List[int]:
        return [v for v, d in dag.in_degree() if d == 0]

    @staticmethod
    def get_exit_nodes(dag: nx.DiGraph) -> List[int]:
        return [v for v, d in dag.out_degree() if d == 0]

    @staticmethod
    def get_option_min(option: Optional[Union[list, int, float]]) -> Optional[Union[int, float]]:
        if option is None:
            return None
        if isinstance(option, list):
            return min(option)
        else:
            return option

    @staticmethod
    def get_option_max(option: Optional[Union[list, int, float]]) -> Optional[Union[int, float]]:
        if option is None:
            return None
        if isinstance(option, list):
            return max(option)
        else:
            return option

    @staticmethod
    def get_min_in_node(dag: nx.DiGraph, option: Collection[int]) -> int:
        min_in_node_i: int
        min_in = sys.maxsize
        for node_i in option:
            if (in_degree := dag.in_degree(node_i)) < min_in:
                min_in_node_i = node_i
                min_in = in_degree
            if min_in == 0:
                break

        return min_in_node_i

    @staticmethod
    def get_min_out_node(dag: nx.DiGraph, option: Collection[int]) -> int:
        min_out_node_i: int
        min_out = sys.maxsize
        for node_i in option:
            if (out_degree := dag.out_degree(node_i)) < min_out:
                min_out_node_i = node_i
                min_out = out_degree
            if min_out == 0:
                break

        return min_out_node_i