#ifdef HAS_OPENCV3 #include //Any OPENCV3 code #else #include //Any Opencv2 code #endif double dist(cv::Point, cv::Point); double inner_angle(cv::Point, cv::Point, cv::Point); cv::Point map_point(double, cv::Point, cv::Point); cv::Point unmap_point(double, cv::Point, cv::Point); cv::Vec get_line(cv::Point, cv::Point); bool is_in_line(cv::Vec line, cv::Point p); bool is_above_line(cv::Vec line, cv::Point p); double line_value(cv::Vec, cv::Point); cv::Point further_point_from_line(cv::Vec, std::vector); class CoordinateSystem { private: double theta; cv::Matx R, Rt; cv::Point origin; void precompute(); public: CoordinateSystem(cv::Point, cv::Point); CoordinateSystem(double angle, cv::Point origin_); cv::Point map(cv::Point p); cv::Point unmap(cv::Point p); };