From 51b4f09bca802c4941700c78c5733ce968ddc7c6 Mon Sep 17 00:00:00 2001 From: Samo Penic <samo.penic@gmail.com> Date: Wed, 27 Feb 2019 22:44:22 +0000 Subject: [PATCH] An attempt of adding hard constraints plugin to the simulator. It seems it does not work yet --- src/general.h | 48 ++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 46 insertions(+), 2 deletions(-) diff --git a/src/general.h b/src/general.h index 9a8feab..d7c1ec7 100644 --- a/src/general.h +++ b/src/general.h @@ -201,6 +201,7 @@ struct ts_triangle_list{ ts_uint n; + ts_double a0; ts_triangle **tria; }; typedef struct ts_triangle_list ts_triangle_list; @@ -251,6 +252,11 @@ typedef struct ts_poly_list ts_poly_list; +typedef struct{ + ts_float z_max; + ts_float z_min; + ts_int force_switch; +} ts_confinement_plane; typedef struct { long int nshell; @@ -292,9 +298,45 @@ ts_double c0; ts_double w; ts_double F; + long int plane_confinement_switch; + ts_double plane_d; + ts_double plane_F; } ts_tape; +/* plugins */ +typedef struct { + void (*at_start)(int argc, char **argv); + void *(*after_vesicle_init)(void *vesicle); + ts_bool (*vm_hard_constraint)(void *vesicle, ts_vertex *vtx, ts_vertex *odl_vtx); + ts_double (*vm_energy_before_prepare)(void *vesicle, ts_vertex *vtx); + ts_double (*vm_energy_before_execute)(void *vesicle, ts_vertex *vtx); + ts_double (*vm_energy_after_prepare)(void *vesicle, ts_vertex *vtx); + ts_double (*vm_energy_after_execute)(void *vesicle, ts_vertex *vtx); + ts_double (*vm_new_state_accepted)(void *vesicle, ts_vertex *vtx); + ts_double (*vm_new_state_rejected)(void *vesicle, ts_vertex *vtx); + void (*cleanup)(void); +} ts_plugin_function; + +typedef struct { + ts_char *name; + ts_char *description; + ts_char *author; +} ts_plugin_details; + +typedef struct { + ts_plugin_details *details; + ts_plugin_function *function; + ts_char *filename; + void *libhandle; +} ts_plugin; + +typedef struct { + ts_uint n; + ts_plugin **plugin; +} ts_plugin_list; + +/* end plugins */ typedef struct { @@ -317,13 +359,15 @@ ts_double spring_constant; ts_double pressure; ts_int pswitch; - ts_tape *tape; + ts_tape *tape; ts_double R_nucleus; ts_double R_nucleusX; ts_double R_nucleusY; ts_double R_nucleusZ; ts_double nucleus_center[3]; - ts_double area; + ts_double area; + ts_confinement_plane confinement_plane; + ts_plugin_list *plist; } ts_vesicle; -- Gitblit v1.9.3