Robotran C Documentation
mbs_rk4.h
Go to the documentation of this file.
1 
17 #ifndef MBS_RK4_H_INCLUDED
18 #define MBS_RK4_H_INCLUDED
19 
20 #include "mbs_project_interface.h"
21 
25 typedef struct MbsDirdynRK4
26 {
27  double *yt;
28  double *dyt;
29  double *dym;
30 
31  int(*derivs)(double, double[], double[], MbsData *, MbsDirdyn *);
33  void (*loop_fct)(MbsData *, MbsDirdyn *);
35  int (*save_realtime_update)(MbsDirdyn* dd, MbsData* mbs_data);
36 } MbsDirdynRK4;
37 
45 void initialize_rk4(MbsData *mbs_data, MbsDirdyn *mbs_dd,
46  int(*derivs)(double, double[], double[], MbsData *, MbsDirdyn *),
47  void (*loop_fct)(MbsData *, MbsDirdyn *),
48  int (*save_realtime_update)(MbsDirdyn* dd, MbsData* mbs_data));
49 
59 int loop_rk4(double t0, double tf, MbsData *mbs_data, MbsDirdyn *mbs_dd);
60 
66 void finish_rk4(MbsData *mbs_data, MbsDirdyn *mbs_dd);
67 
75 void error_rk4(MbsData *mbs_data, MbsDirdyn *dd, int err);
76 
77 #endif // MBS_RK4_H_INCLUDED
loop_rk4
int loop_rk4(double t0, double tf, MbsData *mbs_data, MbsDirdyn *mbs_dd)
Integrate the motion from t0 to tf.
Definition: mbs_rk4.c:43
MbsDirdynOptions::flag_precise_dynamics
int flag_precise_dynamics
= 1 to call the direct dynamics at the beginning of each time step of integration.
Definition: mbs_dirdyn_struct.h:118
mbs_msg
void mbs_msg(const char *msg,...)
Send a message.
Definition: mbs_message.c:87
MbsData::tsim
double tsim
The time value.
Definition: mbs_data.h:305
MbsDirdyn::y
double * y
Pointer to the state vector, this is a dvec_0 of size nState.
Definition: mbs_dirdyn_struct.h:175
MbsDirdyn::nState
int nState
size of the state vector
Definition: mbs_dirdyn_struct.h:174
mbs_dirdyn_struct.h
get_dvec_0
double * get_dvec_0(int l_v)
create (with memory allocation) a vector (length l_v) of doubles, starting at index 0
Definition: mbs_1D_array.c:955
MbsDirdyn::yd
double * yd
Pointers to the derivative vector (dvec_0) of size nState.
Definition: mbs_dirdyn_struct.h:182
mbs_project_interface.h
Declaration of functions that are project dependent.
MbsDirdynRK4::dym
double * dym
allocated saved derivative vector
Definition: mbs_rk4.h:29
MbsDirdynRK4::dyt
double * dyt
allocated derivative vector
Definition: mbs_rk4.h:28
MbsDirdyn::yout
double * yout
Allocation of a vector (dvec_0) of size nState.
Definition: mbs_dirdyn_struct.h:177
MbsDirdynRK4::yt
double * yt
allocated state vector
Definition: mbs_rk4.h:27
mbs_1D_array.h
MbsDirdyn::integrator_struct
void * integrator_struct
pointer to store integrator structure
Definition: mbs_dirdyn_struct.h:205
rk4
int rk4(double y[], double dydx[], int n, double x, double h, double yout[], int(*derivs)(double, double[], double[], MbsData *, MbsDirdyn *), MbsData *s, MbsDirdyn *dd)
Runge Kutta 4 integrator implementation Given values for the variables y[1..n] and their derivatives ...
Definition: rk4.c:22
MbsDirdyn::tsim
double tsim
current simulation time
Definition: mbs_dirdyn_struct.h:171
MbsDirdynRK4::derivs
int(* derivs)(double, double[], double[], MbsData *, MbsDirdyn *)
The function computing the derivative of the system.
Definition: mbs_rk4.h:31
MbsDirdynRK4
Runge-Kutta 4 structure for dirdyn.
Definition: mbs_rk4.h:25
MbsDirdynRK4::save_realtime_update
int(* save_realtime_update)(MbsDirdyn *dd, MbsData *mbs_data)
Definition: mbs_rk4.h:35
save_realtime_update
int save_realtime_update(MbsDirdyn *dd, MbsData *mbs_data)
update the real-time and saving modules if requested
Definition: mbs_dirdyn.c:1252
mbs_message.h
MbsData
Definition: mbs_data.h:246
DIRDYN_INTEGRATOR_WAYPOINT_TIME_ERROR_max
#define DIRDYN_INTEGRATOR_WAYPOINT_TIME_ERROR_max
Definition: mbs_dirdyn_struct.h:32
finish_rk4
void finish_rk4(MbsData *mbs_data, MbsDirdyn *mbs_dd)
Finalize and clear memory allocated for RK4 integrator.
Definition: mbs_rk4.c:121
integrator.h
This header defines specific integrators functions in C.
MbsData::flag_stop
int flag_stop
stop the simulation. For dirdyn, equil, invdyn and solvekin only.
Definition: mbs_data.h:397
finish_rk4
void finish_rk4(MbsData *mbs_data, MbsDirdyn *dd)
Finalize and clear memory allocated for RK4 integrator.
Definition: mbs_rk4.c:121
MbsDirdynOptions::flag_solout_wp
int flag_solout_wp
1 to call solout only at required waypoints (only if flag_waypoint activated), default = 0
Definition: mbs_dirdyn_struct.h:128
MbsDirdyn
General structure of the direct dynamic module.
Definition: mbs_dirdyn_struct.h:166
initialize_rk4
void initialize_rk4(MbsData *mbs_data, MbsDirdyn *mbs_dd, int(*derivs)(double, double[], double[], MbsData *, MbsDirdyn *), void(*loop_fct)(MbsData *, MbsDirdyn *), int(*save_realtime_update)(MbsDirdyn *dd, MbsData *mbs_data))
Initialize all needed fields in MbsDirdyn for RK4 integrator.
Definition: mbs_rk4.c:24
MbsDirdyn::dt
double dt
current integration step size
Definition: mbs_dirdyn_struct.h:172
mbs_rk4.h
This header defines global functions for Runge Kutta 4 integrator in C.
error_rk4
void error_rk4(MbsData *mbs_data, MbsDirdyn *dd, int err)
If an error occurs during time integration, this function prints the error message and call finish_rk...
Definition: mbs_rk4.c:138
initialize_rk4
void initialize_rk4(MbsData *mbs_data, MbsDirdyn *mbs_dd, int(*derivs)(double, double[], double[], MbsData *, MbsDirdyn *), void(*loop_fct)(MbsData *, MbsDirdyn *), int(*save_realtime_update)(MbsDirdyn *dd, MbsData *mbs_data))
Initialize all needed fields in MbsDirdyn for RK4 integrator.
Definition: mbs_rk4.c:24
MbsDirdyn::options
MbsDirdynOptions * options
structure defining the option of a direct dynamic
Definition: mbs_dirdyn_struct.h:168
error_rk4
void error_rk4(MbsData *mbs_data, MbsDirdyn *dd, int err)
If an error occurs during time integration, this function prints the error message and call finish_rk...
Definition: mbs_rk4.c:138
MbsDirdynRK4::loop_fct
void(* loop_fct)(MbsData *, MbsDirdyn *)
The function to be called at the end of each time step, or waypoints.
Definition: mbs_rk4.h:33
loop_rk4
int loop_rk4(double t0, double tf, MbsData *mbs_data, MbsDirdyn *mbs_dd)
Integrate the motion from t0 to tf.
Definition: mbs_rk4.c:43