CGAL:将商转换为双倍
CGAL: convert quotient to double
我在转换 CGAL QP 求解器时遇到问题
typedef CGAL::Gmpzf ET;
...define a quadratic program qp here...
Solution s = CGAL::solve_quadratic_program(qp, ET());
assert (s.solves_quadratic_program(qp));
cout<<"QP objective = "<<s.objective_value()<<endl;
// The above returns a value of type CGAL::Quotient<ET>
// and I need to convert it to double
double n = s.objective_value_numerator().to_double();
double d = s.objective_value_denominator().to_double();
cout<<"QP objective 2 = "<<n/d<<endl;
我得到了:
QP objective = -2.57497e-22/2.01459e-22
QP objective 2 = -nan
我检查并观察到n = -inf
和d = inf
.
我们如何正确地将商转换为双精度?
提前感谢您的任何建议!!
CGAL 有一个函数CGAL::to_double
可用于大多数数字类型,尤其是商。它有特殊的代码,正是针对分子和分母溢出的情况。它没有用于下溢的代码,这不会发生在整数商中,但可能发生在 Gmpzf 中,产生0/0
。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 将 Eigen::MatrixXd 矩阵转换为 cgal 容器类型
- 将多面体转换为nef(违反访问)时,与CGAL崩溃
- CGAL将非manifold nef_polyhedron_3转换为三角网格
- 如何将平面网格转换为CGAL的布置
- CGAL:将商转换为双倍