From 23d807748be58e5178c04304d9cc788bf122eb12 Mon Sep 17 00:00:00 2001 From: Samo Penic <samo.penic@fe.uni-lj.si> Date: Tue, 11 Feb 2014 15:34:18 +0000 Subject: [PATCH] Make changes in memory allocation. Memory reservation is done, but pointers are not linked into corresponding structure. A lot to be done still. However, check how pointers can be recalculated at any time when the block is copied in memory. --- src/general.h | 108 +++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 75 insertions(+), 33 deletions(-) diff --git a/src/general.h b/src/general.h index ca778bf..afd238b 100644 --- a/src/general.h +++ b/src/general.h @@ -2,6 +2,7 @@ #define _GENERAL_H #include<stdarg.h> +#include<stdio.h> /* @brief This is a header file, defining general constants and structures. * @file header.h @@ -109,12 +110,29 @@ /* 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. */ @@ -133,12 +151,9 @@ 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; @@ -148,18 +163,13 @@ } ts_vertex_list; - -/** ts_bond_data is a structure that describes a bond */ -typedef struct { +struct ts_bond { + ts_uint idx; ts_vertex *vtx1; ts_vertex *vtx2; ts_double bond_length; ts_double bond_length_dual; -} ts_bond_data; - -struct ts_bond { - ts_uint idx; - ts_bond_data *data; + ts_bool tainted; }; typedef struct ts_bond ts_bond; @@ -169,22 +179,16 @@ }; typedef struct ts_bond_list ts_bond_list; -/** ts_triangle_data is a structure that describes a triangle */ -struct ts_triangle_data { - ts_uint idx; +struct ts_triangle { + ts_uint idx; ts_vertex *vertex[3]; ts_uint neigh_no; struct ts_triangle **neigh; ts_double xnorm; ts_double ynorm; ts_double znorm; - -}; -typedef struct ts_triangle_data ts_triangle_data; - -struct ts_triangle { - ts_uint idx; - ts_triangle_data *data; + ts_double area; // firstly needed for sh.c + ts_double volume; // firstly needed for sh.c }; typedef struct ts_triangle ts_triangle; @@ -194,14 +198,11 @@ }; typedef struct ts_triangle_list ts_triangle_list; -typedef struct ts_cell_data { - ts_vertex **vertex; - ts_uint nvertex; -} ts_cell_data; typedef struct ts_cell { ts_uint idx; - ts_cell_data *data; + ts_vertex **vertex; + ts_uint nvertex; } ts_cell; typedef struct ts_cell_list{ @@ -215,6 +216,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; @@ -224,12 +236,42 @@ ts_double dmax; ts_double stepsize; ts_double cm[3]; + ts_double volume; + ts_spharm *sphHarmonics; } ts_vesicle; +typedef struct { + ts_uint vertex_no; + ts_uint ncmax[3]; + ts_vesicle *vesicle; + ts_vertex_list *vlist; + ts_bond_list *blist; + ts_triangle_list *tlist; + ts_cell_list *clist; + ts_vertex **vtx_ptr; + ts_vertex *vtx; + ts_vertex *vtx_neighbours; + ts_vertex **vtx_neighbours_ptr; + ts_bond **vtx_neighbond; + ts_triangle **tristar; + ts_triangle **tria_ptr; + ts_triangle *tria; + ts_triangle **trianeigh; + ts_bond **bond_ptr; + ts_bond *bond; + ts_cell **cell_ptr; + ts_cell *cell; + ts_vertex **cell_ocupancy; + /* ts_spharm *sphHarmonics; */ +} ts_memory; /* GLOBAL VARIABLES */ int quiet; + + +/* ERROR CODES */ +#define TS_ERR_MEM_ALLOC 1 /* FUNCTIONS */ @@ -247,7 +289,7 @@ */ void fatal(char *text, ts_int errcode); -//ts_uint ts_fprintf(FILE *fd, char *fmt, va_list ap); +ts_uint ts_fprintf(FILE *fd, char *fmt, ...); #define VTX(n) &(vlist->vtx[n]) #define VTX_DATA(n) vlist->vtx[n].data -- Gitblit v1.9.3