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. | |
| void | Eval (const Eigen::Ref< const AutoDiffVecXd > &x, AutoDiffVecXd *y) const |
| Evaluates the expression. | |
| void | Eval (const Eigen::Ref< const VectorX< symbolic::Variable > > &x, VectorX< symbolic::Expression > *y) const |
| Evaluates the expression. | |
| void | set_description (const std::string &description) |
| Set a human-friendly description for the evaluator. | |
| const std::string & | get_description () const |
| Getter for a human-friendly description for the evaluator. | |
| 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. | |
| std::ostream & | Display (std::ostream &os) const |
| Formats this evaluator into the given stream, without displaying the decision variables it is bound to. | |
| std::string | ToLatex (const VectorX< symbolic::Variable > &vars, int precision=3) const |
| Returns a LaTeX string describing this evaluator. | |
| int | num_vars () const |
| Getter for the number of variables, namely the number of rows in x, as used in Eval(x, y). | |
| int | num_outputs () const |
| Getter for the number of outputs, namely the number of rows in y, as used in Eval(x, y). | |
| 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) . | |
| 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. | |
| bool | is_thread_safe () const |
| Returns whether it is safe to call Eval in parallel. | |
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. | |
| virtual void | DoEval (const Eigen::Ref< const Eigen::VectorXd > &x, Eigen::VectorXd *y) const =0 |
| Implements expression evaluation for scalar type double. | |
| virtual void | DoEval (const Eigen::Ref< const AutoDiffVecXd > &x, AutoDiffVecXd *y) const =0 |
| Implements expression evaluation for scalar type AutoDiffXd. | |
| 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. | |
| virtual std::ostream & | DoDisplay (std::ostream &os, const VectorX< symbolic::Variable > &vars) const |
| NVI implementation of Display. | |
| 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 |
Formats this evaluator into the given stream, without displaying the decision variables it is bound to.
| 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.)
|
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 LinearConstraint, LinearCost, ExpressionConstraint, ExpressionCost, L1NormCost, L2NormCost, LinearConstraint, LinearCost, LInfNormCost, and PerspectiveQuadraticCost.
|
protectedpure virtual |
Implements expression evaluation for scalar type AutoDiffXd.
| x | Input vector. |
| y | Output vector. |
Implemented in LinearConstraint, LinearCost, DirectCollocationConstraint, EvaluatorCost< EvaluatorType >, ExponentialConeConstraint, ExpressionConstraint, ExpressionCost, L1NormCost, L2NormCost, LinearComplementarityConstraint, LinearConstraint, LinearCost, LinearMatrixInequalityConstraint, LInfNormCost, PerspectiveQuadraticCost, and PositiveSemidefiniteConstraint.
|
protectedpure virtual |
Implements expression evaluation for scalar type double.
| x | Input vector. |
| y | Output vector. |
Implemented in LinearConstraint, LinearCost, DirectCollocationConstraint, EvaluatorCost< EvaluatorType >, EvaluatorCost< PolynomialEvaluator >, ExponentialConeConstraint, ExpressionConstraint, ExpressionCost, L1NormCost, L2NormCost, LinearComplementarityConstraint, LinearConstraint, LinearCost, LinearMatrixInequalityConstraint, LInfNormCost, PerspectiveQuadraticCost, and PositiveSemidefiniteConstraint.
|
protectedpure virtual |
Implements expression evaluation for scalar type symbolic::Expression.
| [in] | x | Input vector. |
| [out] | y | Output vector. |
Implemented in LinearConstraint, LinearCost, DirectCollocationConstraint, EvaluatorCost< EvaluatorType >, ExponentialConeConstraint, ExpressionConstraint, ExpressionCost, L1NormCost, L2NormCost, LinearComplementarityConstraint, LinearConstraint, LinearCost, LinearMatrixInequalityConstraint, LInfNormCost, PerspectiveQuadraticCost, and PositiveSemidefiniteConstraint.
|
protectedvirtual |
Reimplemented in LinearConstraint, LinearCost, ExponentialConeConstraint, ExpressionConstraint, ExpressionCost, L1NormCost, L2NormCost, LinearComplementarityConstraint, LinearConstraint, LinearCost, LinearMatrixInequalityConstraint, LInfNormCost, PerspectiveQuadraticCost, and PositiveSemidefiniteConstraint.
| 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 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 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.
| 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.
| 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() + "$$".