Your task is to implement an algorithm to find the Maximum Bipartite Matching and verify its functional correctness in Dafny. Preconditions The input is a Bipartite Graph consisting of two disjoint sets of vertices: Left Set (U) with left_size nodes. Right Set (V) with right_size nodes. The graph is represented as an adjacency list adj (a sequence of sequences) where adj[u] contains a list of neighbors in the Right Set. (i.e., this is a directed representation U→V). You can assume both left_size and right_size are at most 1,000. Requirements: Implement the function max_bipartite_matching which returns the size (number of edges) of the maximum matching. Algorithm: You are encouraged to use Kuhn's Algorithm (DFS-based matching). This algorithms attempt to find "augmenting paths" that alternate between edges in the matching and edges outside it. Output: The returned integer must equal the maximum number of pairs (u,v) (where u∈U,v∈V) that can be selected such that no two pairs share a node. Verification Challenges: (1) Valid Pairing: Proving that the match array maintained by your algorithm correctly maps nodes in the Right Set to their matched partners in the Left Set, and that every recorded match corresponds to a real edge exists in adj. (2) Disjointness: Proving that the algorithm never assigns two different Left-nodes to the same Right-node (and vice-versa). (3) Optimality: Proving that when the algorithm terminates, the matching size is indeed maximal. This usually requires proving Berge's Lemma: a matching is maximum if and only if there is no augmenting path. The proof typically involves showing that the DFS search exhaustively checked for such paths.