26 #ifndef CASADI_MX_FUNCTION_HPP
27 #define CASADI_MX_FUNCTION_HPP
34 #include "x_function.hpp"
35 #include "mx_node.hpp"
53 std::vector<casadi_int> arg;
56 std::vector<casadi_int> res;
66 class CASADI_EXPORT MXFunction :
67 public XFunction<MXFunction, MX, MXNode>{
72 typedef MXAlgEl AlgEl;
77 std::vector<AlgEl> algorithm_;
82 std::vector<casadi_int> workloc_;
85 std::vector<MX> free_vars_;
88 std::vector<double> default_in_;
94 bool print_instructions_;
99 MXFunction(
const std::string& name,
100 const std::vector<MX>& input,
const std::vector<MX>& output,
101 const std::vector<std::string>& name_in,
102 const std::vector<std::string>& name_out);
107 ~MXFunction()
override;
112 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w,
void* mem)
const override;
117 void disp_more(std::ostream& stream)
const override;
122 std::string class_name()
const override {
return "MXFunction";}
127 bool is_a(
const std::string& type,
bool recursive)
const override;
133 static const Options options_;
134 const Options& get_options()
const override {
return options_;}
138 Dict get_stats(
void* mem)
const override;
141 Dict generate_options(
const std::string& target=
"clone")
const override;
146 void init(
const Dict& opts)
override;
151 void codegen_declarations(CodeGenerator& g)
const override;
156 void codegen_incref(CodeGenerator& g)
const override;
161 void codegen_decref(CodeGenerator& g)
const override;
166 void codegen_body(CodeGenerator& g)
const override;
171 void serialize_body(SerializingStream &s)
const override;
176 static ProtoFunction* deserialize(DeserializingStream& s);
183 void generate_lifted(Function& vdef_fcn, Function& vinit_fcn)
const override;
186 bool should_inline(
bool always_inline,
bool never_inline)
const override;
191 int eval_sx(
const SXElem** arg, SXElem** res,
192 casadi_int* iw, SXElem* w,
void* mem)
const override;
198 bool always_inline,
bool never_inline)
const override;
203 void ad_forward(
const std::vector<std::vector<MX> >& fwdSeed,
204 std::vector<std::vector<MX> >& fwdSens)
const;
209 void ad_reverse(
const std::vector<std::vector<MX> >& adjSeed,
210 std::vector<std::vector<MX> >& adjSens)
const;
213 std::vector<MX> symbolic_output(
const std::vector<MX>& arg)
const override;
218 int sp_forward(
const bvec_t** arg, bvec_t** res,
219 casadi_int* iw, bvec_t* w,
void* mem)
const override;
224 int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w,
void* mem)
const override;
227 std::string print(
const AlgEl& el)
const;
230 void print_arg(std::ostream &stream, casadi_int k,
const AlgEl& el,
const double** arg)
const;
233 void print_res(std::ostream &stream, casadi_int k,
const AlgEl& el,
double** res)
const;
239 const MX mx_in(casadi_int ind)
const override;
240 const std::vector<MX> mx_in()
const override;
244 std::vector<MX> free_mx()
const override {
return free_vars_;}
249 bool has_free()
const override {
return !free_vars_.empty();}
254 std::vector<std::string> get_free()
const override {
255 std::vector<std::string> ret;
256 for (
auto&& e : free_vars_) ret.push_back(e.name());
263 casadi_int n_nodes()
const override {
return algorithm_.size();}
265 casadi_int n_instructions()
const override {
return algorithm_.size();}
270 MX instruction_MX(casadi_int k)
const override;
275 casadi_int instruction_id(casadi_int k)
const override {
return algorithm_.at(k).op;}
280 double get_default_in(casadi_int ind)
const override {
return default_in_.at(ind);}
285 std::vector<casadi_int> instruction_input(casadi_int k)
const override;
290 std::vector<casadi_int> instruction_output(casadi_int k)
const override;
295 void export_code_body(
const std::string& lang,
296 std::ostream &stream,
const Dict& options)
const override;
299 void substitute_inplace(std::vector<MX>& vdef, std::vector<MX>& ex)
const;
302 void find(std::map<FunctionInternal*, Function>& all_fun, casadi_int max_depth)
const override;
307 void change_option(
const std::string& option_name,
const GenericType& option_value)
override;
313 explicit MXFunction(DeserializingStream& s);
std::vector< MX > MXVector
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.