From 38ed8080d35e61c2b3695c37d4a0bbe84c5722dd Mon Sep 17 00:00:00 2001
From: Samo Penic <samo.penic@gmail.com>
Date: Sun, 03 Jul 2016 18:37:04 +0000
Subject: [PATCH] Difference in energy still persists.

---
 src/initial_distribution.c |   26 +++++++++++++++++++-------
 1 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/src/initial_distribution.c b/src/initial_distribution.c
index 0f04e5f..dbdd0c4 100644
--- a/src/initial_distribution.c
+++ b/src/initial_distribution.c
@@ -44,6 +44,7 @@
 	vesicle=initial_distribution_dipyramid(tape->nshell,tape->ncxmax,tape->ncymax,tape->nczmax,tape->stepsize);
     	vesicle->tape=tape;
 	set_vesicle_values_from_tape(vesicle);
+		initial_population_with_c0(vesicle,tape);
 	return vesicle;
 }
 
@@ -111,11 +112,27 @@
         vesicle->sphHarmonics=NULL;
     }
 
-	int rndvtx;
+    
+    return TS_SUCCESS;
+
+}
+
+
+ts_bool initial_population_with_c0(ts_vesicle *vesicle, ts_tape *tape){
+	int rndvtx,i,j;
 	if(tape->number_of_vertices_with_c0>0){
 		ts_fprintf(stderr,"Setting values for spontaneous curvature as defined in tape\n");
+		j=0;
 		for(i=0;i<tape->number_of_vertices_with_c0;i++){
 			rndvtx=rand() % vesicle->vlist->n;
+			if(fabs(vesicle->vlist->vtx[rndvtx]->c-tape->c0)<1e-15){
+				j++;
+				i--;
+				if(j>10*vesicle->vlist->n){
+					fatal("cannot populate vesicle with vertices with spontaneous curvature. Too many spontaneous curvature vertices?",100);
+				}
+				continue;
+			}
 			vesicle->vlist->vtx[rndvtx]->c=tape->c0;
 		}
 		mean_curvature_and_energy(vesicle);
@@ -124,13 +141,8 @@
 			sweep_attraction_bond_energy(vesicle);
 		}
 	}
-    
-    return TS_SUCCESS;
-
+	return TS_SUCCESS;
 }
-
-
-
 
 
 ts_bool pentagonal_dipyramid_vertex_distribution(ts_vertex_list *vlist){

--
Gitblit v1.9.3