26 #ifndef CASADI_SPLIT_HPP
27 #define CASADI_SPLIT_HPP
29 #include "multiple_output.hpp"
43 class CASADI_EXPORT Split :
public MultipleOutput {
46 Split(
const MX& x,
const std::vector<casadi_int>& offset);
49 ~Split()
override = 0;
54 casadi_int nout()
const override {
return output_sparsity_.size(); }
59 const Sparsity& sparsity(casadi_int oind)
const override {
return output_sparsity_.at(oind);}
63 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
66 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
69 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
74 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
79 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
84 void generate(CodeGenerator& g,
85 const std::vector<casadi_int>& arg,
86 const std::vector<casadi_int>& res)
const override;
89 Dict info()
const override;
92 std::vector<casadi_int> offset_;
93 std::vector<Sparsity> output_sparsity_;
98 void serialize_body(SerializingStream& s)
const override;
104 explicit Split(DeserializingStream& s);
113 class CASADI_EXPORT Horzsplit :
public Split {
117 Horzsplit(
const MX& x,
const std::vector<casadi_int>& offset);
120 ~Horzsplit()
override {}
125 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
130 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
131 std::vector<std::vector<MX> >& fsens)
const override;
136 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
137 std::vector<std::vector<MX> >& asens)
const override;
142 std::string disp(
const std::vector<std::string>& arg)
const override;
147 casadi_int op()
const override {
return OP_HORZSPLIT;}
150 MX get_horzcat(
const std::vector<MX>& x)
const override;
155 static MXNode* deserialize(DeserializingStream& s) {
return new Horzsplit(s); }
161 explicit Horzsplit(DeserializingStream& s) : Split(s) {}
170 class CASADI_EXPORT Diagsplit :
public Split {
174 Diagsplit(
const MX& x,
175 const std::vector<casadi_int>& offset1,
const std::vector<casadi_int>& offset2);
178 ~Diagsplit()
override {}
183 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
188 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
189 std::vector<std::vector<MX> >& fsens)
const override;
194 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
195 std::vector<std::vector<MX> >& asens)
const override;
200 std::string disp(
const std::vector<std::string>& arg)
const override;
205 casadi_int op()
const override {
return OP_DIAGSPLIT;}
208 MX get_diagcat(
const std::vector<MX>& x)
const override;
213 static MXNode* deserialize(DeserializingStream& s) {
return new Diagsplit(s); }
219 explicit Diagsplit(DeserializingStream& s) : Split(s) {}
228 class CASADI_EXPORT Vertsplit :
public Split {
232 Vertsplit(
const MX& x,
const std::vector<casadi_int>& offset);
235 ~Vertsplit()
override {}
240 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
245 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
246 std::vector<std::vector<MX> >& fsens)
const override;
251 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
252 std::vector<std::vector<MX> >& asens)
const override;
257 std::string disp(
const std::vector<std::string>& arg)
const override;
262 casadi_int op()
const override {
return OP_VERTSPLIT;}
265 MX get_vertcat(
const std::vector<MX>& x)
const override;
270 static MXNode* deserialize(DeserializingStream& s) {
return new Vertsplit(s); }
276 explicit Vertsplit(DeserializingStream& s) : Split(s) {}
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.