Your task is to implement the update (modify) operation for a Range Maximum Segment Tree using a functional (immutable) approach and verify its correctness in Dafny , where the operation updates the value at a specific index $idx$ to $v$ by creating a new version of the tree (path copying) via recursion—returning a new leaf for the base case and a new internal node with updated max value for the recursive step—while formally proving (1) Functional Correctness: in the returned tree, the value at $idx$ is exactly $v$, (2) Frame Preservation: for all other indices $k \neq idx$, the value is identical to the old tree, and (3) Invariant Preservation: the new tree maintains the is_segment_tree invariant, ensuring structural integrity and the Max property remain valid.