Skip to content

Commit

Permalink
Improve command to merge paths
Browse files Browse the repository at this point in the history
  • Loading branch information
Chatewgne committed Jul 25, 2023
1 parent 6019375 commit 320f462
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 32 deletions.
34 changes: 15 additions & 19 deletions geotrek/core/management/commands/merge_segmented_paths.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ def extract_neighbourgs_graph(self, number_of_neighbourgs, extremities=[]):

def try_merge(self, a, b):
if {a, b} in self.discarded:
print(f"├ Already discarded {a} and {b}")
self.stdout.write(f"├ Already discarded {a} and {b}")
return False
success = 2
try:
Expand All @@ -42,24 +42,20 @@ def try_merge(self, a, b):
with transaction.atomic():
success = patha.merge_path(pathb)
except Exception:
print(f"├ Cannot merge {a} and {b}")
self.stdout.write(f"├ Cannot merge {a} and {b}")
self.discarded.append({a, b})
return False
if success == 2:
print(f"├ Cannot merge {a} and {b}")
self.discarded.append({a, b})
return False
elif success == 0:
print(f"├ No matching points to merge paths {a} and {b} found")
if success == 2 or success == 0:
self.stdout.write(f"├ Cannot merge {a} and {b}")
self.discarded.append({a, b})
return False
else:
print(f"├ Merged {b} into {a}")
self.stdout.write(f"├ Merged {b} into {a}")
sleep(self.sleeptime)
return True

def merge_paths_with_one_neighbour(self):
print("┌ STEP 1")
self.stdout.write("┌ STEP 1")
neighbours_graph = self.extract_neighbourgs_graph(1)
successes = 0
fails = 0
Expand All @@ -75,7 +71,7 @@ def merge_paths_with_one_neighbour(self):
return successes

def merge_paths_with_two_neighbours(self):
print("┌ STEP 2")
self.stdout.write("┌ STEP 2")
successes = 0
neighbours_graph = self.extract_neighbourgs_graph(2)
mergeables = list(neighbours_graph.keys())
Expand All @@ -94,7 +90,7 @@ def merge_paths_with_two_neighbours(self):
return successes

def merge_paths_with_three_neighbours(self):
print("┌ STEP 3")
self.stdout.write("┌ STEP 3")
successes = 0
neighbours_graph = self.extract_neighbourgs_graph(3)
mergeables = list(neighbours_graph.keys())
Expand All @@ -120,21 +116,21 @@ def handle(self, *args, **options):
self.discarded = []
paths_before = Path.include_invisible.count()

print("\n")
print(datetime.now())
self.stdout.write("\n")
self.stdout.write(str(datetime.now()))

first_step_successes = self.merge_paths_with_one_neighbour()
print(f"└ {first_step_successes} merges")
self.stdout.write(f"└ {first_step_successes} merges")
total_successes += first_step_successes

second_step_successes = self.merge_paths_with_two_neighbours()
print(f"└ {second_step_successes} merges")
self.stdout.write(f"└ {second_step_successes} merges")
total_successes += second_step_successes

third_step_successes = self.merge_paths_with_three_neighbours()
print(f"└ {third_step_successes} merges")
self.stdout.write(f"└ {third_step_successes} merges")
total_successes += third_step_successes

paths_after = Path.include_invisible.count()
print(f"\n--- RAN {total_successes} MERGES - FROM {paths_before} TO {paths_after} PATHS ---\n")
print(datetime.now())
self.stdout.write(f"\n--- RAN {total_successes} MERGES - FROM {paths_before} TO {paths_after} PATHS ---\n")
self.stdout.write(str(datetime.now()))
61 changes: 48 additions & 13 deletions geotrek/core/tests/test_commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -661,6 +661,8 @@ def setUpTestData(cls):
cls.p14 = Path.objects.create(geom=geom_14)
geom_15 = LineString((5, 3), (4, 1))
cls.p15 = Path.objects.create(geom=geom_15)
geom_16 = LineString((7, 5), (8, 5), (8, 6), (7, 6), (7, 5))
cls.p16 = Path.objects.create(geom=geom_16)

@override_settings(PATH_SNAPPING_DISTANCE=0, PATH_MERGE_SNAPPING_DISTANCE=0)
def test_find_and_merge_paths(self):
Expand All @@ -670,16 +672,16 @@ def test_find_and_merge_paths(self):
# | |
# | p4 | p13
# | |
# + +
# |
# | p10
# p11 |
# +------+------+ p15
# + +-------
# | | |
# | p10 | p16 |
# p11 | | |
# +------+------+ p15 --------
# |
# | p12
# |
# +
self.assertEqual(Path.objects.count(), 15)
self.assertEqual(Path.objects.count(), 16)
output = StringIO()
call_command('merge_segmented_paths', stdout=output)
# After call
Expand All @@ -688,13 +690,46 @@ def test_find_and_merge_paths(self):
# | |
# | p4 | p13
# | |
# + +
# |
# | p10
# p11 |
# +------+------+ p15
# + +-------
# | | |
# | p10 | p16 |
# p11 | | |
# +------+------+ p15 --------
# |
# | p12
# |
# +
self.assertEqual(Path.objects.count(), 9)
#
output_str = ("┌ STEP 1\n"
"├ Merged 2 into 1\n"
"├ Merged 9 into 14\n"
"├ Cannot merge 16 and 13\n"
"├ Merged 8 into 14\n"
"├ Already discarded 16 and 13\n"
"└ 3 merges\n"
"┌ STEP 2\n"
"├ Cannot merge 1 and 3\n"
"├ Merged 3 into 5\n"
"├ Merged 5 into 6\n"
"├ Cannot merge 14 and 7\n"
"└ 2 merges\n"
"┌ STEP 3\n"
"├ Cannot merge 6 and 1\n"
"├ Cannot merge 6 and 4\n"
"├ Merged 7 into 6\n"
"├ Cannot merge 7 and 6\n"
"├ Cannot merge 7 and 13\n"
"├ Already discarded 7 and 14\n"
"├ Cannot merge 10 and 4\n"
"├ Cannot merge 10 and 11\n"
"├ Cannot merge 10 and 15\n"
"├ Cannot merge 12 and 4\n"
"├ Cannot merge 12 and 11\n"
"├ Cannot merge 12 and 15\n"
"├ Already discarded 13 and 7\n"
"├ Cannot merge 13 and 14\n"
"├ Already discarded 13 and 16\n"
"└ 1 merges\n"
"\n"
"--- RAN 6 MERGES - FROM 16 TO 10 PATHS ---\n")
self.assertEqual(Path.objects.count(), 10)
self.assertIn(output_str, output.getvalue())

0 comments on commit 320f462

Please sign in to comment.