From 88bdd70987e76a58ea0fd917f63aa0c682848116 Mon Sep 17 00:00:00 2001
From: Samo Penic <samo.penic@gmail.com>
Date: Sun, 09 Dec 2018 21:47:36 +0000
Subject: [PATCH] testing confinement (preliminary)

---
 src/timestep.c   |   13 +++++++++++--
 src/io.c         |    4 ++--
 src/vertexmove.c |    8 ++++++++
 3 files changed, 21 insertions(+), 4 deletions(-)

diff --git a/src/io.c b/src/io.c
index 669a4b0..d5157be 100644
--- a/src/io.c
+++ b/src/io.c
@@ -1195,8 +1195,8 @@
     cfg = cfg_init(opts, 0);
     retval=cfg_parse_buf(cfg, buffer);
 	tape->plane_confinement_switch=cfg_getint(cfg,"plane_confinement_switch");
-	tape->plane_d=cfg_getint(cfg,"plane_d");
-	tape->plane_F=cfg_getint(cfg,"plane_F");
+	tape->plane_d=cfg_getfloat(cfg,"plane_d");
+	tape->plane_F=cfg_getfloat(cfg,"plane_F");
 
     if(retval==CFG_FILE_ERROR){
 	fatal("No tape file.",100);
diff --git a/src/timestep.c b/src/timestep.c
index 27400e7..d8440d0 100644
--- a/src/timestep.c
+++ b/src/timestep.c
@@ -62,7 +62,7 @@
 	centermass(vesicle);
 	cell_occupation(vesicle);
 	vesicle_volume(vesicle); //needed for constant volume at this moment
-    vesicle_area(vesicle); //needed for constant area at this moment
+	vesicle_area(vesicle); //needed for constant area at this moment
 	if(V0<0.000001) 
 		V0=vesicle->volume; 
 	ts_fprintf(stdout,"Setting volume V0=%.17f\n",V0);
@@ -70,7 +70,16 @@
 		A0=vesicle->area;
 	ts_fprintf(stdout,"Setting area A0=%.17f\n",A0);
 	epsvol=4.0*sqrt(2.0*M_PI)/pow(3.0,3.0/4.0)*V0/pow(vesicle->tlist->n,3.0/2.0);
-    epsarea=A0/(ts_double)vesicle->tlist->n;
+	epsarea=A0/(ts_double)vesicle->tlist->n;
+
+	//plane confinement part 1
+
+	if(vesicle->tape->plane_confinement_switch){
+		vesicle->confinement_plane.z_min=-vesicle->tape->plane_d/2.0;
+		vesicle->confinement_plane.z_max=vesicle->tape->plane_d/2.0;
+		ts_fprintf(stderr,"Vesicle confinement by plane set to (zmin, zmax)=(%e,%e).\n",vesicle->confinement_plane.z_min,vesicle->confinement_plane.z_max);
+	}
+	
   //  fprintf(stderr, "DVol=%1.16f (%1.16f), V0=%1.16f\n", epsvol,0.003e-2*V0,V0);
 	if(start_iteration<inititer) ts_fprintf(stdout, "Starting simulation (first %d x %d MC sweeps will not be recorded on disk)\n", inititer, mcsweeps);
 	for(i=start_iteration;i<inititer+iterations;i++){
diff --git a/src/vertexmove.c b/src/vertexmove.c
index 2517f69..a3244b2 100644
--- a/src/vertexmove.c
+++ b/src/vertexmove.c
@@ -88,6 +88,14 @@
 	}
 
 }
+
+	// plane confinement check whether the new position of vertex will be out of bounds
+	if(vesicle->tape->plane_confinement_switch){
+		if(vtx->z>vesicle->confinement_plane.z_max || vtx->z<vesicle->confinement_plane.z_min){
+		vtx=memcpy((void *)vtx,(void *)&backupvtx[0],sizeof(ts_vertex));
+		return TS_FAIL;
+		}
+	}
 //#undef SQ
 //self avoidance check with distant vertices
 	cellidx=vertex_self_avoidance(vesicle, vtx);

--
Gitblit v1.9.3