26 #ifndef CASADI_PROJECT_HPP
27 #define CASADI_PROJECT_HPP
29 #include "mx_node.hpp"
55 std::string disp(
const std::vector<std::string>& arg)
const override;
59 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
62 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
65 int eval_sx(
const SXElem** arg,
SXElem** res, casadi_int* iw,
SXElem* w)
const override;
70 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
76 std::vector<std::array<MX, 3> >& res)
const override {
77 eval_linear_rearrange(arg, res);
83 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
84 std::vector<std::vector<MX> >& fsens)
const override;
89 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
90 std::vector<std::vector<MX> >& asens)
const override;
96 const std::vector<casadi_int>& arg,
97 const std::vector<casadi_int>& res,
98 const std::vector<bool>& arg_is_ref,
99 std::vector<bool>& res_is_ref)
const override;
104 int sp_forward(
const bvec_t** arg,
bvec_t** res, casadi_int* iw,
bvec_t* w)
const override;
119 size_t sz_w()
const override {
return size1();}
157 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
160 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
163 int eval_sx(
const SXElem** arg,
SXElem** res, casadi_int* iw,
SXElem* w)
const override;
169 const std::vector<casadi_int>& arg,
170 const std::vector<casadi_int>& res,
171 const std::vector<bool>& arg_is_ref,
172 std::vector<bool>& res_is_ref)
const override;
177 size_t sz_w()
const override {
return 0;}
207 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
210 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
213 int eval_sx(
const SXElem** arg,
SXElem** res, casadi_int* iw,
SXElem* w)
const override;
219 const std::vector<casadi_int>& arg,
220 const std::vector<casadi_int>& res,
221 const std::vector<bool>& arg_is_ref,
222 std::vector<bool>& res_is_ref)
const override;
227 size_t sz_w()
const override {
return 0;}
Helper class for C code generation.
Densify(DeserializingStream &s)
Deserializing constructor.
Densify(const MX &x, const Sparsity &sp)
Constructor.
size_t sz_w() const override
Get required length of iw field.
~Densify() override
Destructor.
Helper class for Serialization.
Node class for MX objects.
Change the sparsity of an expression.
casadi_int op() const override
Get the operation.
Project(DeserializingStream &s)
Deserializing constructor.
void eval_linear(const std::vector< std::array< MX, 3 > > &arg, std::vector< std::array< MX, 3 > > &res) const override
Evaluate the MX node on a const/linear/nonlinear partition.
size_t sz_w() const override
Get required length of w field.
~Project() override
Destructor.
The basic scalar symbolic class of CasADi.
Helper class for Serialization.
Sparsify(const MX &x, const Sparsity &sp)
Constructor.
size_t sz_w() const override
Get required length of iw field.
Sparsify(DeserializingStream &s)
Deserializing constructor.
~Sparsify() override
Destructor.
unsigned long long bvec_t