Exemple #1
0
def bidirectional_search(initial, end, problem):
    """Search the shallowest nodes in the search tree first.
            Search through the successors of a problem to find a goal.
            The argument frontier should be an empty queue.
            Repeats infinitely in case of loops. [Figure 3.7]"""
    frontier = deque([Node(initial)])  # FIFO queue
    interior = deque([Node(end)])
    seen_f = []
    seen_i = []
    max_len_f = len(frontier)
    max_len_i = len(interior)

    f = open('out.txt', 'a')
    while frontier:
        for item_f in frontier:
            for item_i in interior:
                if item_f.state == item_i.state:
                    len_made = len(frontier) + len(interior)
                    len_seen = len(seen_f) + len(seen_i)
                    print(
                        "**********************Bidirectional Search*********************",
                        file=f)
                    print("the number of expanded nodes: {}".format(len_seen),
                          file=f)
                    print("the number of made nodes: {}".format(len_seen +
                                                                len_made),
                          file=f)
                    print("the maximum number of made nodes: {}".format(
                        max_len_f + max_len_i),
                          file=f)
                    print("depth of result: {}".format(item_i.depth +
                                                       item_f.depth),
                          file=f)

                    return item_f.path() + item_i.path()

        node_f = frontier.popleft()
        node_i = interior.popleft()
        seen_f.append(node_f)
        seen_i.append(node_i)

        frontier.extend(node_f.expand(problem))
        interior.extend(node_i.expand(problem))

        max_len_f = max(max_len_f, len(frontier))
        max_len_i = max(max_len_i, len(interior))

    return None
Exemple #2
0
def breadth_first_tree_search(initial, problem):
    """Search the shallowest nodes in the search tree first.
        Search through the successors of a problem to find a goal.
        The argument frontier should be an empty queue.
        Repeats infinitely in case of loops. [Figure 3.7]"""
    f = open('out.txt', 'a')
    frontier = deque([Node(initial)])  # FIFO queue
    max_frontier = len(frontier)
    seen = []

    while frontier:
        node = frontier.popleft()
        seen.append(node)
        if problem.goal_test(node.state):
            len_seen = len(seen)
            print(
                "**********************Breadth First Search*********************",
                file=f)
            print("the number of expanded nodes: {}".format(len_seen), file=f)
            print("the number of made nodes: {}".format(len_seen +
                                                        len(frontier)),
                  file=f)
            print("the maximum number of made nodes: {}".format(max_frontier),
                  file=f)
            print("depth of result: {}".format(node.depth), file=f)
            return node
        frontier.extend(node.expand(problem))
        len_frontier = len(frontier)
        if max_frontier < len_frontier:
            max_frontier = len_frontier
    print('have no result')
    return None
Exemple #3
0
def a_star(initial, problem):

    f = open('out.txt', 'a')
    frontier = [Node(initial)]
    max_len = len(frontier)
    seen = []

    while frontier:
        frontier.sort(key=lambda x: x.h2 + x.path_cost, reverse=True)
        node = frontier.pop()
        seen.append(node)

        if problem.goal_test(node.state):

            len_made = len(frontier)
            len_seen = len(seen)
            print("**********************A* Search*********************",
                  file=f)
            print("the number of expanded nodes: {}".format(len_seen), file=f)
            print("the number of made nodes: {}".format(len_seen + len_made),
                  file=f)
            print("the maximum number of made nodes: {}".format(max_len),
                  file=f)
            print("depth of result: {}".format(node.depth), file=f)

            return node

        for node in node.expand(problem):
            if node.state not in [x.state for x in frontier + seen]:
                frontier.append(node)
        max_len = max(max_len, len(frontier))
    print("the end of list")
    return None
Exemple #4
0
def limited_depth_first_tree_search(initial, problem, limit):
    """Search the deepest nodes in the search tree first.
        Search through the successors of a problem to find a goal.
        The argument frontier should be an empty queue.
        Repeats infinitely in case of loops. [Figure 3.7]"""
    f = open('out.txt', 'a')
    frontier = [Node(initial)]  # Stack
    max_frontier = len(frontier)
    seen = []
    while frontier:
        node = frontier.pop()
        seen.append(node)
        if problem.goal_test(node.state):
            len_seen = len(seen)
            print(
                "**********************Limited Depth First Search*********************",
                file=f)
            print("the number of expanded nodes: {}".format(len_seen), file=f)
            print("the number of made nodes: {}".format(len_seen +
                                                        len(frontier)),
                  file=f)
            print("the maximum number of made nodes: {}".format(max_frontier),
                  file=f)
            print("depth of result: {}".format(node.depth), file=f)
            return node

        expanded_node = node.expand(problem)
        step_front = []
        for item in expanded_node:
            if item.state not in [x.state for x in seen]:
                if item.depth <= limit:
                    frontier.append(item)
                    step_front.append(item)
        len_frontier = len(frontier)
        if max_frontier < len_frontier:
            max_frontier = len_frontier
    print('have no result')
    return None
Exemple #5
0
def iter_depth_first_tree_search(initial, problem, max_iter):
    for limit in range(0, max_iter):
        f = open('out.txt', 'a')
        frontier = [Node(initial)]  # Stack
        max_frontier = len(frontier)
        seen = []
        while frontier:
            node = frontier.pop()
            seen.append(node)
            if problem.goal_test(node.state):
                len_seen = len(seen)
                print(
                    "**********************Iterative Depth First Search*********************",
                    file=f)
                print("the number of expanded nodes: {}".format(len_seen),
                      file=f)
                print("the number of made nodes: {}".format(len_seen +
                                                            len(frontier)),
                      file=f)
                print("the maximum number of made nodes: {}".format(
                    max_frontier),
                      file=f)
                print("depth of result: {}".format(node.depth), file=f)
                return node

            expanded_node = node.expand(problem)
            step_front = []
            for item in expanded_node:
                if item.state not in [x.state for x in seen]:
                    if item.depth <= limit:
                        frontier.append(item)
                        step_front.append(item)
            len_frontier = len(frontier)
            if max_frontier < len_frontier:
                max_frontier = len_frontier
    print('have no result')
    return None