26 #include "casadi_low.hpp"
36 std::string lookup_mode =
"auto";
37 for (
auto&& e : opts) {
38 if (e.first==
"lookup_mode") {
39 lookup_mode = e.second.to_string();
41 casadi_error(
"Unrecognized option: " +
str(e.first));
49 switch (lookup_mode) {
57 casadi_assert_dev(
false);
62 if (lookup_mode==
"auto") {
65 }
else if (lookup_mode==
"binary") {
67 }
else if (lookup_mode==
"linear") {
69 }
else if (lookup_mode==
"exact") {
72 casadi_error(
"Invalid lookup mode '" + lookup_mode +
"'. "
73 "Available modes: linear|binary|exact|auto");
77 std::string
Low::disp(
const std::vector<std::string>& arg)
const {
78 return "low(" + arg.at(0) +
", " + arg.at(1) +
")";
81 int Low::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
82 for (casadi_int i=0;i<
dep(1).
nnz();++i) {
88 void Low::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
89 res[0] = low(arg[0], arg[1]);
93 std::vector<std::vector<MX> >& fsens)
const {
94 for (casadi_int d=0; d<fsens.size(); ++d) {
100 std::vector<std::vector<MX> >& asens)
const {
104 std::fill_n(res[0],
nnz(), 0);
109 std::fill_n(res[0],
nnz(), 0);
114 const std::vector<casadi_int>& arg,
115 const std::vector<casadi_int>& res,
116 const std::vector<bool>& arg_is_ref,
117 std::vector<bool>& res_is_ref)
const {
118 casadi_int n =
dep(1).
nnz();
119 casadi_int ng =
dep(0).
nnz();
120 g.
local(
"cr",
"const casadi_real",
"*");
121 g.
local(
"rr",
"casadi_real",
"*");
122 g <<
"for (cr=" << g.
work(arg[1], n, arg_is_ref[1]) <<
", rr=" << g.
work(res[0], n,
false);
123 g <<
";cr!=" << g.
work(arg[1], n, arg_is_ref[1]) <<
"+" << n <<
";++cr) ";
125 g << g.
low(
"*cr", g.
work(arg[0], ng, arg_is_ref[0]), ng, lookup_mode_) <<
"\n";
130 s.
pack(
"Low::lookup_mode",
static_cast<casadi_int
>(lookup_mode_));
134 casadi_int lookup_mode;
135 s.
unpack(
"Low::lookup_mode", lookup_mode);
136 lookup_mode_ =
static_cast<casadi_int
>(lookup_mode);
Helper class for C code generation.
std::string work(casadi_int n, casadi_int sz, bool is_ref) const
std::string low(const std::string &x, const std::string &grid, casadi_int ng, casadi_int lookup_mode)
low
void local(const std::string &name, const std::string &type, const std::string &ref="")
Declare a local variable.
Helper class for Serialization.
void unpack(Sparsity &e)
Reconstruct an object from the input stream.
casadi_int numel() const
Get the number of elements.
bool is_dense() const
Check if the matrix expression is dense.
bool is_vector() const
Check if the matrix is a row or column vector.
casadi_int nnz() const
Get the number of (structural) non-zero elements.
static std::string lookup_mode_from_enum(casadi_int lookup_mode)
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
void serialize_body(SerializingStream &s) const override
Serialize an object without type information.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate the function numerically.
Low(const MX &v, const MX &p, const Dict &opts)
Constructor.
int sp_reverse(bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity backwards.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
void generate(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< casadi_int > &res, const std::vector< bool > &arg_is_ref, std::vector< bool > &res_is_ref) const override
Generate code for the operation.
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
static casadi_int interpret_lookup_mode(const std::string &lookup_mode, casadi_int n)
int sp_forward(const bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity forward.
std::string disp(const std::vector< std::string > &arg) const override
Print expression.
Node class for MX objects.
casadi_int nnz(casadi_int i=0) const
const MX & dep(casadi_int ind=0) const
dependencies - functions that have to be evaluated before this one
virtual void serialize_body(SerializingStream &s) const
Serialize an object without type information.
void set_sparsity(const Sparsity &sparsity)
Set the sparsity.
void set_dep(const MX &dep)
Set unary dependency.
const Sparsity & sparsity() const
Get the sparsity pattern.
Helper class for Serialization.
void pack(const Sparsity &e)
Serializes an object to the output stream.
unsigned long long bvec_t
casadi_int casadi_low(T1 x, const T1 *grid, casadi_int ng, casadi_int lookup_mode)
constexpr casadi_int LOOKUP_BINARY
std::string str(const T &v)
String representation, any type.
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
constexpr casadi_int LOOKUP_EXACT
constexpr casadi_int LOOKUP_LINEAR