26 #include "assertion.hpp"
27 #include "serializing_stream.hpp"
32 : fail_message_(fail_message) {
34 "Assertion:: assertion expression y must be scalar, but got " + y.
dim());
40 return "assertion(" + arg.at(0) +
", " + arg.at(1) +
")";
44 res[0] = arg[0].attachAssert(arg[1], fail_message_);
48 std::vector<std::vector<MX> >& fsens)
const {
49 for (casadi_int d=0; d<fsens.size(); ++d) {
50 fsens[d][0] = fseed[d][0];
55 std::vector<std::vector<MX> >& asens)
const {
56 for (casadi_int d=0; d<aseed.size(); ++d) {
57 asens[d][0] += aseed[d][0];
63 std::copy(arg[0], arg[0]+
nnz(), res[0]);
68 int Assertion::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
70 casadi_error(
"Assertion error: " + fail_message_);
75 std::copy(arg[0], arg[0]+
nnz(), res[0]);
82 std::copy(arg[0], arg[0]+
nnz(), res[0]);
92 for (casadi_int i=0; i<n; ++i) {
101 const std::vector<casadi_int>& arg,
102 const std::vector<casadi_int>& res,
103 const std::vector<bool>& arg_is_ref,
104 std::vector<bool>& res_is_ref)
const {
106 g <<
"if (" << g.
workel(arg[1]) <<
"!=1.) {\n"
107 <<
" /* " << fail_message_ <<
" */\n"
116 s.
pack(
"Assertion::fail_message", fail_message_);
120 s.
unpack(
"Assertion::fail_message", fail_message_);
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate the function symbolically (SX)
std::string disp(const std::vector< std::string > &arg) const override
Print expression.
void generate(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< casadi_int > &res, const std::vector< bool > &arg_is_ref, std::vector< bool > &res_is_ref) const override
Generate code for the operation.
int sp_reverse(bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity backwards.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate the function numerically.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
int sp_forward(const bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity forward.
void serialize_body(SerializingStream &s) const override
Serialize an object without type information.
Assertion(const MX &x, const MX &y, const std::string &fail_message)
Constructor.
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
Helper class for C code generation.
std::string workel(casadi_int n) const
Helper class for Serialization.
void unpack(Sparsity &e)
Reconstruct an object from the input stream.
std::string dim(bool with_nz=false) const
Get string representation of dimensions.
bool is_scalar(bool scalar_and_dense=false) const
Check if the matrix expression is scalar.
Node class for MX objects.
void generate_copy(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< casadi_int > &res, const std::vector< bool > &arg_is_ref, std::vector< bool > &res_is_ref, casadi_int i) const
casadi_int nnz(casadi_int i=0) const
virtual void serialize_body(SerializingStream &s) const
Serialize an object without type information.
void set_sparsity(const Sparsity &sparsity)
Set the sparsity.
void set_dep(const MX &dep)
Set unary dependency.
const Sparsity & sparsity() const
Get the sparsity pattern.
The basic scalar symbolic class of CasADi.
Helper class for Serialization.
void pack(const Sparsity &e)
Serializes an object to the output stream.
unsigned long long bvec_t