当前位置: 首页>>代码示例>>C++>>正文


C++ interval::sup方法代码示例

本文整理汇总了C++中interval::sup方法的典型用法代码示例。如果您正苦于以下问题:C++ interval::sup方法的具体用法?C++ interval::sup怎么用?C++ interval::sup使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在interval的用法示例。


在下文中一共展示了interval::sup方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: meet

 interval interval_relation_plugin::meet(interval const& src1, interval const& src2, bool& isempty) {
     isempty = false;
     if (is_empty(0, src1) || is_infinite(src2)) {
         return src1;
     }
     if (is_empty(0, src2) || is_infinite(src1)) {
         return src2;
     }
     bool l_open = src1.is_lower_open();
     bool r_open = src1.is_upper_open();
     ext_numeral low = src1.inf();
     ext_numeral high = src1.sup();
     if (src2.inf() > low || (src2.inf() == low && !l_open)) {
         low = src2.inf();
         l_open = src2.is_lower_open();
     }
     if (src2.sup() < high || (src2.sup() == high && !r_open)) {
         high = src2.sup();
         r_open = src2.is_upper_open();
     }
     if (low > high || (low == high && (l_open || r_open))) {
         isempty = true;
         return interval(dep());
     }
     else {
         return interval(dep(), low, l_open, nullptr, high, r_open, nullptr);
     }
 }
开发者ID:NikolajBjorner,项目名称:z3,代码行数:28,代码来源:dl_interval_relation.cpp

示例2: unite

 interval interval_relation_plugin::unite(interval const& src1, interval const& src2) {
     bool l_open = src1.is_lower_open();
     bool r_open = src1.is_upper_open();
     ext_numeral low = src1.inf();
     ext_numeral high = src1.sup();
     if (src2.inf() < low || (src2.inf() == low && l_open)) {
         low = src2.inf();
         l_open = src2.is_lower_open();
     }
     if (src2.sup() > high || (src2.sup() == high && r_open)) {
         high = src2.sup();
         r_open = src2.is_upper_open();
     }
     return interval(dep(), low, l_open, nullptr, high, r_open, nullptr);
 }
开发者ID:NikolajBjorner,项目名称:z3,代码行数:15,代码来源:dl_interval_relation.cpp

示例3: sqr_inverse

// FIXME It actually performs intersection which is inconsistent with intersect
bool sqr_inverse(interval& z, interval& x, interval& gap) {

	bool has_gap = false;

	const interval x_1 = sqrt(z);

	const interval x_2 = -x_1;

	interval x_image;

	if (disjoint(x, x_2)) {

		x_image = x_1;
	}
	else if (disjoint(x, x_1)) {

		x_image = x_2;
	}
	else {

		gap = interval(x_2.sup(), x_1.inf());

		has_gap = gap.diameter() > IMPROVEMENT_TOL; // FIXME GAP_SQRT_TOL ?

		x_image = hull_of(x_1, x_2);
	}

	x.intersect(x_image);

	z.intersect(sqr(x));

	return has_gap;
}
开发者ID:baharev,项目名称:old_sandbox,代码行数:34,代码来源:interval.cpp

示例4: extended_division

// Returns true and sets gap if a gap is generated, otherwise gap is undefined
bool extended_division(const interval& x, const interval& y, interval& z, interval& gap) {

	gap = interval();

	if (z.is_narrow()) { // if narrow, don't do anything
		// TODO Actually, feasibility could be checked
		return false;
	}

	if (!y.contains(0)) {  // trivial case

		z.intersect(x/y);

		return false;
	}
	// y.contains(0)==true

	if (x.contains(0)) {  // no progress case

		return false;
	}
	// (!x.contains(0) && y.contains(0)) == true

	if (y.inf()==0 && y.sup()==0) {  // undefined case
		// FIXME Is it safe to declare it infeasible? Or should we just signal no progress?
		//ASSERT2(false, "undefined result; x, z: "<<x<<", "<<z);
		throw infeasible_problem();
	}

	return true_extended_division(x, y, z, gap);
}
开发者ID:baharev,项目名称:old_sandbox,代码行数:32,代码来源:interval.cpp

示例5: widen

 interval interval_relation_plugin::widen(interval const& src1, interval const& src2) {
     bool l_open = src1.is_lower_open();
     bool r_open = src1.is_upper_open();
     ext_numeral low = src1.inf();
     ext_numeral high = src1.sup();
     
     if (src2.inf() < low || (low == src2.inf() && l_open && !src2.is_lower_open())) {
         low = ext_numeral(false);
         l_open = true;
     }
     if (high < src2.sup() || (src2.sup() == high && !r_open && src2.is_upper_open())) {
         high = ext_numeral(true);
         r_open = true;
     }
     return interval(dep(), low, l_open, nullptr, high, r_open, nullptr);
 }
开发者ID:NikolajBjorner,项目名称:z3,代码行数:16,代码来源:dl_interval_relation.cpp

示例6: save_gap_if_any

// FIXME Performs intersection which is inconsistent with intersect!
bool save_gap_if_any(const double l, const double u, interval& z, interval& gap) {

	ASSERT2( l <= u, "l, u: " << l << ", " << u );

	const double zL = z.inf(), zU = z.sup();

	bool ret_val = false;

	if (zL <= l && u <= zU) { // zL--l  u--zU

		gap = interval(l, u);

		ret_val = true;
	}
	else if (l < zL &&  zU < u) { // --l  zL--zU  u--

		throw infeasible_problem();
	}
	else if (zU <= l) { // zL--zU--l  u--

		; // no progress
	}
	else if (u <= zL) { // --l  u--zL--zU

		; // no progress
	}
	else if (zL <= l && zU < u) { // zL--l  zU  u--

		z = interval(zL, l);
	}
	else if (l < zL && u <= zU) { // --l  zL  u--zU

		z = interval(u, zU);
	}
	else {

		ASSERT(false);
	}

	ASSERT(z.subset_of(interval(zL, zU)));

	return ret_val;
}
开发者ID:baharev,项目名称:old_sandbox,代码行数:44,代码来源:interval.cpp

示例7: is_empty

 bool interval_relation_plugin::is_empty(unsigned, interval const& i) {
     return i.sup() < i.inf();
 }
开发者ID:NikolajBjorner,项目名称:z3,代码行数:3,代码来源:dl_interval_relation.cpp


注:本文中的interval::sup方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。