Provides an abstract interface to represent an expression, mapping a fixed or dynamic number of inputs to a fixed number of outputs, that may be evaluated on a scalar type of double or AutoDiffXd.
These objects, and its derivatives, are meant to be bound to a given set of variables using the Binding<> class.
#include <drake/solvers/evaluator_base.h>
Public Member Functions | |
virtual | ~EvaluatorBase () |
void | Eval (const Eigen::Ref< const Eigen::VectorXd > &x, Eigen::VectorXd *y) const |
Evaluates the expression. More... | |
void | Eval (const Eigen::Ref< const AutoDiffVecXd > &x, AutoDiffVecXd *y) const |
Evaluates the expression. More... | |
void | Eval (const Eigen::Ref< const VectorX< symbolic::Variable >> &x, VectorX< symbolic::Expression > *y) const |
Evaluates the expression. More... | |
void | set_description (const std::string &description) |
Set a human-friendly description for the evaluator. More... | |
const std::string & | get_description () const |
Getter for a human-friendly description for the evaluator. More... | |
std::ostream & | Display (std::ostream &os, const VectorX< symbolic::Variable > &vars) const |
Formats this evaluator into the given stream using vars for the bound decision variable names. More... | |
std::ostream & | Display (std::ostream &os) const |
Formats this evaluator into the given stream, without displaying the decision variables it is bound to. More... | |
std::string | ToLatex (const VectorX< symbolic::Variable > &vars, int precision=3) const |
Returns a LaTeX string describing this evaluator. More... | |
int | num_vars () const |
Getter for the number of variables, namely the number of rows in x, as used in Eval(x, y). More... | |
int | num_outputs () const |
Getter for the number of outputs, namely the number of rows in y, as used in Eval(x, y). More... | |
void | SetGradientSparsityPattern (const std::vector< std::pair< int, int >> &gradient_sparsity_pattern) |
Set the sparsity pattern of the gradient matrix ∂y/∂x (the gradient of y value in Eval, w.r.t x in Eval) . More... | |
const std::optional< std::vector< std::pair< int, int > > > & | gradient_sparsity_pattern () const |
Returns the vector of (row_index, col_index) that contains all the entries in the gradient of Eval function (∂y/∂x) whose value could be non-zero, namely if ∂yᵢ/∂xⱼ could be non-zero, then the pair (i, j) is in gradient_sparsity_pattern. More... | |
bool | is_thread_safe () const |
Returns whether it is safe to call Eval in parallel. More... | |
Does not allow copy, move, or assignment | |
EvaluatorBase (const EvaluatorBase &)=delete | |
EvaluatorBase & | operator= (const EvaluatorBase &)=delete |
EvaluatorBase (EvaluatorBase &&)=delete | |
EvaluatorBase & | operator= (EvaluatorBase &&)=delete |
Protected Member Functions | |
EvaluatorBase (int num_outputs, int num_vars, const std::string &description="") | |
Constructs a evaluator. More... | |
virtual void | DoEval (const Eigen::Ref< const Eigen::VectorXd > &x, Eigen::VectorXd *y) const =0 |
Implements expression evaluation for scalar type double. More... | |
virtual void | DoEval (const Eigen::Ref< const AutoDiffVecXd > &x, AutoDiffVecXd *y) const =0 |
Implements expression evaluation for scalar type AutoDiffXd. More... | |
virtual void | DoEval (const Eigen::Ref< const VectorX< symbolic::Variable >> &x, VectorX< symbolic::Expression > *y) const =0 |
Implements expression evaluation for scalar type symbolic::Expression. More... | |
virtual std::ostream & | DoDisplay (std::ostream &os, const VectorX< symbolic::Variable > &vars) const |
NVI implementation of Display. More... | |
virtual std::string | DoToLatex (const VectorX< symbolic::Variable > &vars, int precision) const |
void | set_num_outputs (int num_outputs) |
void | set_is_thread_safe (bool is_thread_safe) |
|
delete |
|
delete |
|
virtual |
|
protected |
Constructs a evaluator.
num_outputs. | The number of rows in the output. |
num_vars. | The number of rows in the input. If the input dimension is not known, then set num_vars to Eigen::Dynamic. |
description | A human-friendly description. |
std::ostream& Display | ( | std::ostream & | os, |
const VectorX< symbolic::Variable > & | vars | ||
) | const |
Formats this evaluator into the given stream using vars
for the bound decision variable names.
The size of vars
must match the num_vars()
declared by this evaluator. (If num_vars()
is Eigen::Dynamic
, then vars
may be any size.)
std::ostream& Display | ( | std::ostream & | os | ) | const |
Formats this evaluator into the given stream, without displaying the decision variables it is bound to.
|
protectedvirtual |
NVI implementation of Display.
The default implementation will report the NiceTypeName, get_description, and list the bound variables. Subclasses may override to customize the message.
Reimplemented in ExpressionConstraint, LinearConstraint, ExpressionCost, PerspectiveQuadraticCost, LInfNormCost, L2NormCost, L1NormCost, and LinearCost.
|
protectedpure virtual |
Implements expression evaluation for scalar type double.
x | Input vector. |
y | Output vector. |
num_vars
x 1. num_outputs
x 1. Implemented in ExponentialConeConstraint, ExpressionConstraint, LinearMatrixInequalityConstraint, PositiveSemidefiniteConstraint, LinearComplementarityConstraint, LinearConstraint, ExpressionCost, EvaluatorCost< EvaluatorType >, EvaluatorCost< PolynomialEvaluator >, PerspectiveQuadraticCost, LInfNormCost, L2NormCost, L1NormCost, DirectCollocationConstraint, and LinearCost.
|
protectedpure virtual |
Implements expression evaluation for scalar type AutoDiffXd.
x | Input vector. |
y | Output vector. |
num_vars
x 1. num_outputs
x 1. Implemented in ExponentialConeConstraint, ExpressionConstraint, LinearMatrixInequalityConstraint, PositiveSemidefiniteConstraint, LinearComplementarityConstraint, LinearConstraint, ExpressionCost, EvaluatorCost< EvaluatorType >, EvaluatorCost< PolynomialEvaluator >, PerspectiveQuadraticCost, LInfNormCost, L2NormCost, L1NormCost, DirectCollocationConstraint, and LinearCost.
|
protectedpure virtual |
Implements expression evaluation for scalar type symbolic::Expression.
[in] | x | Input vector. |
[out] | y | Output vector. |
num_vars
x 1. num_outputs
x 1. Implemented in ExponentialConeConstraint, ExpressionConstraint, LinearMatrixInequalityConstraint, PositiveSemidefiniteConstraint, LinearComplementarityConstraint, LinearConstraint, ExpressionCost, EvaluatorCost< EvaluatorType >, EvaluatorCost< PolynomialEvaluator >, PerspectiveQuadraticCost, LInfNormCost, L2NormCost, L1NormCost, DirectCollocationConstraint, and LinearCost.
|
protectedvirtual |
void Eval | ( | const Eigen::Ref< const Eigen::VectorXd > & | x, |
Eigen::VectorXd * | y | ||
) | const |
Evaluates the expression.
[in] | x | A num_vars x 1 input vector. |
[out] | y | A num_outputs x 1 output vector. |
void Eval | ( | const Eigen::Ref< const AutoDiffVecXd > & | x, |
AutoDiffVecXd * | y | ||
) | const |
Evaluates the expression.
[in] | x | A num_vars x 1 input vector. |
[out] | y | A num_outputs x 1 output vector. |
void Eval | ( | const Eigen::Ref< const VectorX< symbolic::Variable >> & | x, |
VectorX< symbolic::Expression > * | y | ||
) | const |
Evaluates the expression.
[in] | x | A num_vars x 1 input vector. |
[out] | y | A num_outputs x 1 output vector. |
const std::string& get_description | ( | ) | const |
Getter for a human-friendly description for the evaluator.
Returns the vector of (row_index, col_index) that contains all the entries in the gradient of Eval function (∂y/∂x) whose value could be non-zero, namely if ∂yᵢ/∂xⱼ could be non-zero, then the pair (i, j) is in gradient_sparsity_pattern.
gradient_sparsity_pattern | If nullopt, then we regard all entries of the gradient as potentially non-zero. |
bool is_thread_safe | ( | ) | const |
Returns whether it is safe to call Eval in parallel.
int num_outputs | ( | ) | const |
Getter for the number of outputs, namely the number of rows in y, as used in Eval(x, y).
int num_vars | ( | ) | const |
Getter for the number of variables, namely the number of rows in x, as used in Eval(x, y).
|
delete |
|
delete |
void set_description | ( | const std::string & | description | ) |
Set a human-friendly description for the evaluator.
|
protected |
|
protected |
void SetGradientSparsityPattern | ( | const std::vector< std::pair< int, int >> & | gradient_sparsity_pattern | ) |
Set the sparsity pattern of the gradient matrix ∂y/∂x (the gradient of y value in Eval, w.r.t x in Eval) .
gradient_sparsity_pattern contains all the pairs of (row_index, col_index) for which the corresponding entries could have non-zero value in the gradient matrix ∂y/∂x.
std::string ToLatex | ( | const VectorX< symbolic::Variable > & | vars, |
int | precision = 3 |
||
) | const |
Returns a LaTeX string describing this evaluator.
Does not include any characters to enter/exit math mode; you might want, e.g. "$$" + evaluator.ToLatex() + "$$".