26 #ifndef CASADI_ASSERTION_HPP
27 #define CASADI_ASSERTION_HPP
29 #include "mx_node.hpp"
41 class CASADI_EXPORT Assertion :
public MXNode {
45 Assertion(
const MX& x,
const MX& y,
const std::string & fail_message);
48 ~Assertion()
override {}
53 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
58 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
59 std::vector<std::vector<MX> >& fsens)
const override;
64 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
65 std::vector<std::vector<MX> >& asens)
const override;
68 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 int sp_forward(
const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
81 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w)
const override;
86 void generate(CodeGenerator& g,
87 const std::vector<casadi_int>& arg,
88 const std::vector<casadi_int>& res)
const override;
93 std::string disp(
const std::vector<std::string>& arg)
const override;
98 casadi_int op()
const override {
return OP_ASSERTION;}
101 casadi_int n_inplace()
const override {
return 1;}
106 void serialize_body(SerializingStream& s)
const override;
111 static MXNode* deserialize(DeserializingStream& s) {
return new Assertion(s); }
117 explicit Assertion(DeserializingStream& s);
120 std::string fail_message_;