本文整理汇总了C++中IntervalVector::lb方法的典型用法代码示例。如果您正苦于以下问题:C++ IntervalVector::lb方法的具体用法?C++ IntervalVector::lb怎么用?C++ IntervalVector::lb使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IntervalVector
的用法示例。
在下文中一共展示了IntervalVector::lb方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: centeredFormEval
Interval centeredFormEval(const Function& function, const IntervalVector& arg) {
/*Interval natural_extension = function.eval(arg);
Interval centered_form = function.eval(arg.mid()) + function.gradient(arg) * (arg - arg.mid());*/
IntervalVector new_arg_ub(arg);
IntervalVector new_arg_lb(arg);
IntervalVector grad = function.gradient(arg);
for(int i = 0; i < arg.size(); ++i) {
if(grad[i].lb() > 0) {
new_arg_ub[i] = arg[i].ub();
new_arg_lb[i] = arg[i].lb();
} else if(grad[i].ub() < 0) {
new_arg_ub[i] = arg[i].lb();
new_arg_lb[i] = arg[i].ub();
}
}
Interval natural_extension = function.eval(arg);
Interval centered_form = function.eval(arg.mid()) + grad * (arg - arg.mid());
Interval ub_form = function.eval(arg.ub()) + grad * (arg - arg.ub());
Interval lb_form = function.eval(arg.lb()) + grad * (arg - arg.lb());
Interval res = natural_extension & centered_form & ub_form & lb_form;
res &= Interval(function.eval(new_arg_lb).lb(), function.eval(new_arg_ub).ub());
return res;
}