Your task is to implement the link_roots operation for a Union-Find data structure, which performs the actual merging of two sets, and verify its correctness in Dafny. This operation takes two distinct valid roots, $root_i$ and $root_j$, and merges their trees into a single set using the Union-by-Rank heuristic to maintain balance.  The operation applies one of three cases: (1) Attach Smaller: If $rank[root_i] < rank[root_j]$, make $root_j$ the parent of $root_i$. (2) Attach Equal: If $rank[root_i] == rank[root_j]$, arbitrarily make $root_j$ the parent of $root_i$ and increment the rank of $root_j$ by 1. (3) Attach Larger: If $rank[root_j] < rank[root_i]$, make $root_i$ the parent of $root_j$. Specifically, you must prove the following: (1) Merged Sets: After the operation, the two input roots (and consequently all nodes in their respective trees) must share the same representative logical root. (2) Rank Invariant: The strict rank ordering property (where a parent's rank is strictly greater than its children's ranks) must be preserved for every node in the tree. This guarantees the tree structure remains a Directed Acyclic Graph (DAG) and ensures termination. (3) Frame Condition: The operation must only affect the logical sets associated with $root_i$ and $root_j$. The representatives for all other disjoint sets in the structure must remain unchanged.