collections =========== .. py:module:: quantify_scheduler.helpers.collections .. autoapi-nested-parse:: Helpers for various collections. Module Contents --------------- Functions ~~~~~~~~~ .. autoapisummary:: quantify_scheduler.helpers.collections.make_hash quantify_scheduler.helpers.collections.without quantify_scheduler.helpers.collections.find_inner_dicts_containing_key quantify_scheduler.helpers.collections.find_all_port_clock_combinations quantify_scheduler.helpers.collections.find_port_clock_path .. py:function:: make_hash(obj: Any) -> int Makes a hash from a dictionary, list, tuple or set to any level, that contains only other hashable types (including any lists, tuples, sets, and dictionaries). From: https://stackoverflow.com/questions/5884066/hashing-a-dictionary :param obj: Input collection. :returns: Hash. .. py:function:: without(dict_in: dict, keys: list) -> dict Utility that copies a dictionary excluding a specific list of keys. :param dict_in: Input dictionary. :param keys: List of keys to exclude. :returns: Filtered dictionary. .. py:function:: find_inner_dicts_containing_key(d: dict, key: Any) -> List[dict] Generates a list of the first dictionaries encountered that contain a certain key, in a complicated dictionary with nested dictionaries or Iterables. This is achieved by recursively traversing the nested structures until the key is found, which is then appended to a list. :param d: The dictionary to traverse. :param key: The key to search for. :returns: A list containing all the inner dictionaries containing the specified key. .. py:function:: find_all_port_clock_combinations(d: dict) -> List[Tuple[str, str]] Generates a list with all port and clock combinations found in a dictionary with nested structures. Traversing the dictionary is done using the `find_inner_dicts_containing_key` function. :param d: The dictionary to traverse. :returns: A list containing tuples representing the port and clock combinations found in the dictionary. .. py:function:: find_port_clock_path(hardware_config: dict, port: str, clock: str) -> list | None Finds the path to a port-clock combination in a nested dictionary. :param hardware_config: The (nested) hardware config dictionary to loop over. :param port: The port to find. :param clock: The clock to find. :returns: A list representing the keys to the port-clock combination in the hardware config. If the port-clock location is in a list, the list index is also included in this path.