Your task is to implement a Binary Search Tree and verify that it correctly implements a mathematical Set. The tree must maintain the BST Invariant: for any node with value $v$, all values in the left subtree are less than $v$ and all values in the right subtree are greater than $v$. Here, you just need to focus on the Zig operation (a single right rotation) and verify that it correctly preserves the tree's logical state while modifying its physical structure. The Zig operation is a fundamental building block of self-balancing trees like Splay Trees. It involves rotating a node $P$ with its left child $L$ such that $L$ becomes the new root of the subtree.Specifically, you must prove the following: (1) Set Preservation: The mathematical set of values (the tree's "view") remains exactly the same before and after the rotation; no elements are lost or added during the pointer manipulation. (2) BST Invariant Preservation: for any node with value $v$, all values in the left subtree are less than $v$ and all values in the right subtree are greater than $v$. (3) Structural Correctness: After the rotation, the original left child $L$ must now be the root of the returned tree, and the original parent $P$ must now be $L$'s right child.