本文整理汇总了C++中SX::getValue方法的典型用法代码示例。如果您正苦于以下问题:C++ SX::getValue方法的具体用法?C++ SX::getValue怎么用?C++ SX::getValue使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SX
的用法示例。
在下文中一共展示了SX::getValue方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: create
/** \brief Create a binary expression */
inline static SX create(unsigned char op, const SX& dep0, const SX& dep1){
if(dep0.isConstant() && dep1.isConstant()){
// Evaluate constant
double dep0_val = dep0.getValue();
double dep1_val = dep1.getValue();
double ret_val;
casadi_math<double>::fun(op,dep0_val,dep1_val,ret_val);
return ret_val;
} else {
// Expression containing free variables
return SX::create(new BinarySX(op,dep0,dep1));
}
}
示例2: isEquivalent
bool SX::isEquivalent(const SX& y, int depth) const{
if (isEqual(y)) return true;
if (isConstant() && y.isConstant()) return y.getValue()==getValue();
if (depth==0) return false;
if (hasDep() && y.hasDep() && getOp()==y.getOp()) {
if (getDep(0).isEquivalent(y.getDep(0),depth-1) && getDep(1).isEquivalent(y.getDep(1),depth-1)) return true;
return (operation_checker<CommChecker>(getOp()) && getDep(0).isEquivalent(y.getDep(1),depth-1) && getDep(1).isEquivalent(y.getDep(0),depth-1));
}
return false;
}
示例3: __div__
SX SX::__div__(const SX& y) const{
// Only simplifications that do not result in extra nodes area allowed
if(y->isZero()) // term2 is zero
return casadi_limits<SX>::nan;
else if(node->isZero()) // term1 is zero
return 0;
else if(y->isOne()) // term2 is one
return *this;
else if(isEquivalent(y)) // terms are equal
return 1;
else if(isDoubled() && y.isEqual(2))
return node->dep(0);
else if(isOp(OP_MUL) && y.isEquivalent(node->dep(0)))
return node->dep(1);
else if(isOp(OP_MUL) && y.isEquivalent(node->dep(1)))
return node->dep(0);
else if(node->isOne())
return y.inv();
else if(y.hasDep() && y.getOp()==OP_INV)
return (*this)*y.inv();
else if(isDoubled() && y.isDoubled())
return node->dep(0) / y->dep(0);
else if(y.isConstant() && hasDep() && getOp()==OP_DIV && getDep(1).isConstant() && y.getValue()*getDep(1).getValue()==1) // (x/5)/0.2
return getDep(0);
else if(y.hasDep() && y.getOp()==OP_MUL && y.getDep(1).isEquivalent(*this)) // x/(2*x) = 1/2
return BinarySX::create(OP_DIV,1,y.getDep(0));
else if(hasDep() && getOp()==OP_NEG && getDep(0).isEquivalent(y)) // (-x)/x = -1
return -1;
else if(y.hasDep() && y.getOp()==OP_NEG && y.getDep(0).isEquivalent(*this)) // x/(-x) = 1
return -1;
else if(y.hasDep() && y.getOp()==OP_NEG && hasDep() && getOp()==OP_NEG && getDep(0).isEquivalent(y.getDep(0))) // (-x)/(-x) = 1
return 1;
else if(isOp(OP_DIV) && y.isEquivalent(node->dep(0)))
return node->dep(1).inv();
else // create a new branch
return BinarySX::create(OP_DIV,*this,y);
}