26 #ifndef CASADI_DAE_BUILDER_HPP
27 #define CASADI_DAE_BUILDER_HPP
29 #include "function.hpp"
34 class DaeBuilderInternal;
70 public SWIG_IF_ELSE(PrintableCommon, Printable<DaeBuilder>) {
74 std::string
type_name()
const {
return "DaeBuilder";}
80 explicit DaeBuilder(
const std::string& name,
const std::string& path =
"",
86 const std::string&
name()
const;
98 std::vector<std::string>
t_new()
const {
return all(
"t");}
103 std::vector<std::string>
x()
const {
return all(
"x");}
106 std::vector<std::string>
y()
const;
111 std::vector<MX>
ode()
const;
116 std::vector<std::string>
z()
const {
return all(
"z");}
121 std::vector<MX>
alg()
const;
126 std::vector<std::string>
q()
const {
return all(
"q");}
146 std::vector<std::string>
u()
const {
return all(
"u");}
151 std::vector<std::string>
p()
const {
return all(
"p");}
156 std::vector<std::string>
c()
const {
return all(
"c");}
166 std::vector<std::string>
d()
const {
return all(
"d");}
178 std::vector<std::string>
w()
const {
return all(
"w");}
223 casadi_int
nx()
const;
228 casadi_int
nz()
const;
233 casadi_int
nq()
const;
243 casadi_int
ny()
const;
248 casadi_int
nu()
const;
253 casadi_int
np()
const;
258 casadi_int
nc()
const;
263 casadi_int
nd()
const;
268 casadi_int
nw()
const;
278 const std::string& causality,
279 const std::string& variability,
284 const std::string& causality,
292 void add(
const std::string& name,
293 const std::string& causality,
294 const std::string& variability,
298 #ifdef WITH_DEPRECATED_FEATURES
300 const MX&
t()
const {
return time();}
306 MX add_p(
const std::string& name=std::string());
309 MX add_u(
const std::string& name=std::string());
312 MX add_x(
const std::string& name=std::string());
315 MX add_z(
const std::string& name=std::string());
318 MX add_q(
const std::string& name=std::string());
341 void when(
const MX& cond,
const std::vector<std::string>& eqs,
const Dict& opts=
Dict());
344 std::string
assign(
const std::string& name,
const MX& val);
347 std::string
reinit(
const std::string& name,
const MX& val);
352 #ifdef WITH_DEPRECATED_FEATURES
354 void set_ode(
const std::string& name,
const MX& ode_rhs) {
355 eq(var(name), ode_rhs);
359 void set_alg(
const std::string& name,
const MX& alg_rhs) {
366 set_init(lhs.
name(), rhs);
370 casadi_int
ne()
const {
return nzero();}
373 std::vector<std::string>
e()
const {
return all(
"zero");}
382 void reorder(
const std::string& cat,
const std::vector<std::string>& v);
384 #ifdef WITH_DEPRECATED_FEATURES
389 void set_all(
const std::string& v,
const std::vector<std::string>& name);
422 void sort_z(
const std::vector<std::string>& z_order);
436 void sort(
const std::string& cat);
439 void lift(
bool lift_shared =
true,
bool lift_calls =
true);
442 void prune(
bool prune_p =
true,
bool prune_u =
true);
455 const std::vector<std::string>& arg,
456 const std::vector<std::string>& res,
const Dict& opts=
Dict());
472 std::vector<Function>
fun()
const;
482 void parse_fmi(
const std::string& filename) {load_fmi_description(filename); }
497 void add_lc(
const std::string& name,
const std::vector<std::string>& f_out);
501 const std::vector<std::string>& name_in,
502 const std::vector<std::string>& name_out,
bool sx,
bool lifted_calls =
false)
const;
513 const std::vector<std::string>& name_in,
514 const std::vector<std::string>& name_out,
533 const std::vector<std::string>& s_in,
534 const std::vector<std::string>& s_out)
const;
547 MX var(
const std::string& name)
const;
552 std::vector<std::string>
der(
const std::vector<std::string>& name)
const;
561 std::vector<std::string>
pre(
const std::vector<std::string>& name)
const;
570 MX beq(
const std::string& name)
const;
586 std::string
type(
const std::string& name, casadi_int fmi_version = 3)
const;
587 void set_type(
const std::string& name,
const std::string& val);
624 std::string
category(
const std::string& name)
const;
640 std::string
initial(
const std::string& name)
const;
641 void set_initial(
const std::string& name,
const std::string& val);
646 std::string
unit(
const std::string& name)
const;
647 void set_unit(
const std::string& name,
const std::string& val);
657 casadi_int
numel(
const std::string& name)
const;
660 std::vector<casadi_int>
dimension(
const std::string& name)
const;
688 #if !(defined(SWIG) && defined(SWIGMATLAB))
690 std::string
der(
const std::string& name)
const;
693 std::string
pre(
const std::string& name)
const;
696 double attribute(
const std::string& a,
const std::string& name)
const;
699 void set_attribute(
const std::string& a,
const std::string& name,
double val);
702 double min(
const std::string& name)
const;
705 void set_min(
const std::string& name,
double val);
708 double max(
const std::string& name)
const;
711 void set_max(
const std::string& name,
double val);
714 double nominal(
const std::string& name)
const;
720 std::vector<double>
start(
const std::string& name)
const;
726 void set_start(
const std::string& name,
const std::vector<double>& val);
732 void set(
const std::string& name,
double val);
735 void set(
const std::string& name,
const std::string& val);
743 std::vector<double>
attribute(
const std::string& a,
const std::vector<std::string>& name)
const;
746 void set_attribute(
const std::string& a,
const std::vector<std::string>& name,
747 const std::vector<double>& val);
750 std::vector<double>
min(
const std::vector<std::string>& name)
const;
753 void set_min(
const std::vector<std::string>& name,
const std::vector<double>& val);
756 std::vector<double>
max(
const std::vector<std::string>& name)
const;
759 void set_max(
const std::vector<std::string>& name,
const std::vector<double>& val);
762 std::vector<double>
nominal(
const std::vector<std::string>& name)
const;
765 void set_nominal(
const std::vector<std::string>& name,
const std::vector<double>& val);
768 std::vector<double>
start(
const std::vector<std::string>& name)
const;
771 void set_start(
const std::vector<std::string>& name,
const std::vector<double>& val);
774 void set(
const std::vector<std::string>& name,
const std::vector<double>& val);
777 void set(
const std::vector<std::string>& name,
const std::vector<std::string>& val);
780 std::vector<GenericType>
get(
const std::vector<std::string>& name)
const;
783 bool has(
const std::string& name)
const;
786 std::vector<std::string>
all()
const;
789 std::vector<std::string>
all(
const std::string& cat)
const;
791 #ifdef WITH_DEPRECATED_FEATURES
818 Function oracle(
bool sx =
false,
bool elim_w =
false,
bool lifted_calls =
false)
const;
824 const std::vector<std::string>& inames)
const;
827 #ifdef WITH_DEPRECATED_FEATURES
829 Variable& new_variable(
const std::string& name, casadi_int numel = 1);
833 Variable& variable(
const std::string& name);
834 const Variable& variable(
const std::string& name)
const;
836 const Variable& variable(
size_t ind)
const;
837 size_t find(
const std::string& name)
const;
838 std::vector<size_t> find(
const std::vector<std::string>& name)
const;
839 const std::string& name(
size_t ind)
const;
840 std::vector<std::string> name(
const std::vector<size_t>& ind)
const;
845 const MX& var(
size_t ind)
const;
846 std::vector<MX> var(
const std::vector<size_t>& ind)
const;
852 const DaeBuilderInternal* operator->()
const;
855 DaeBuilderInternal* operator->();
858 static bool test_cast(
const SharedObjectInternal* ptr);
A symbolic representation of a differential-algebraic equations model.
double start_time() const
Get the start time.
const MX & time() const
Expression for independent variable (usually time)
DaeBuilder(const std::string &name, const std::string &path="", const Dict &opts=Dict())
Construct a DaeBuilder instance.
void when(const MX &cond, const std::vector< std::string > &eqs, const Dict &opts=Dict())
Add when equations.
bool has_fun(const std::string &name) const
Does a particular function already exist?
Function create(const std::string &fname, const std::vector< std::string > &name_in, const std::vector< std::string > &name_out, bool sx, bool lifted_calls=false) const
Construct a function object, legacy syntax.
void set_start(const std::string &name, const std::vector< double > &val)
Set the start attribute, vector argument.
std::vector< std::string > export_fmu(const Dict &opts=Dict())
Export instance into an FMU.
void register_w(const std::string &name)
void set(const std::vector< std::string > &name, const std::vector< std::string > &val)
Set the current value (string)
void set_stop_time(double val)
Set the stop time.
std::vector< std::string > q() const
Quadrature states.
casadi_int nu() const
Free controls.
double nominal(const std::string &name) const
Get the nominal value, single variable.
void set_beq(const std::string &name, const MX &val)
[DEPRECATED] Replaced by eq
void sort_z(const std::vector< std::string > &z_order)
[DEPRECATED] Use reorder("z", new_order)
Function add_fun(const std::string &name, const Importer &compiler, const Dict &opts=Dict())
Add an external function.
void sanity_check() const
Check if dimensions match.
Function add_fun(const std::string &name, const std::vector< std::string > &arg, const std::vector< std::string > &res, const Dict &opts=Dict())
Add a function from loaded expressions.
bool has(const std::string &name) const
Check if a particular variable exists.
MX add_variable(const std::string &name, casadi_int n=1)
[DEPRECATED] Use add
std::string variability(const std::string &name) const
Get the variability.
void set_alg(const std::string &name, const MX &alg_rhs)
[DEPRECATED] Replaced by eq
std::vector< double > min(const std::vector< std::string > &name) const
Get the lower bound.
void set_value_reference(const std::string &name, casadi_int val)
casadi_int nx() const
Differential states.
void set_start(const std::string &name, double val)
Set the start attribute, single variable.
Function transition(const std::string &fname, casadi_int index) const
Construct a function describing transition at a specific events.
void sort_d()
[DEPRECATED] Use sort("d")
double tolerance() const
Get the tolerance.
std::string initial(const std::string &name) const
std::vector< double > attribute(const std::string &a, const std::vector< std::string > &name) const
Get an attribute.
Function dependent_fun(const std::string &fname, const std::vector< std::string > &s_in, const std::vector< std::string > &s_out) const
Construct a function for evaluating dependent parameters.
double max(const std::string &name) const
Get the upper bound, single variable.
std::vector< MX > cdef() const
Definitions of named constants.
void set(const std::string &name, const std::string &val)
std::string unit(const std::string &name) const
void clear_all(const std::string &v)
[DEPRECATED] Use set_variability, set_causality or set_category to change variable category
void set_min(const std::vector< std::string > &name, const std::vector< double > &val)
Set the lower bound.
void set_max(const std::string &name, double val)
Set the upper bound, single variable.
std::string der(const std::string &name) const
Get the time derivative of model variables, single variable.
Function oracle(bool sx=false, bool elim_w=false, bool lifted_calls=false) const
Get the (cached) oracle, SX or MX.
const MX & t() const
[DEPRECATED] Renamed "time"
MX add_t(const std::string &name="t")
[DEPRECATED] Replaced by add
void set_ode(const std::string &name, const MX &ode_rhs)
[DEPRECATED] Replaced by eq
Function fun(const std::string &name) const
Get function by name.
std::vector< std::string > c() const
Named constants.
std::string category(const std::string &name) const
Get the variable category.
void register_e(const std::string &name)
MX add_p(const std::string &name=std::string())
[DEPRECATED] Replaced by add
casadi_int nd() const
Dependent parameters.
void set_attribute(const std::string &a, const std::string &name, double val)
Set an attribute, single variable.
void reorder(const std::string &cat, const std::vector< std::string > &v)
Reorder variables in a category.
MX der(const MX &v) const
casadi_int ne() const
[DEPRECATED] Replaced by nzero()
std::vector< double > start(const std::string &name) const
Get the start attribute, single variable.
std::vector< std::string > der(const std::vector< std::string > &name) const
Get the time derivative of model variables.
double step_size() const
Get the step size.
MX add_c(const std::string &name, const MX &new_cdef)
[DEPRECATED] Replaced by add and eq
void parse_fmi(const std::string &filename)
void gather_fun(casadi_int max_depth=-1)
Collect embedded functions from the expression graph.
MX add_variable(const std::string &name, const Sparsity &sp)
[DEPRECATED] Use add
const std::string & name() const
Name of instance.
std::string pre(const std::string &name) const
Get the pre-variables of model variables.
std::string causality(const std::string &name) const
Get the causality.
std::vector< double > start(const std::vector< std::string > &name) const
Get the start attribute.
casadi_int nc() const
Named constants.
bool provides_directional_derivatives() const
Does the FMU provide support for analytic derivatives.
MX add(const std::string &name, const Dict &opts=Dict())
Add a new model variable, default variability and causality.
void set_tolerance(double val)
Set the tolerance.
void register_c(const std::string &name)
void eliminate_w()
[DEPRECATED] Use eliminate("w")
void set_min(const std::string &name, double val)
Set the lower bound, single variable.
std::vector< MX > wdef() const
Dependent variables and corresponding definitions.
bool has_variable(const std::string &name) const
[DEPRECATED] Ranamed "has"
std::string assign(const std::string &name, const MX &val)
Assignment inside a when-equation or if-else equation.
void tear()
Identify iteration variables and residual equations using naming convention.
Function transition() const
Construct an event transition function, default naming.
Function create(const std::string &fname, const Dict &opts=Dict()) const
Create a function with standard integrator DAE signature.
std::string type_name() const
Readable name of the class.
void eliminate_quad()
[DEPRECATED] Use eliminate("q")
void set_type(const std::string &name, const std::string &val)
double attribute(const std::string &a, const std::string &name) const
Get an attribute, single variable.
void set_unit(const std::string &name, const std::string &val)
std::vector< std::string > e() const
[DEPRECATED] Use all("zero") */
void sort(const std::string &cat)
Sort dependent parameters.
std::vector< std::string > derivatives() const
Model structure: derivatives.
bool provides_directional_derivative() const
Does the FMU provide support for analytic derivatives (FMI 2 naming)
double stop_time() const
Get the stop time.
Function create() const
Create a function with standard integrator DAE signature, default naming.
std::vector< Function > fun() const
Get all functions.
double min(const std::string &name) const
Get the lower bound, single variable.
std::vector< std::string > all() const
Get a list of all variables.
void set_max(const std::vector< std::string > &name, const std::vector< double > &val)
Set the upper bound.
Function add_fun(const Function &f)
Add an already existing function.
Function transition(const std::string &fname) const
Construct a function describing transition at any events.
std::vector< std::string > all(const std::string &cat) const
Get a list of all variables of a particular category.
void set_display_unit(const std::string &name, const std::string &val)
std::string reinit(const std::string &name, const MX &val)
Reinitialize a state inside when-equations.
std::vector< double > max(const std::vector< std::string > &name) const
Get the upper bound.
size_t add_variable_new(const std::string &name, const Sparsity &sp)
[DEPRECATED] Use add
MX operator()(const std::string &name) const
Function create(const std::string &name, const std::vector< std::string > &name_in, const std::vector< std::string > &name_out, const Dict &opts=Dict()) const
Construct a function object, names provided.
void register_z(const std::string &name)
std::vector< double > nominal(const std::vector< std::string > &name) const
Get the nominal value.
std::vector< MX > alg() const
Algebraic equations.
void set_init(const std::string &name, const MX &init_rhs)
Specify the initial equation for a variable.
void add_lc(const std::string &name, const std::vector< std::string > &f_out)
Add a named linear combination of output expressions.
void eq(const MX &lhs, const MX &rhs, const Dict &opts=Dict())
Add a simple equation.
MX add_u(const std::string &name=std::string())
[DEPRECATED] Replaced by add
std::vector< std::string > x() const
Differential states.
void set_category(const std::string &name, const std::string &val)
Set the variable category, if permitted.
casadi_int nz() const
Algebraic variables.
std::vector< std::string > y() const
Outputs */.
bool has_beq(const std::string &name) const
Does a variable have a binding equation?
size_t add_variable_new(const MX &new_v)
[DEPRECATED] Use add
std::string display_unit(const std::string &name) const
void register_u(const std::string &name)
MX add(const std::string &name, const std::string &causality, const Dict &opts=Dict())
Add a new model variable, default variability.
void set_nominal(const std::string &name, double val)
Set the nominal value, single variable.
std::vector< casadi_int > dimension(const std::string &name) const
Get the dimensions of a variable.
MX pre(const MX &v) const
Get the pre-expression given variable expression.
void set_causality(const std::string &name, const std::string &val)
Set the causality, if permitted.
void prune(bool prune_p=true, bool prune_u=true)
Prune unused controls.
casadi_int nq() const
Quadrature states.
void add(const std::string &name, const std::string &causality, const std::string &variability, const MX &expr, const Dict &opts=Dict())
Add a new model variable, symbolic expression already available.
std::vector< std::string > z() const
Algebraic variables.
MX add_q(const std::string &name=std::string())
[DEPRECATED] Replaced by add
void set_attribute(const std::string &a, const std::vector< std::string > &name, const std::vector< double > &val)
Set an attribute.
MX add_y(const std::string &name, const MX &new_ydef)
[DEPRECATED] Replaced by add and eq
void set_variability(const std::string &name, const std::string &val)
Set the variability, if permitted.
MX add(const std::string &name, const std::string &causality, const std::string &variability, const Dict &opts=Dict())
Add a new model variable.
std::vector< MX > ode() const
Ordinary differential equations (ODE)
bool has_t() const
Is there a time variable?
void set_start_time(double val)
Set the start time.
DaeBuilder()
Default constructor.
void set(const std::string &name, double val)
std::vector< std::string > t_new() const
Independent variable (usually time)
void eliminate(const std::string &cat)
Eliminate all dependent parameters.
std::vector< std::string > initial_unknowns() const
Model structure: initial unknowns.
std::vector< MX > init_lhs() const
Initial conditions, left-hand-side.
void add_init(const MX &lhs, const MX &rhs)
[DEPRECATED] Replaced by set_init
casadi_int value_reference(const std::string &name) const
MX add_z(const std::string &name=std::string())
[DEPRECATED] Replaced by add
std::vector< MX > ydef() const
Definitions of output variables.
std::vector< std::string > p() const
Parameters.
Sparsity jac_sparsity(const std::vector< std::string > &onames, const std::vector< std::string > &inames) const
Get Jacobian sparsity.
casadi_int np() const
Parameters.
std::vector< std::string > pre(const std::vector< std::string > &name) const
Get the pre-variables of model variables.
std::vector< std::string > d() const
Dependent parameters.
void lift(bool lift_shared=true, bool lift_calls=true)
Lift problem formulation by extracting shared subexpressions.
void sort_w()
[DEPRECATED] Use sort("w")
MX var(const std::string &name) const
void register_y(const std::string &name)
MX add_x(const std::string &name=std::string())
[DEPRECATED] Replaced by add
void register_q(const std::string &name)
size_t add_variable_new(const std::string &name, casadi_int n=1)
[DEPRECATED] Use add
casadi_int ny() const
Output variables.
void set(const std::vector< std::string > &name, const std::vector< double > &val)
Set the current value.
std::vector< MX > zero() const
Zero-crossing functions.
void set_all(const std::string &v, const std::vector< std::string > &name)
[DEPRECATED] Use set_variability, set_causality, set_category and/or reorder
void register_t(const std::string &name)
std::vector< std::string > outputs() const
Model structure: outputs.
void load_fmi_description(const std::string &filename)
Import problem description from FMI or XML.
void register_x(const std::string &name)
std::vector< GenericType > get(const std::vector< std::string > &name) const
Evaluate the values for a set of variables at the initial time.
casadi_int numel(const std::string &name) const
Get the number of elements of a variable.
GenericType get(const std::string &name) const
Evaluate the values for a set of variables at the initial time, single value.
std::vector< std::string > w() const
Dependent variables.
std::vector< std::string > all_variables() const
Get a list of all variables.
std::vector< MX > ddef() const
Definitions of dependent parameters.
void register_p(const std::string &name)
casadi_int nw() const
Dependent variables.
std::vector< MX > init_rhs() const
Initial conditions, right-hand-side.
MX add_w(const std::string &name, const MX &new_wdef)
[DEPRECATED] Replaced by add and eq
void set_step_size(double val)
Set the step size.
void register_d(const std::string &name)
void add_variable(const MX &new_v)
Add a new variable from symbolic expressions.
casadi_int nzero() const
Zero-crossing functions.
std::string description(const std::string &name) const
void set_initial(const std::string &name, const std::string &val)
std::vector< std::string > u() const
Free controls.
void set_nominal(const std::vector< std::string > &name, const std::vector< double > &val)
Set the nominal value.
void eliminate_d()
[DEPRECATED] Use eliminate("d")
void set_start(const std::vector< std::string > &name, const std::vector< double > &val)
Set the start attribute.
std::vector< MX > quad() const
Quadrature equations.
MX beq(const std::string &name) const
Get the binding equation for a variable.
std::string type(const std::string &name, casadi_int fmi_version=3) const
MX add_d(const std::string &name, const MX &new_ddef)
[DEPRECATED] Replaced by add and eq
void set_description(const std::string &name, const std::string &val)
Generic data type, can hold different types such as bool, casadi_int, std::string etc.
std::string name() const
Get the name.
GenericShared implements a reference counting framework similar for efficient and.
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.
Holds expressions and meta-data corresponding to a physical quantity evolving in time.