26 #ifndef CASADI_TRANSPOSE_HPP
27 #define CASADI_TRANSPOSE_HPP
29 #include "mx_node.hpp"
42 class CASADI_EXPORT Transpose :
public MXNode {
46 Transpose(
const MX& x);
49 ~Transpose()
override {}
53 int eval_gen(
const T*
const* arg, T*
const* res, casadi_int* iw, T* w)
const;
56 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
59 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
64 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
69 void eval_linear(
const std::vector<std::array<MX, 3> >& arg,
70 std::vector<std::array<MX, 3> >& res)
const override {
71 eval_linear_rearrange(arg, res);
77 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
78 std::vector<std::vector<MX> >& fsens)
const override;
83 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
84 std::vector<std::vector<MX> >& asens)
const override;
89 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
94 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
99 std::string disp(
const std::vector<std::string>& arg)
const override;
104 void generate(CodeGenerator& g,
105 const std::vector<casadi_int>& arg,
106 const std::vector<casadi_int>& res,
107 const std::vector<bool>& arg_is_ref,
108 std::vector<bool>& res_is_ref)
const override;
113 casadi_int op()
const override {
return OP_TRANSPOSE;}
118 size_t sz_iw()
const override {
return size2()+1;}
121 MX get_transpose()
const override {
return dep();}
128 MX get_solve_triu(
const MX& r,
bool tr)
const override {
129 return dep()->get_solve_tril(r, !tr);
133 MX get_solve_tril(
const MX& r,
bool tr)
const override {
134 return dep()->get_solve_triu(r, !tr);
138 MX get_solve_triu_unity(
const MX& r,
bool tr)
const override {
139 return dep()->get_solve_tril_unity(r, !tr);
143 MX get_solve_tril_unity(
const MX& r,
bool tr)
const override {
144 return dep()->get_solve_triu_unity(r, !tr);
150 bool is_equal(
const MXNode* node, casadi_int depth)
const override {
151 return sameOpAndDeps(node, depth);
157 void serialize_type(SerializingStream& s)
const override;
162 static MXNode* deserialize(DeserializingStream& s);
168 explicit Transpose(DeserializingStream& s) : MXNode(s) {}
177 class CASADI_EXPORT DenseTranspose :
public Transpose {
181 DenseTranspose(
const MX& x) : Transpose(x) {}
184 ~DenseTranspose()
override {}
188 int eval_gen(
const T*
const* arg, T*
const* res, casadi_int* iw, T* w)
const;
191 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
194 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
199 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
204 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
209 void generate(CodeGenerator& g,
210 const std::vector<casadi_int>& arg,
211 const std::vector<casadi_int>& res,
212 const std::vector<bool>& arg_is_ref,
213 std::vector<bool>& res_is_ref)
const override;
218 size_t sz_iw()
const override {
return 0;}
223 void serialize_type(SerializingStream& s)
const override;
228 explicit DenseTranspose(DeserializingStream& s) : Transpose(s) {}