26 #ifndef CASADI_NORM_HPP
27 #define CASADI_NORM_HPP
29 #include "mx_node.hpp"
40 class CASADI_EXPORT Norm :
public MXNode {
46 explicit Norm(
const MX& x);
57 explicit Norm(DeserializingStream& s) : MXNode(s) {}
66 class CASADI_EXPORT NormF :
public Norm {
72 explicit NormF(
const MX& x) : Norm(x) {}
81 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
84 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
87 int eval_sx(
const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w)
const override;
92 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
97 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
98 std::vector<std::vector<MX> >& fsens)
const override;
103 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
104 std::vector<std::vector<MX> >& asens)
const override;
109 void generate(CodeGenerator& g,
110 const std::vector<casadi_int>& arg,
111 const std::vector<casadi_int>& res)
const override;
116 std::string disp(
const std::vector<std::string>& arg)
const override;
121 casadi_int op()
const override {
return OP_NORMF;}
126 static MXNode* deserialize(DeserializingStream& s) {
return new NormF(s); }
132 explicit NormF(DeserializingStream& s) : Norm(s) {}
141 class CASADI_EXPORT Norm2 :
public Norm {
147 explicit Norm2(
const MX& x): Norm(x) {}
157 std::string disp(
const std::vector<std::string>& arg)
const override;
162 casadi_int op()
const override {
return OP_NORM2;}
167 static MXNode* deserialize(DeserializingStream& s) {
return new Norm2(s); }
173 explicit Norm2(DeserializingStream& s) : Norm(s) {}
182 class CASADI_EXPORT Norm1 :
public Norm {
188 explicit Norm1(
const MX& x) : Norm(x) {}
198 std::string disp(
const std::vector<std::string>& arg)
const override;
203 casadi_int op()
const override {
return OP_NORM1;}
208 static MXNode* deserialize(DeserializingStream& s) {
return new Norm1(s); }
214 explicit Norm1(DeserializingStream& s) : Norm(s) {}
223 class CASADI_EXPORT NormInf :
public Norm {
229 explicit NormInf(
const MX& x) : Norm(x) {}
234 ~NormInf()
override {}
239 std::string disp(
const std::vector<std::string>& arg)
const override;
244 casadi_int op()
const override {
return OP_NORMINF;}
249 static MXNode* deserialize(DeserializingStream& s) {
return new NormInf(s); }
255 explicit NormInf(DeserializingStream& s) : Norm(s) {}