26 #ifndef CASADI_MMIN_HPP
27 #define CASADI_MMIN_HPP
29 #include "mx_node.hpp"
40 class CASADI_EXPORT MMin :
public MXNode {
46 explicit MMin(
const MX& x);
56 std::string disp(
const std::vector<std::string>& arg)
const override;
61 casadi_int op()
const override {
return OP_MMIN;}
66 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
71 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
76 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
81 void generate(CodeGenerator& g,
82 const std::vector<casadi_int>& arg,
83 const std::vector<casadi_int>& res)
const override;
87 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
88 std::vector<std::vector<MX> >& fsens)
const override;
93 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
94 std::vector<std::vector<MX> >& asens)
const override;
99 static MXNode* deserialize(DeserializingStream& s) {
return new MMin(s); }
104 explicit MMin(DeserializingStream& s) : MXNode(s) {}
113 class CASADI_EXPORT MMax :
public MXNode {
119 explicit MMax(
const MX& x);
129 std::string disp(
const std::vector<std::string>& arg)
const override;
134 casadi_int op()
const override {
return OP_MMAX;}
139 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
144 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
149 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
154 void generate(CodeGenerator& g,
155 const std::vector<casadi_int>& arg,
156 const std::vector<casadi_int>& res)
const override;
160 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
161 std::vector<std::vector<MX> >& fsens)
const override;
166 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
167 std::vector<std::vector<MX> >& asens)
const override;
172 static MXNode* deserialize(DeserializingStream& s) {
return new MMax(s); }
177 explicit MMax(DeserializingStream& s) : MXNode(s) {}