Your task is to implement the Edmonds-Karp Algorithm to find the maximum flow in a directed graph with edge capacities and verify its functional correctness in Dafny. Preconditions: You can assume the graph contains at most 1,000 nodes. You can assume edge capacities are between 0 and 100,000. The Source s and Sink t are valid, distinct nodes. Crucially, the graph is a Simple Graph (no parallel edges between the same two nodes), ensuring that capacities between any pair of nodes are unique. Requirements: Implement the function max_flow_value which returns the integer value of the max flow. Algorithm: You must implement the Edmonds-Karp strategy, which repeatedly finds the shortest augmenting path (in terms of number of edges) from s to t in the residual graph using BFS, and pushes the maximum possible flow along that path. Output: The returned value must be equal to the net flow out of the source in a valid maximum flow assignment. Verification Challenges: (1) Residual Graph Correctness: Proving that your calculation of "remaining capacity" is correct and that pushing flow conserves mass (Flow In == Flow Out) for all internal nodes. (2) Termination: Edmonds-Karp terminates because the shortest path distance from s to t in the residual graph is non-decreasing and strictly increases periodically. Proving this requires reasoning about BFS Layers and global topology. (3) Optimality (Min-Cut): Proving that when no augmenting path exists, the current flow is maximum. This typically requires identifying a "Cut" (a set of vertices reachable from s) and showing that all edges crossing this cut are saturated.