Your task is to implement the Zig-Zig operation (Double Right Rotation) in a binary search tree and verify its correctness in Lean. A Zig-Zig is performed when a node X, its parent P, and its grandparent G form a straight line (X is left child of P, P is left child of G). Prove: (1) Set Preservation: The tree's view is unchanged. (2) BST Invariant Preservation. (3) Structural Correctness: X becomes the new root, P becomes the right child of X, and G becomes the right child of P.
