From 83a885e1f9d767441ff7a67d90eb43495e7d55dd Mon Sep 17 00:00:00 2001 From: "Harutaka Obara(Matsumoto)" Date: Thu, 28 Nov 2024 17:11:43 +0900 Subject: [PATCH 1/4] Refactored tests --- Measure_test.go | 454 +++++++++++++++++++++--------------------------- 1 file changed, 194 insertions(+), 260 deletions(-) diff --git a/Measure_test.go b/Measure_test.go index bb64e37..9a10340 100644 --- a/Measure_test.go +++ b/Measure_test.go @@ -11,99 +11,63 @@ import ( ) func TestMeasureNonnegativeDistance(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {0.0, 5.5, 0.0}, - {2.3, 1.0, -2.0}, - {8.1, 4.0, 2.4}, - {4.3, 5.0, 2.2}, - {2.5, 1.0, 2.3}, - {7.1, 1.0, 2.4}, - {1.0, 1.5, 0.3}, - {3.3, 0.5, 0.3}, - {6.0, 1.4, 0.2}, - } - - convexHull1 := []*mgl64.Vec3{ - {0.0, -5.5, 0.0}, - {-4.0, 1.0, 5.0}, - } - - correctDistance := 5.233333333333333 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureNonnegativeDistance( + t, + 5.233333333333333, + []*mgl64.Vec3{ + {0.0, 5.5, 0.0}, + {2.3, 1.0, -2.0}, + {8.1, 4.0, 2.4}, + {4.3, 5.0, 2.2}, + {2.5, 1.0, 2.3}, + {7.1, 1.0, 2.4}, + {1.0, 1.5, 0.3}, + {3.3, 0.5, 0.3}, + {6.0, 1.4, 0.2}, }, - } - - measure.MeasureNonnegativeDistance() - - if measure.Distance != correctDistance { - t.Error("The distance:", measure.Distance, "is different from the correct distance:", correctDistance) - } + []*mgl64.Vec3{ + {0.0, -5.5, 0.0}, + {-4.0, 1.0, 5.0}, + }, + ) } func TestMeasureNonnegativeDistance_Degeneration(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {10, 10, 10}, - {93.76614808098593, 10, 10}, - } - - convexHull1 := []*mgl64.Vec3{ - {26.902334690093994, 7.686383247375488, 12}, - {30.745525360107422, 7.686383247375488, 12}, - {30.745525360107422, 11.529574871063232, 12}, - {26.902334690093994, 11.529574871063232, 12}, - {26.902334690093994, 7.686383247375488, 13}, - {30.745525360107422, 7.686383247375488, 13}, - {30.745525360107422, 11.529574871063232, 13}, - {26.902334690093994, 11.529574871063232, 13}, - } - - correctDistance := 2.0 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureNonnegativeDistance( + t, + 2.0, + []*mgl64.Vec3{ + {10, 10, 10}, + {93.76614808098593, 10, 10}, }, - } - - measure.MeasureNonnegativeDistance() - - if measure.Distance != correctDistance { - t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) - } + []*mgl64.Vec3{ + {26.902334690093994, 7.686383247375488, 12}, + {30.745525360107422, 7.686383247375488, 12}, + {30.745525360107422, 11.529574871063232, 12}, + {26.902334690093994, 11.529574871063232, 12}, + {26.902334690093994, 7.686383247375488, 13}, + {30.745525360107422, 7.686383247375488, 13}, + {30.745525360107422, 11.529574871063232, 13}, + {26.902334690093994, 11.529574871063232, 13}, + }, + ) } func TestMeasureNonnegativeDistance_OutOfTetrahedron(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {24.80916023254391, -436.06686488070386, 1}, - {24.809160232543945, 149.8855333328247, 1}, - } - - convexHull1 := []*mgl64.Vec3{ - {503.46153831481934, 0, 0}, - {503.46153831481934, 299.7710666656494, 0}, - {503.46153831481934, 299.7710666656494, 2}, - {503.46153831481934, 0, 2}, - } - - correctDistance := 478.65237808227545 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureNonnegativeDistance( + t, + 478.65237808227545, + []*mgl64.Vec3{ + {24.80916023254391, -436.06686488070386, 1}, + {24.809160232543945, 149.8855333328247, 1}, }, - } - - measure.MeasureNonnegativeDistance() - - if measure.Distance != correctDistance { - t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) - } + []*mgl64.Vec3{ + {503.46153831481934, 0, 0}, + {503.46153831481934, 299.7710666656494, 0}, + {503.46153831481934, 299.7710666656494, 2}, + {503.46153831481934, 0, 2}, + }, + ) } func TestMeasureNonnegativeDistance_InOfTetrahedron(t *testing.T) { @@ -111,71 +75,68 @@ func TestMeasureNonnegativeDistance_InOfTetrahedron(t *testing.T) { t.Skip("TODO: Make this test succeed.") } - convexHull0 := []*mgl64.Vec3{ - {9.809160232543945, 74.8855333328247, 1}, - {499.80916023254395, 74.8855333328247, 1}, - } - - convexHull1 := []*mgl64.Vec3{ - {103.76688194274902, 73.02115726470947, 1}, - {103.76688194274902, 73.02115726470947, 2}, - {103.76688194274902, 76.86437606811523, 2}, - {103.76688194274902, 76.86437606811523, 1}, - } - - correctDistance := 0.0 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureNonnegativeDistance( + t, + 0.0, + []*mgl64.Vec3{ + {9.809160232543945, 74.8855333328247, 1}, + {499.80916023254395, 74.8855333328247, 1}, }, - } - - measure.MeasureNonnegativeDistance() - - if measure.Distance != correctDistance { - t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) - } + []*mgl64.Vec3{ + {103.76688194274902, 73.02115726470947, 1}, + {103.76688194274902, 73.02115726470947, 2}, + {103.76688194274902, 76.86437606811523, 2}, + {103.76688194274902, 76.86437606811523, 1}, + }, + ) } func TestMeasureNonnegativeDistance_MinError(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - { - 231.13410161715001, - 42.359085964038968, - 8.2070553228259087, - }, - { - 231.13428923673928, - 42.360740889096633, - 8.3670506989583373, - }, - } - - convexHull1 := []*mgl64.Vec3{ - { - 1126.8901406135462, - 506.76397722481852, - -991.48334605572745, - }, - { - -694.78953127471266, - -318.69762289359494, - -991.48334605572745, - }, - { - -694.78953127471266, - -318.69762289359494, - 1008.5166539442725, + testMeasureNonnegativeDistance( + t, + 53.29158003236736, + []*mgl64.Vec3{ + { + 231.13410161715001, + 42.359085964038968, + 8.2070553228259087, + }, + { + 231.13428923673928, + 42.360740889096633, + 8.3670506989583373, + }, }, - { - 1126.8901406135462, - 506.76397722481852, - 1008.5166539442725, + []*mgl64.Vec3{ + { + 1126.8901406135462, + 506.76397722481852, + -991.48334605572745, + }, + { + -694.78953127471266, + -318.69762289359494, + -991.48334605572745, + }, + { + -694.78953127471266, + -318.69762289359494, + 1008.5166539442725, + }, + { + 1126.8901406135462, + 506.76397722481852, + 1008.5166539442725, + }, }, - } + ) +} +func testMeasureNonnegativeDistance( + t *testing.T, + correctDistance float64, + convexHull0, convexHull1 []*mgl64.Vec3, + ) { measure := Measure{ ConvexHulls: [2][]*mgl64.Vec3{ convexHull0, @@ -183,84 +144,61 @@ func TestMeasureNonnegativeDistance_MinError(t *testing.T) { }, } + start := time.Now() measure.MeasureNonnegativeDistance() - - if measure.Distance != 53.29158003236736 { - t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", 53.291580) + t.Log("Time: ", time.Since(start)) + if measure.Distance != correctDistance { + t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) } } func TestMeasureDistance(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {0.0, 5.5, 0.0}, - {2.3, 1.0, -2.0}, - {8.1, 4.0, 2.4}, - {4.3, 5.0, 2.2}, - {2.5, 1.0, 2.3}, - {7.1, 1.0, 2.4}, - {1.0, 1.5, 0.3}, - {3.3, 0.5, 0.3}, - {6.0, 1.4, 0.2}, - } - - convexHull1 := []*mgl64.Vec3{ - {5.0, 6.0, -1.0}, - {-4.0, 1.0, 5.0}, - } - - correctDistance := -0.8135953914471573 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureDistance( + t, + -0.8135953914471573, + []*mgl64.Vec3{ + {0.0, 5.5, 0.0}, + {2.3, 1.0, -2.0}, + {8.1, 4.0, 2.4}, + {4.3, 5.0, 2.2}, + {2.5, 1.0, 2.3}, + {7.1, 1.0, 2.4}, + {1.0, 1.5, 0.3}, + {3.3, 0.5, 0.3}, + {6.0, 1.4, 0.2}, }, - } - - measure.MeasureDistance() - - if measure.Distance != correctDistance { - t.Error("The distance:", measure.Distance, "is different from the correct distance:", correctDistance) - } + []*mgl64.Vec3{ + {5.0, 6.0, -1.0}, + {-4.0, 1.0, 5.0}, + }, + ) } func TestMeasureDistance_Geodetic(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {136.243592, 36.294155, 0}, - {136.243591519521, 36.3058526069559, 0.132705141790211}, - {136.249286077761, 36.3058526238534, 0.153129168786108}, - {136.2492857044, 36.2941550169325, 0.0204240279272199}, - {136.243592, 36.294155, 99.9999999990687}, - {136.249285614983, 36.2941550169343, 100.020423707552}, - {136.249285988325, 36.3058524401501, 100.153126765043}, - {136.243591519529, 36.3058524232507, 100.13270305749}, - } - - convexHull1 := []*mgl64.Vec3{ - {136.24420166015625, 36.29409768373033, 12}, - {136.24420166015625, 36.29423604083452, 12}, - {136.2443733215332, 36.29423604083452, 12}, - {136.2443733215332, 36.29409768373033, 12}, - {136.24420166015625, 36.29409768373033, 28}, - {136.2443733215332, 36.29409768373033, 28}, - {136.2443733215332, 36.29423604083452, 28}, - {136.24420166015625, 36.29423604083452, 28}, - } - - correctDistance := -8.103902144849304e-05 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureDistance( + t, + -8.103902144849304e-05, + []*mgl64.Vec3{ + {136.243592, 36.294155, 0}, + {136.243591519521, 36.3058526069559, 0.132705141790211}, + {136.249286077761, 36.3058526238534, 0.153129168786108}, + {136.2492857044, 36.2941550169325, 0.0204240279272199}, + {136.243592, 36.294155, 99.9999999990687}, + {136.249285614983, 36.2941550169343, 100.020423707552}, + {136.249285988325, 36.3058524401501, 100.153126765043}, + {136.243591519529, 36.3058524232507, 100.13270305749}, }, - } - - measure.MeasureDistance() - - if measure.Distance != correctDistance { - t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) - } + []*mgl64.Vec3{ + {136.24420166015625, 36.29409768373033, 12}, + {136.24420166015625, 36.29423604083452, 12}, + {136.2443733215332, 36.29423604083452, 12}, + {136.2443733215332, 36.29409768373033, 12}, + {136.24420166015625, 36.29409768373033, 28}, + {136.2443733215332, 36.29409768373033, 28}, + {136.2443733215332, 36.29423604083452, 28}, + {136.24420166015625, 36.29423604083452, 28}, + }, + ) } func TestMeasureDistance_Geodetic2(t *testing.T) { @@ -268,69 +206,65 @@ func TestMeasureDistance_Geodetic2(t *testing.T) { t.Skip("TODO: Make this test succeed.") } - convexHull0 := []*mgl64.Vec3{ - {136.2436866760254, 36.293959326380744, 12}, - {136.24385833740234, 36.293959326380744, 12}, - {136.24385833740234, 36.29409768373033, 12}, - {136.2436866760254, 36.29409768373033, 12}, - {136.2436866760254, 36.293959326380744, 28}, - {136.24385833740234, 36.293959326380744, 28}, - {136.24385833740234, 36.29409768373033, 28}, - {136.2436866760254, 36.29409768373033, 28}, - } - - convexHull1 := []*mgl64.Vec3{ - {136.243592, 36.29415500000001, 0}, - {136.2493088026763, 36.29415500000001, 0}, - {136.2493088026763, 36.30588827924294, 0}, - {136.243592, 36.30588827924294, 0}, - {136.243592, 36.29415500000001, 100.15410614013672}, - {136.2493088026763, 36.29415500000001, 100.15410614013672}, - {136.2493088026763, 36.30588827924294, 100.15410614013672}, - {136.243592, 36.30588827924294, 100.15410614013672}, - } - - correctDistance := 5.7316269682416994e-05 - - measure := Measure{ - ConvexHulls: [2][]*mgl64.Vec3{ - convexHull0, - convexHull1, + testMeasureDistance( + t, + 5.7316269682416994e-05, + []*mgl64.Vec3{ + {136.2436866760254, 36.293959326380744, 12}, + {136.24385833740234, 36.293959326380744, 12}, + {136.24385833740234, 36.29409768373033, 12}, + {136.2436866760254, 36.29409768373033, 12}, + {136.2436866760254, 36.293959326380744, 28}, + {136.24385833740234, 36.293959326380744, 28}, + {136.24385833740234, 36.29409768373033, 28}, + {136.2436866760254, 36.29409768373033, 28}, }, - } - - measure.MeasureDistance() - - if measure.Distance != correctDistance { - t.Error("The distance:", measure.Distance, "is different from the correct distance:", correctDistance) - } + []*mgl64.Vec3{ + {136.243592, 36.29415500000001, 0}, + {136.2493088026763, 36.29415500000001, 0}, + {136.2493088026763, 36.30588827924294, 0}, + {136.243592, 36.30588827924294, 0}, + {136.243592, 36.29415500000001, 100.15410614013672}, + {136.2493088026763, 36.29415500000001, 100.15410614013672}, + {136.2493088026763, 36.30588827924294, 100.15410614013672}, + {136.243592, 36.30588827924294, 100.15410614013672}, + }, + ) } func TestMeasureDistance_DistanceNaN(t *testing.T) { - convexHull0 := []*mgl64.Vec3{ - {0.8594475607808709, 0.9742341196245268, 0.03881845158332072}, - {0.11518805721821658, 0.2886100593167679, 0.7264075543605955}, - } - - convexHull1 := []*mgl64.Vec3{ - {0.1808976766933622, 0.4678535876991557, 0.39595195969136837}, - {0.9318649386849539, -0.061164616366541524, 0.12579316768712678}, - {0.3326005890627055, 0.053609576287277694, 0.7200526359540806}, - {0.147048080416384, 0.1043118025314802, 0.11557811629097817}, - {0.5917329252351495, 0.5148435176841939, 0.7696251459508143}, - } - - correctDistance := 0.0 + testMeasureDistance( + t, + 0.0, + []*mgl64.Vec3{ + {0.8594475607808709, 0.9742341196245268, 0.03881845158332072}, + {0.11518805721821658, 0.2886100593167679, 0.7264075543605955}, + }, + []*mgl64.Vec3{ + {0.1808976766933622, 0.4678535876991557, 0.39595195969136837}, + {0.9318649386849539, -0.061164616366541524, 0.12579316768712678}, + {0.3326005890627055, 0.053609576287277694, 0.7200526359540806}, + {0.147048080416384, 0.1043118025314802, 0.11557811629097817}, + {0.5917329252351495, 0.5148435176841939, 0.7696251459508143}, + }, + ) +} +func testMeasureDistance( + t *testing.T, + correctDistance float64, + convexHull0, convexHull1 []*mgl64.Vec3, + ) { measure := Measure{ ConvexHulls: [2][]*mgl64.Vec3{ convexHull0, convexHull1, }, - Direction: mgl64.Vec3{-0.09838696251414104, 0.19117353980163715, 0.08413127327169329}, } + start := time.Now() measure.MeasureDistance() + t.Log("Time: ", time.Since(start)) if measure.Distance != correctDistance { t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) From f2b5d55a3698c0cde6ed64e12bc3b1def2657c59 Mon Sep 17 00:00:00 2001 From: "Harutaka Obara(Matsumoto)" Date: Thu, 28 Nov 2024 17:18:25 +0900 Subject: [PATCH 2/4] Reverted TestMeasureDistance_DistanceNaN(_) --- Measure_test.go | 41 +++++++++++++++++++++++++++-------------- 1 file changed, 27 insertions(+), 14 deletions(-) diff --git a/Measure_test.go b/Measure_test.go index 9a10340..507a8d4 100644 --- a/Measure_test.go +++ b/Measure_test.go @@ -233,21 +233,34 @@ func TestMeasureDistance_Geodetic2(t *testing.T) { } func TestMeasureDistance_DistanceNaN(t *testing.T) { - testMeasureDistance( - t, - 0.0, - []*mgl64.Vec3{ - {0.8594475607808709, 0.9742341196245268, 0.03881845158332072}, - {0.11518805721821658, 0.2886100593167679, 0.7264075543605955}, - }, - []*mgl64.Vec3{ - {0.1808976766933622, 0.4678535876991557, 0.39595195969136837}, - {0.9318649386849539, -0.061164616366541524, 0.12579316768712678}, - {0.3326005890627055, 0.053609576287277694, 0.7200526359540806}, - {0.147048080416384, 0.1043118025314802, 0.11557811629097817}, - {0.5917329252351495, 0.5148435176841939, 0.7696251459508143}, + convexHull0 := []*mgl64.Vec3{ + {0.8594475607808709, 0.9742341196245268, 0.03881845158332072}, + {0.11518805721821658, 0.2886100593167679, 0.7264075543605955}, + } + + convexHull1 := []*mgl64.Vec3{ + {0.1808976766933622, 0.4678535876991557, 0.39595195969136837}, + {0.9318649386849539, -0.061164616366541524, 0.12579316768712678}, + {0.3326005890627055, 0.053609576287277694, 0.7200526359540806}, + {0.147048080416384, 0.1043118025314802, 0.11557811629097817}, + {0.5917329252351495, 0.5148435176841939, 0.7696251459508143}, + } + + correctDistance := 0.0 + + measure := Measure{ + ConvexHulls: [2][]*mgl64.Vec3{ + convexHull0, + convexHull1, }, - ) + Direction: mgl64.Vec3{-0.09838696251414104, 0.19117353980163715, 0.08413127327169329}, + } + + measure.MeasureDistance() + + if measure.Distance != correctDistance { + t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) + } } func testMeasureDistance( From 4e1185ff14f6c4361a826bf93f62e85880a8a742 Mon Sep 17 00:00:00 2001 From: "Harutaka Obara(Matsumoto)" Date: Thu, 28 Nov 2024 17:22:15 +0900 Subject: [PATCH 3/4] Appended logging time to TestMeasureDistance_DistanceNaN(_) --- Measure_test.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Measure_test.go b/Measure_test.go index 507a8d4..0216d1b 100644 --- a/Measure_test.go +++ b/Measure_test.go @@ -256,7 +256,9 @@ func TestMeasureDistance_DistanceNaN(t *testing.T) { Direction: mgl64.Vec3{-0.09838696251414104, 0.19117353980163715, 0.08413127327169329}, } + start := time.Now() measure.MeasureDistance() + t.Log("Time: ", time.Since(start)) if measure.Distance != correctDistance { t.Error("The distance: ", measure.Distance, " is different from the correct distance: ", correctDistance) From 037a830ff91f41410de999197b5e108741e2aae1 Mon Sep 17 00:00:00 2001 From: "Harutaka Obara(Matsumoto)" Date: Thu, 28 Nov 2024 17:42:29 +0900 Subject: [PATCH 4/4] Moved main.yml --- {workflows => .github/workflows}/main.yml | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename {workflows => .github/workflows}/main.yml (100%) diff --git a/workflows/main.yml b/.github/workflows/main.yml similarity index 100% rename from workflows/main.yml rename to .github/workflows/main.yml