Your task is to implement the update (modify) operation for a Range Maximum Segment Tree and verify its correctness in Lean. The operation updates the value at a specific index using path copying (functional update). Postconditions: Functional Correctness (view(result) = view(node)[idx := v]) and Invariant Preservation (result satisfies is_segment_tree). Frame Preservation (other indices unchanged).
