使用 cgal 库计算向量的夹角
#include <vector> #include <iostream> #include <CGAL/Exact_predicates_exact_constructions_kernel.h> #include <CGAL/Ray_2.h> #include <CGAL/Polygon_2.h> #include <CGAL/intersections.h> typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel; typedef Kernel::Point_2 Point_2; typedef Kernel::Vector_2 Vector_2; typedef Kernel::Segment_2 Segment_2; typedef Kernel::Circle_2 Circle_2; typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel; typedef Kernel::Point_2 Point_2; typedef Kernel::Line_2 Line_2; int main() { Vector_2 v1(-1, -1); Vector_2 v2(0, -1); // Compute the scalar product and squared length of the vectors double scalar_product = CGAL::to_double(v1 * v2); double squared_length_v1 = CGAL::to_double(v1.squared_length()); double squared_length_v2 = CGAL::to_double(v2.squared_length()); // Compute the angle between the vectors double cos_angle = scalar_product / std::sqrt(squared_length_v1 * squared_length_v2); double angle = std::acos(cos_angle)* (180 /CGAL_PI); std::cout << "angle: " << angle << std::endl; return 0; }
转载请注明原文链接:https://www.cnblogs.com/itfanr/p/17773947.html
公众号:小弧光黑板报
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战