From a806304afafa9b9c8c3da8d02812d8351ac5830f Mon Sep 17 00:00:00 2001 From: Yaraslau <44506630+Yaraslaut@users.noreply.github.com> Date: Fri, 26 Aug 2022 05:44:11 +0100 Subject: [PATCH 1/3] Increase precision in centroid calculation --- utils/geom.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/utils/geom.c b/utils/geom.c index edbaca9..1724dfa 100644 --- a/utils/geom.c +++ b/utils/geom.c @@ -2589,8 +2589,8 @@ void init_prism(geometric_object *o) { vector3 centroid = {0.0, 0.0, 0.0}; int nv; for (nv = 0; nv < num_vertices; nv++) - centroid = vector3_plus(centroid, vertices[nv]); - prsm->centroid = centroid = vector3_scale(1.0 / ((double)num_vertices), centroid); + centroid = vector3_plus(centroid, vector3_scale(1.0 / (double)num_vertices, vertices[nv])); + prsm->centroid = centroid; // make sure all vertices lie in a plane, i.e. that the normal // vectors to all triangles (v_n, v_{n+1}, centroid) agree. From 91459baf0486476671cedb3b7ec43ef0ebdb148d Mon Sep 17 00:00:00 2001 From: Yaraslau <44506630+Yaraslaut@users.noreply.github.com> Date: Mon, 29 Aug 2022 08:58:23 +0300 Subject: [PATCH 2/3] Added unit test to cover bug --- utils/test-prism.c | 38 +++++++++++++++++++++++++++++++++++++- 1 file changed, 37 insertions(+), 1 deletion(-) diff --git a/utils/test-prism.c b/utils/test-prism.c index cb29c7e..4364522 100644 --- a/utils/test-prism.c +++ b/utils/test-prism.c @@ -1085,6 +1085,41 @@ int test_helper_functions_on_octagonal_c_prism() { return num_failed_normal + num_failed_tapered; } +/************************************************************************/ +/* 8th unit test: */ +/* Prism initialization test from issue #61 */ +/* https://github.com/NanoComp/libctl/issues/61 */ +/************************************************************************/ +int test_init_prism_from_issues() { + geometric_object *m = NULL; + + int num_nodes = 11; + vector3 nodes_prism[num_nodes]; + nodes_prism[0] = make_vector3(1.0, 0.0, -0.15); + nodes_prism[1] = make_vector3(1.0, 1.0, -0.15); + nodes_prism[2] = make_vector3(-1.0, 1.0, -0.15); + nodes_prism[3] = make_vector3(-1.0, -1.0, -0.15); + nodes_prism[4] = make_vector3(1.0, -1.0, -0.15); + nodes_prism[5] = make_vector3(1.0, 0.0, -0.15); + nodes_prism[6] = make_vector3(2.0, 0.0, -0.15); + nodes_prism[7] = make_vector3(2.0, -2.0, -0.15); + nodes_prism[8] = make_vector3(-2.0, -2.0, -0.15); + nodes_prism[9] = make_vector3(-2.0, 2.0, -0.15); + nodes_prism[10] = make_vector3(2.0, 2.0, -0.15); + nodes_prism[11] = make_vector3(2.0, 0.0, -0.15); + + double height_prism = 0.3; + vector3 zhat = make_vector3(0, 0, 1); + + double normal_sidewall = 0; + geometric_object prism_geom_obj = make_prism(m, nodes_prism, num_nodes, height_prism, zhat); + prism *prism_obj = prism_geom_obj.subclass.prism_data; + + if(prism_obj) return 0; + return 1; + +} + /***************************************************************/ /* unit tests: create the same parallelepiped two ways (as a */ /* block and as a prism) and verify that geometric primitives */ @@ -1148,8 +1183,9 @@ int run_unit_tests() { int num_failed_5 = test_square_base_sidewall_prisms_to_gnuplot(); int num_failed_6 = test_octagon_c_base_sidewall_prisms_to_gnuplot(); int num_failed_7 = test_helper_functions_on_octagonal_c_prism(); + int num_failed_8 = test_init_prism_from_issues(); - return num_failed_1 + num_failed_3 + num_failed_4 + num_failed_5 + num_failed_6 + num_failed_7; + return num_failed_1 + num_failed_3 + num_failed_4 + num_failed_5 + num_failed_6 + num_failed_7 + num_failed_8; } /***************************************************************/ From 4d726ceddb5e4db44137fd88a36cba198d59fc09 Mon Sep 17 00:00:00 2001 From: Yaraslau <44506630+Yaraslaut@users.noreply.github.com> Date: Mon, 29 Aug 2022 13:48:48 +0100 Subject: [PATCH 3/3] fix typo --- utils/test-prism.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utils/test-prism.c b/utils/test-prism.c index 4364522..0913b94 100644 --- a/utils/test-prism.c +++ b/utils/test-prism.c @@ -1091,7 +1091,7 @@ int test_helper_functions_on_octagonal_c_prism() { /* https://github.com/NanoComp/libctl/issues/61 */ /************************************************************************/ int test_init_prism_from_issues() { - geometric_object *m = NULL; + void *m = NULL; int num_nodes = 11; vector3 nodes_prism[num_nodes];