From 64c113ed06cb749fdc513162a1cddf4ec024fd72 Mon Sep 17 00:00:00 2001 From: Samo Penic <samo.penic@gmail.com> Date: Sat, 30 Nov 2013 10:10:13 +0000 Subject: [PATCH] Changes in data structure, added vertex_list_remove_vtx and vertex_list_add_vtx. Trying to fix the rest --- src/general.h | 61 ++++++++++++++++++++++++------ 1 files changed, 48 insertions(+), 13 deletions(-) diff --git a/src/general.h b/src/general.h index 6d2ab06..cc051f5 100644 --- a/src/general.h +++ b/src/general.h @@ -110,17 +110,35 @@ /* STRUCTURES */ + +/** @brief Data structure for keeping the coordinates in selected coordinate + * system + */ +#define TS_COORD_CARTESIAN 0 +#define TS_COORD_SPHERICAL 1 +#define TS_COORD_CYLINDRICAL 2 + +typedef struct { + ts_double e1; + ts_double e2; + ts_double e3; + ts_uint coord_type; +} ts_coord; + + + /** @brief Data structure of all data connected to a vertex * - * ts_vertex_data holds the data for one single point (bead, vertex). To understand how to use it + * ts_vertex holds the data for one single point (bead, vertex). To understand how to use it * here is a detailed description of the fields in the data structure. */ -struct ts_vertex_data { - ts_uint idx; /**< Represents index of the vertex point. Should become obsolete, since it is also present in ts_vertex structure. */ +struct ts_vertex { + ts_uint idx; ts_double x; /**< The x coordinate of vertex. */ ts_double y; /**< The y coordinate of vertex. */ ts_double z; /**< The z coordinate of vertex. */ - ts_uint neigh_no; /**< The number of neighbours. */ - struct ts_vertex **neigh; /**< The pointer that holds neigh_no pointers to this structure. */ +// ts_uint neigh_no; /**< The number of neighbours. */ +// struct ts_vertex **neigh; /**< The pointer that holds neigh_no pointers to this structure. */ + struct ts_vertex_list *neigh; ts_double *bond_length; /**< Obsolete! The bond lenght is moved to ts_bond */ ts_double *bond_length_dual; /**< Obsolete! Bond length in dual lattice is moved to ts_bond! */ ts_double curvature; @@ -134,20 +152,19 @@ ts_double xk; ts_double c; ts_uint id; -}; -typedef struct ts_vertex_data ts_vertex_data; - -struct ts_vertex { - ts_uint idx; - ts_vertex_data *data; + ts_double projArea; + ts_double relR; + ts_double solAngle; }; typedef struct ts_vertex ts_vertex; -typedef struct { +struct ts_vertex_list{ ts_uint n; + ts_uint list_size; ts_vertex **vtx; -} ts_vertex_list; +}; +typedef struct ts_vertex_list ts_vertex_list; struct ts_bond { ts_uint idx; @@ -155,6 +172,7 @@ ts_vertex *vtx2; ts_double bond_length; ts_double bond_length_dual; + ts_bool tainted; }; typedef struct ts_bond ts_bond; @@ -172,6 +190,8 @@ ts_double xnorm; ts_double ynorm; ts_double znorm; + ts_double area; // firstly needed for sh.c + ts_double volume; // firstly needed for sh.c }; typedef struct ts_triangle ts_triangle; @@ -199,6 +219,17 @@ typedef struct { + ts_uint l; + ts_double **ulm; + ts_double **sumUlm2; + ts_uint N; + ts_double **co; + ts_double ***Ylmi; +} ts_spharm; + + + +typedef struct { ts_vertex_list *vlist; ts_bond_list *blist; ts_triangle_list *tlist; @@ -208,9 +239,13 @@ ts_double dmax; ts_double stepsize; ts_double cm[3]; + ts_double volume; + ts_spharm *sphHarmonics; } ts_vesicle; + + /* GLOBAL VARIABLES */ int quiet; -- Gitblit v1.9.3