pub fn convex_hull(ps: Vec<(i64, i64)>) -> Vec<(i64, i64)>