From 13f45e61241e43d709df10228b946ed9870e8ebb Mon Sep 17 00:00:00 2001
From: Samo Penic <samo.penic@gmail.com>
Date: Tue, 23 Apr 2019 16:12:05 +0000
Subject: [PATCH] Fixing the vesicle 123 and neighbours just for a test

---
 src/main.c       |   19 +++++++++++++++++++
 src/general.h    |    1 +
 src/vertexmove.c |    1 +
 3 files changed, 21 insertions(+), 0 deletions(-)

diff --git a/src/general.h b/src/general.h
index c9cc537..098c159 100644
--- a/src/general.h
+++ b/src/general.h
@@ -158,6 +158,7 @@
         ts_double solAngle;
 		struct ts_poly *grafted_poly;
 		struct ts_cluster *cluster;
+	ts_uint fixed;
 };
 typedef struct ts_vertex ts_vertex;
 
diff --git a/src/main.c b/src/main.c
index 3f91f43..26be035 100644
--- a/src/main.c
+++ b/src/main.c
@@ -131,6 +131,25 @@
 //	exit(1);
 
 			//write_vertex_xml_file(vesicle,1000);
+
+
+	//fix some vertices on mesh. Don't allow them to move.
+
+	ts_uint i,j;
+	ts_vertex *vtx;
+       for(i=0;i<vesicle->vlist->n;i++){
+               if(vesicle->vlist->vtx[i]->idx==123){
+                       vtx=vesicle->vlist->vtx[i];
+                       vtx->fixed=1;
+                       for(j=0;j<vtx->neigh_no;j++){
+                               vtx->neigh[j]->fixed=1;
+                       }
+               }
+       }
+
+
+	
+
 	run_simulation(vesicle, tape->mcsweeps, tape->inititer, tape->iterations, start_iteration);
 	write_master_xml_file(command_line_args.output_fullfilename);
 	write_dout_fcompat_file(vesicle,"dout");
diff --git a/src/vertexmove.c b/src/vertexmove.c
index e74fa74..22ed597 100644
--- a/src/vertexmove.c
+++ b/src/vertexmove.c
@@ -24,6 +24,7 @@
     ts_double delta_energy, delta_energy_cv,oenergy,dvol=0.0, darea=0.0, dstretchenergy=0.0;
     ts_double costheta,sintheta,phi,r;
 	//This will hold all the information of vtx and its neighbours
+	if(vtx->fixed) return TS_FAIL;
 	ts_vertex backupvtx[20], *constvol_vtx_moved=NULL, *constvol_vtx_backup=NULL;
 	memcpy((void *)&backupvtx[0],(void *)vtx,sizeof(ts_vertex));
 

--
Gitblit v1.9.3