26 #ifndef CASADI_SPLIT_HPP
27 #define CASADI_SPLIT_HPP
29 #include "multiple_output.hpp"
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;
75 std::vector<std::array<MX, 3> >& res)
const override {
76 eval_linear_rearrange(arg, res);
82 int sp_forward(
const bvec_t** arg,
bvec_t** res, casadi_int* iw,
bvec_t* w)
const override;
93 const std::vector<casadi_int>& arg,
94 const std::vector<casadi_int>& res,
95 const std::vector<bool>& arg_is_ref,
96 std::vector<bool>& res_is_ref)
const override;
99 Dict info()
const override;
127 Horzsplit(
const MX& x,
const std::vector<casadi_int>& offset);
135 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
140 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
141 std::vector<std::vector<MX> >& fsens)
const override;
146 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
147 std::vector<std::vector<MX> >& asens)
const override;
152 std::string disp(
const std::vector<std::string>& arg)
const override;
160 MX get_horzcat(
const std::vector<MX>& x)
const override;
185 const std::vector<casadi_int>& offset1,
const std::vector<casadi_int>& offset2);
193 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
198 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
199 std::vector<std::vector<MX> >& fsens)
const override;
204 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
205 std::vector<std::vector<MX> >& asens)
const override;
210 std::string disp(
const std::vector<std::string>& arg)
const override;
218 MX get_diagcat(
const std::vector<MX>& x)
const override;
242 Vertsplit(
const MX& x,
const std::vector<casadi_int>& offset);
250 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
255 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
256 std::vector<std::vector<MX> >& fsens)
const override;
261 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
262 std::vector<std::vector<MX> >& asens)
const override;
267 std::string disp(
const std::vector<std::string>& arg)
const override;
275 MX get_vertcat(
const std::vector<MX>& x)
const override;
Helper class for C code generation.
Helper class for Serialization.
Diag split, x -> x0, x1, ...
casadi_int op() const override
Get the operation.
Diagsplit(DeserializingStream &s)
Deserializing constructor.
static MXNode * deserialize(DeserializingStream &s)
Deserialize without type information.
~Diagsplit() override
Destructor.
Horizontal split, x -> x0, x1, ...
Horzsplit(DeserializingStream &s)
Deserializing constructor.
~Horzsplit() override
Destructor.
casadi_int op() const override
Get the operation.
static MXNode * deserialize(DeserializingStream &s)
Deserialize without type information.
Node class for MX objects.
The basic scalar symbolic class of CasADi.
Helper class for Serialization.
Split: Split into multiple expressions splitting the nonzeros.
std::vector< Sparsity > output_sparsity_
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.
std::vector< casadi_int > offset_
casadi_int nout() const override
Number of outputs.
const Sparsity & sparsity(casadi_int oind) const override
Get the sparsity of output oind.
Vertical split of vectors, x -> x0, x1, ...
static MXNode * deserialize(DeserializingStream &s)
Deserialize without type information.
~Vertsplit() override
Destructor.
Vertsplit(DeserializingStream &s)
Deserializing constructor.
casadi_int op() const override
Get the operation.
unsigned long long bvec_t
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.