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)
const override;
68 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
71 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
74 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
79 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
84 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
85 std::vector<std::vector<MX> >& fsens)
const override;
90 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
91 std::vector<std::vector<MX> >& asens)
const override;
96 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
101 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
106 casadi_int op()
const override {
return OP_MTIMES;}
109 casadi_int n_inplace()
const override {
return 1;}
114 bool is_equal(
const MXNode* node, casadi_int depth)
const override {
115 return sameOpAndDeps(node, depth) &&
dynamic_cast<const Multiplication*
>(node)!=
nullptr;
121 size_t sz_w()
const override {
return sparsity().size1();}
126 void serialize_type(SerializingStream& s)
const override;
131 static MXNode* deserialize(DeserializingStream& s);
137 explicit Multiplication(DeserializingStream& s) : MXNode(s) {}
148 class CASADI_EXPORT DenseMultiplication :
public Multiplication{
154 DenseMultiplication(
const MX& z,
const MX& x,
const MX& y)
155 : Multiplication(z, x, y) {}
160 ~DenseMultiplication()
override {}
165 void generate(CodeGenerator& g,
166 const std::vector<casadi_int>& arg,
167 const std::vector<casadi_int>& res)
const override;
172 void serialize_type(SerializingStream& s)
const override;
177 explicit DenseMultiplication(DeserializingStream& s) : Multiplication(s) {}