[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [58853] branches/ soc-2013-meshdata_transfer/source/blender/bmesh/tools/bmesh_data_transfer.c : Shapekey transfer through projection: fixing the memory leaks and applying the same optimization found in Vertex colors and Vertex weights transfer

Walid Shouman eng.walidshouman at gmail.com
Sat Aug 3 13:03:52 CEST 2013


Revision: 58853
          http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=58853
Author:   walid
Date:     2013-08-03 11:03:52 +0000 (Sat, 03 Aug 2013)
Log Message:
-----------
Shapekey transfer through projection: fixing the memory leaks and applying the same optimization found in Vertex colors and Vertex weights transfer

Modified Paths:
--------------
    branches/soc-2013-meshdata_transfer/source/blender/bmesh/tools/bmesh_data_transfer.c

Modified: branches/soc-2013-meshdata_transfer/source/blender/bmesh/tools/bmesh_data_transfer.c
===================================================================
--- branches/soc-2013-meshdata_transfer/source/blender/bmesh/tools/bmesh_data_transfer.c	2013-08-03 10:41:36 UTC (rev 58852)
+++ branches/soc-2013-meshdata_transfer/source/blender/bmesh/tools/bmesh_data_transfer.c	2013-08-03 11:03:52 UTC (rev 58853)
@@ -1836,6 +1836,8 @@
 	float (*v_co_list_dst)[3], (*v_co_list_src)[3];
 	float f_mid_dst[3], f_mid_src[3];
 	coord_pool *offsets_grp;				//stores all the gathered offsets/vert to be averaged at the end of interpolation
+	const int exp_vert_per_face = 10;
+	int v_src_max_count, v_dst_max_count;
 	//====algorithm definitions end
 
 	int CD_offset_src, CD_offset_dst;
@@ -1873,8 +1875,8 @@
 	//get the faces tree
 	bmtree_src = BKE_bmbvh_new(em_src, 0, NULL, false);
 
-	v_co_list_dst = MEM_mallocN(sizeof(*v_co_list_dst), "v_co_list_dst bmesh_data_transfer.c");
-	v_co_list_src = MEM_mallocN(sizeof(*v_co_list_src), "v_co_list bmesh_data_transfer.c");
+	v_co_list_dst = MEM_mallocN(sizeof(*v_co_list_dst) * exp_vert_per_face, "v_co_list_dst bmesh_data_transfer.c");
+	v_co_list_src = MEM_mallocN(sizeof(*v_co_list_src) * exp_vert_per_face, "v_co_list_src bmesh_data_transfer.c");
 
 	offsets_grp = MEM_mallocN(sizeof(*offsets_grp) * bm_dst->totvert, "offsets_grp bmesh_data_transfer.c");
 	BM_ITER_MESH (v, &iter, bm_dst, BM_VERTS_OF_MESH) {
@@ -1886,6 +1888,7 @@
 		offsets_grp[v->head.index].count = 0;	//if that wasn't fast enf we may use calloc for the offsets_grp
 	}
 
+	tmp_weight = MEM_mallocN(sizeof(*tmp_weight) * exp_vert_per_face, "tmp_weight bmesh_data_transfer.c");
 	if (replace_mode == ST_APPEND_SHAPEKEY_GROUPS) {
 		//add 1 to skip the basis
 		src_lay_start = 1;
@@ -1922,7 +1925,13 @@
 			//get a coordinate list of the f_dst verts
 			//used to get the the f_mid_dst for mid_poly_v3
 			BM_ITER_ELEM_INDEX (v, &fiter, f_dst, BM_VERTS_OF_FACE, v_dst_count) {
-				v_co_list_dst = MEM_reallocN(v_co_list_dst, sizeof(*v_co_list_dst) * (v_dst_count + 1));
+				if (v_dst_count > exp_vert_per_face) {
+					if (v_dst_count > v_dst_max_count) {
+						v_co_list_dst = MEM_reallocN(v_co_list_dst, sizeof(*v_co_list_dst) * (v_dst_count + 1));
+						v_dst_max_count = v_dst_count;
+					}
+				}
+
 				copy_v3_v3(v_co_list_dst[v_dst_count], v->co);
 			}
 
@@ -1940,14 +1949,26 @@
 
 			//get a coordinate list of the f verts
 			BM_ITER_ELEM_INDEX (v2, &fiter, f_src, BM_VERTS_OF_FACE, v_src_count) {
-				v_co_list_src = MEM_reallocN(v_co_list_src, sizeof(*v_co_list_src) * (v_src_count + 1));
+				//reallocate if the verts/faces were more than expected
+				if (v_src_count > exp_vert_per_face) {
+					//and according to the previous records only allocate if that more than max already allocated
+					if (v_src_count > v_src_max_count) {
+						v_co_list_src = MEM_reallocN(v_co_list_src, sizeof(*v_co_list_src) * (v_src_count + 1));
+
+						// Prepare memory for later interpolation
+						tmp_weight = MEM_reallocN(tmp_weight, sizeof(*tmp_weight) * v_src_count);
+
+						v_src_max_count = v_src_count;
+					}
+				}
+
 				copy_v3_v3(v_co_list_src[v_src_count], v2->co);
 			}
+
 			zero_v3(f_mid_src);
 			mid_poly_v3(f_mid_src, v_co_list_src, v_src_count);	//get the mid point of the source face
 
 			BM_ITER_ELEM (v, &fiter, f_dst, BM_VERTS_OF_FACE) {
-				float tmp[3] = {0, 0, 0};
 				zero_v3(tmp_co);
 				// Transform into target space.
 				mul_v3_m4v3(tmp_co, tmp_mat, v->co);
@@ -1957,8 +1978,6 @@
 				//project_v3_plane(tmp_co, f->no, f->l_first->v->co);//not sure, do we really have to use an actual vertex ?
 
 				// Interpolate weights over face.
-				//check that v_count will equal to n not n-1!!
-				tmp_weight = MEM_mallocN(sizeof(*tmp_weight) * v_src_count, "tmp_weight bmesh_data_transfer.c");
 
 				//spatially finding the weights from the face's vertices
 				interp_weights_poly_v3(tmp_weight, v_co_list_src, v_src_count, tmp_co);
@@ -1973,18 +1992,14 @@
 				}
 
 				copy_v3_v3(offsets_grp[v->head.index].coord[offsets_grp[v->head.index].count], v_dst_offset);
-				copy_v3_v3(tmp, v_dst_offset);
-				copy_v3_v3(tmp, offsets_grp[v->head.index].coord[offsets_grp[v->head.index].count]);
 				(offsets_grp[v->head.index].count)++;
 
 				//shall we verify the indices!?
 				//we interpolate vertix weights instead
 			}
-
 		}
 
 		BM_ITER_MESH (v, &iter, bm_dst, BM_VERTS_OF_MESH) {
-			///should be prepended with a copy_v3_v3
 			zero_v3(v_dst_offset);
 			mid_poly_v3(v_dst_offset, offsets_grp[v->head.index].coord, offsets_grp[v->head.index].count);
 
@@ -1995,6 +2010,15 @@
 
 	}
 
+	BM_ITER_MESH (v, &iter, bm_dst, BM_VERTS_OF_MESH) {
+		MEM_freeN(offsets_grp[v->head.index].coord);
+	}
+
+	MEM_freeN(offsets_grp);
+
+	MEM_freeN(v_co_list_dst);
+	MEM_freeN(v_co_list_src);
+	MEM_freeN(tmp_weight);
 	return true;
 }
 




More information about the Bf-blender-cvs mailing list