26 #ifndef CASADI_MULTIPLICATION_HPP
27 #define CASADI_MULTIPLICATION_HPP
29 #include "mx_node.hpp"
41 class CASADI_EXPORT Multiplication :
public MXNode {
47 Multiplication(
const MX& z,
const MX& x,
const MX& y);
52 ~Multiplication()
override {}
57 std::string disp(
const std::vector<std::string>& arg)
const override;
62 void generate(CodeGenerator& g,
63 const std::vector<casadi_int>& arg,
64 const std::vector<casadi_int>& res,
65 const std::vector<bool>& arg_is_ref,
66 std::vector<bool>& res_is_ref)
const override;
70 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
73 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
76 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
81 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
86 void eval_linear(
const std::vector<std::array<MX, 3> >& arg,
87 std::vector<std::array<MX, 3> >& res)
const override;
92 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
93 std::vector<std::vector<MX> >& fsens)
const override;
98 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
99 std::vector<std::vector<MX> >& asens)
const override;
104 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
109 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
114 casadi_int op()
const override {
return OP_MTIMES;}
117 casadi_int n_inplace()
const override {
return 1;}
122 bool is_equal(
const MXNode* node, casadi_int depth)
const override {
123 return sameOpAndDeps(node, depth) &&
dynamic_cast<const Multiplication*
>(node)!=
nullptr;
129 size_t sz_w()
const override {
return sparsity().size1();}
134 void serialize_type(SerializingStream& s)
const override;
139 static MXNode* deserialize(DeserializingStream& s);
145 explicit Multiplication(DeserializingStream& s) : MXNode(s) {}
156 class CASADI_EXPORT DenseMultiplication :
public Multiplication{
162 DenseMultiplication(
const MX& z,
const MX& x,
const MX& y)
163 : Multiplication(z, x, y) {}
168 ~DenseMultiplication()
override {}
173 void generate(CodeGenerator& g,
174 const std::vector<casadi_int>& arg,
175 const std::vector<casadi_int>& res,
176 const std::vector<bool>& arg_is_ref,
177 std::vector<bool>& res_is_ref)
const override;
182 void serialize_type(SerializingStream& s)
const override;
187 explicit DenseMultiplication(DeserializingStream& s) : Multiplication(s) {}