26 #ifndef CASADI_DOT_HPP
27 #define CASADI_DOT_HPP
29 #include "mx_node.hpp"
42 class CASADI_EXPORT Dot :
public MXNode {
46 Dot(
const MX& x,
const MX& y);
53 int eval_gen(
const T** arg, T** 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 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
69 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
74 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
79 void eval_linear(
const std::vector<std::array<MX, 3> >& arg,
80 std::vector<std::array<MX, 3> >& res)
const override;
85 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
86 std::vector<std::vector<MX> >& fsens)
const override;
91 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
92 std::vector<std::vector<MX> >& asens)
const override;
97 void generate(CodeGenerator& g,
98 const std::vector<casadi_int>& arg,
99 const std::vector<casadi_int>& res,
100 const std::vector<bool>& arg_is_ref,
101 std::vector<bool>& res_is_ref)
const override;
106 std::string disp(
const std::vector<std::string>& arg)
const override;
111 casadi_int op()
const override {
return OP_DOT;}
116 static MXNode* deserialize(DeserializingStream& s) {
return new Dot(s); }
122 explicit Dot(DeserializingStream& s) : MXNode(s) {}