From 31f58ab61401061fa2e079d465ee8dd4fe1d8eed Mon Sep 17 00:00:00 2001 From: Derick M <58572875+TurtIeSocks@users.noreply.github.com> Date: Tue, 2 Jul 2024 21:44:01 -0400 Subject: [PATCH 1/2] feat: log worst clusters in stats --- server/algorithms/src/stats.rs | 26 +++++++++++++++++++++++--- 1 file changed, 23 insertions(+), 3 deletions(-) diff --git a/server/algorithms/src/stats.rs b/server/algorithms/src/stats.rs index 557f6afc..6ae86c7c 100644 --- a/server/algorithms/src/stats.rs +++ b/server/algorithms/src/stats.rs @@ -17,6 +17,8 @@ pub struct Stats { pub best_clusters: SingleVec, pub best_cluster_point_count: usize, + pub worst_cluster_point_count: usize, + pub worst_cluster_count: usize, pub cluster_time: Precision, pub route_time: Precision, pub stats_time: Precision, @@ -33,6 +35,8 @@ impl Stats { Self { best_clusters: vec![], best_cluster_point_count: 0, + worst_cluster_point_count: 0, + worst_cluster_count: 0, cluster_time: 0., route_time: 0., stats_time: 0., @@ -106,9 +110,11 @@ impl Stats { ), get_row( format!( - "|| [BEST_CLUSTER] Amount: {:?} | Point Count: {}", - self.best_clusters.len(), + "|| [COVERAGE] Best: {} ({}) | Worst: {} ({})", self.best_cluster_point_count, + self.best_clusters.len(), + self.worst_cluster_point_count, + self.worst_cluster_count, ), true ), @@ -200,7 +206,9 @@ impl Stats { let clusters: Vec> = cluster_info(&tree, &clusters); let mut points_covered: HashSet<&point::Point> = HashSet::new(); let mut best_clusters = SingleVec::new(); - let mut best = 0; + let mut best = usize::MIN; + let mut worst = usize::MAX; + let mut worst_count = 0; for cluster in clusters.iter() { if cluster.all.len() > best { @@ -210,13 +218,24 @@ impl Stats { } else if cluster.all.len() == best { best_clusters.push(cluster.point.center); } + if cluster.all.len() < worst { + worst = cluster.all.len(); + worst_count = 1; + } else if cluster.all.len() == worst { + worst_count += 1; + } if let Some(point) = tree.locate_at_point(&cluster.point.center) { points_covered.insert(point); } points_covered.extend(&cluster.all); } + if worst == usize::MAX { + worst = 0; + } self.best_cluster_point_count = best; + self.worst_cluster_point_count = worst; + self.worst_cluster_count = worst_count; self.best_clusters = best_clusters; self.points_covered = points_covered.len(); @@ -244,6 +263,7 @@ impl Serialize for Stats { let mut state = serializer.serialize_struct("Stats", 11)?; state.serialize_field("best_clusters", &self.best_clusters)?; state.serialize_field("best_cluster_point_count", &self.best_cluster_point_count)?; + state.serialize_field("worst_cluster_point_count", &self.worst_cluster_point_count)?; state.serialize_field("cluster_time", &self.cluster_time)?; state.serialize_field("route_time", &self.route_time)?; state.serialize_field("stats_time", &self.stats_time)?; From 4e1ccc370d9ceb0851b748cd508268b7e3fd6a2c Mon Sep 17 00:00:00 2001 From: Derick M <58572875+TurtIeSocks@users.noreply.github.com> Date: Tue, 2 Jul 2024 21:56:32 -0400 Subject: [PATCH 2/2] refactor: small cleanup --- server/algorithms/src/stats.rs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/server/algorithms/src/stats.rs b/server/algorithms/src/stats.rs index 6ae86c7c..4edeebee 100644 --- a/server/algorithms/src/stats.rs +++ b/server/algorithms/src/stats.rs @@ -211,17 +211,17 @@ impl Stats { let mut worst_count = 0; for cluster in clusters.iter() { - if cluster.all.len() > best { + let length = cluster.all.len(); + if length > best { best_clusters.clear(); - best = cluster.all.len(); + best = length; best_clusters.push(cluster.point.center); - } else if cluster.all.len() == best { + } else if length == best { best_clusters.push(cluster.point.center); - } - if cluster.all.len() < worst { - worst = cluster.all.len(); + } else if length < worst { + worst = length; worst_count = 1; - } else if cluster.all.len() == worst { + } else if length == worst { worst_count += 1; } if let Some(point) = tree.locate_at_point(&cluster.point.center) {