104 lines
4.1 KiB
C
104 lines
4.1 KiB
C
/*
|
|
* Copyright 2019 Gianluca Frison, Dimitris Kouzoupis, Robin Verschueren,
|
|
* Andrea Zanelli, Niels van Duijkeren, Jonathan Frey, Tommaso Sartor,
|
|
* Branimir Novoselnik, Rien Quirynen, Rezart Qelibari, Dang Doan,
|
|
* Jonas Koenemann, Yutao Chen, Tobias Schöls, Jonas Schlagenhauf, Moritz Diehl
|
|
*
|
|
* This file is part of acados.
|
|
*
|
|
* The 2-Clause BSD License
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
*
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.;
|
|
*/
|
|
|
|
#ifndef ACADOS_SIM_{{ model.name }}_H_
|
|
#define ACADOS_SIM_{{ model.name }}_H_
|
|
|
|
#include "acados_c/sim_interface.h"
|
|
#include "acados_c/external_function_interface.h"
|
|
|
|
#define {{ model.name | upper }}_NX {{ dims.nx }}
|
|
#define {{ model.name | upper }}_NZ {{ dims.nz }}
|
|
#define {{ model.name | upper }}_NU {{ dims.nu }}
|
|
#define {{ model.name | upper }}_NP {{ dims.np }}
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
|
|
// ** capsule for solver data **
|
|
typedef struct sim_solver_capsule
|
|
{
|
|
// acados objects
|
|
sim_in *acados_sim_in;
|
|
sim_out *acados_sim_out;
|
|
sim_solver *acados_sim_solver;
|
|
sim_opts *acados_sim_opts;
|
|
sim_config *acados_sim_config;
|
|
void *acados_sim_dims;
|
|
|
|
/* external functions */
|
|
// ERK
|
|
external_function_param_casadi * sim_forw_vde_casadi;
|
|
external_function_param_casadi * sim_expl_ode_fun_casadi;
|
|
external_function_param_casadi * sim_expl_ode_hess;
|
|
|
|
// IRK
|
|
external_function_param_casadi * sim_impl_dae_fun;
|
|
external_function_param_casadi * sim_impl_dae_fun_jac_x_xdot_z;
|
|
external_function_param_casadi * sim_impl_dae_jac_x_xdot_u_z;
|
|
external_function_param_casadi * sim_impl_dae_hess;
|
|
|
|
// GNSF
|
|
external_function_param_casadi * sim_gnsf_phi_fun;
|
|
external_function_param_casadi * sim_gnsf_phi_fun_jac_y;
|
|
external_function_param_casadi * sim_gnsf_phi_jac_y_uhat;
|
|
external_function_param_casadi * sim_gnsf_f_lo_jac_x1_x1dot_u_z;
|
|
external_function_param_casadi * sim_gnsf_get_matrices_fun;
|
|
|
|
} sim_solver_capsule;
|
|
|
|
|
|
int {{ model.name }}_acados_sim_create(sim_solver_capsule *capsule);
|
|
int {{ model.name }}_acados_sim_solve(sim_solver_capsule *capsule);
|
|
int {{ model.name }}_acados_sim_free(sim_solver_capsule *capsule);
|
|
int {{ model.name }}_acados_sim_update_params(sim_solver_capsule *capsule, double *value, int np);
|
|
|
|
sim_config * {{ model.name }}_acados_get_sim_config(sim_solver_capsule *capsule);
|
|
sim_in * {{ model.name }}_acados_get_sim_in(sim_solver_capsule *capsule);
|
|
sim_out * {{ model.name }}_acados_get_sim_out(sim_solver_capsule *capsule);
|
|
void * {{ model.name }}_acados_get_sim_dims(sim_solver_capsule *capsule);
|
|
sim_opts * {{ model.name }}_acados_get_sim_opts(sim_solver_capsule *capsule);
|
|
sim_solver * {{ model.name }}_acados_get_sim_solver(sim_solver_capsule *capsule);
|
|
|
|
|
|
sim_solver_capsule * {{ model.name }}_acados_sim_solver_create_capsule(void);
|
|
int {{ model.name }}_acados_sim_solver_free_capsule(sim_solver_capsule *capsule);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif // ACADOS_SIM_{{ model.name }}_H_
|