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 ad_forward(
const std::vector<std::vector<MX> >& fseed,
70 std::vector<std::vector<MX> >& fsens)
const override;
75 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
76 std::vector<std::vector<MX> >& asens)
const override;
81 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
86 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
91 std::string disp(
const std::vector<std::string>& arg)
const override;
96 void generate(CodeGenerator& g,
97 const std::vector<casadi_int>& arg,
98 const std::vector<casadi_int>& res)
const override;
103 casadi_int op()
const override {
return OP_TRANSPOSE;}
108 size_t sz_iw()
const override {
return size2()+1;}
111 MX get_transpose()
const override {
return dep();}
118 MX get_solve_triu(
const MX& r,
bool tr)
const override {
119 return dep()->get_solve_tril(r, !tr);
123 MX get_solve_tril(
const MX& r,
bool tr)
const override {
124 return dep()->get_solve_triu(r, !tr);
128 MX get_solve_triu_unity(
const MX& r,
bool tr)
const override {
129 return dep()->get_solve_tril_unity(r, !tr);
133 MX get_solve_tril_unity(
const MX& r,
bool tr)
const override {
134 return dep()->get_solve_triu_unity(r, !tr);
140 bool is_equal(
const MXNode* node, casadi_int depth)
const override {
141 return sameOpAndDeps(node, depth);
147 void serialize_type(SerializingStream& s)
const override;
152 static MXNode* deserialize(DeserializingStream& s);
158 explicit Transpose(DeserializingStream& s) : MXNode(s) {}
167 class CASADI_EXPORT DenseTranspose :
public Transpose {
171 DenseTranspose(
const MX& x) : Transpose(x) {}
174 ~DenseTranspose()
override {}
178 int eval_gen(
const T*
const* arg, T*
const* res, casadi_int* iw, T* w)
const;
181 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
184 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
189 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
194 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
199 void generate(CodeGenerator& g,
200 const std::vector<casadi_int>& arg,
201 const std::vector<casadi_int>& res)
const override;
206 size_t sz_iw()
const override {
return 0;}
211 void serialize_type(SerializingStream& s)
const override;
216 explicit DenseTranspose(DeserializingStream& s) : Transpose(s) {}