26 #ifndef CASADI_PROJECT_HPP
27 #define CASADI_PROJECT_HPP
29 #include "mx_node.hpp"
39 class CASADI_EXPORT Project :
public MXNode {
45 Project(
const MX& x,
const Sparsity& sp);
50 ~Project()
override {}
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;
75 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
76 std::vector<std::vector<MX> >& fsens)
const override;
81 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
82 std::vector<std::vector<MX> >& asens)
const override;
87 void generate(CodeGenerator& g,
88 const std::vector<casadi_int>& arg,
89 const std::vector<casadi_int>& res)
const override;
94 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
99 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
104 casadi_int op()
const override {
return OP_PROJECT;}
109 size_t sz_w()
const override {
return size1();}
114 void serialize_type(SerializingStream& s)
const override;
119 static MXNode* deserialize(DeserializingStream& s);
125 explicit Project(DeserializingStream& s) : MXNode(s) {}
136 class CASADI_EXPORT Densify :
public Project {
140 Densify(
const MX& x,
const Sparsity& sp) : Project(x, sp) {}
143 ~Densify()
override {}
147 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
150 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
153 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
158 void generate(CodeGenerator& g,
159 const std::vector<casadi_int>& arg,
160 const std::vector<casadi_int>& res)
const override;
165 size_t sz_w()
const override {
return 0;}
170 void serialize_type(SerializingStream& s)
const override;
175 explicit Densify(DeserializingStream& s) : Project(s) {}
184 class CASADI_EXPORT Sparsify :
public Project {
188 Sparsify(
const MX& x,
const Sparsity& sp) : Project(x, sp) {}
191 ~Sparsify()
override {}
195 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
198 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
201 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
206 void generate(CodeGenerator& g,
207 const std::vector<casadi_int>& arg,
208 const std::vector<casadi_int>& res)
const override;
213 size_t sz_w()
const override {
return 0;}
218 void serialize_type(SerializingStream& s)
const override;
223 explicit Sparsify(DeserializingStream& s) : Project(s) {}