generated from habedi/template-rust-project
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_octree.rs
68 lines (62 loc) · 1.97 KB
/
test_octree.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
use spart::octree::Octree;
mod utils;
use tracing::{debug, info};
use utils::*;
#[test]
fn test_octree_3d() {
info!("Starting test_octree_3d");
let boundary = BOUNDARY_CUBE;
let mut tree = Octree::new(&boundary, CAPACITY);
info!("Created octree with boundary: {:?}", boundary);
let points = common_points_3d();
for pt in &points {
tree.insert(pt.clone());
debug!("Inserted 3D point: {:?}", pt);
}
info!("Finished inserting {} points", points.len());
let target = target_point_3d();
info!("Performing 3D kNN search for target: {:?}", target);
let knn_results = tree.knn_search(&target, KNN_COUNT);
info!("3D kNN search returned {} results", knn_results.len());
assert_eq!(
knn_results.len(),
KNN_COUNT,
"Expected {} nearest neighbors in 3D, got {}",
KNN_COUNT,
knn_results.len()
);
let mut prev_dist = 0.0;
for pt in &knn_results {
let d = distance_3d(&target, pt);
debug!("3D kNN: Point {:?} at distance {}", pt, d);
assert!(
d >= prev_dist,
"3D kNN results not sorted by increasing distance"
);
prev_dist = d;
}
let range_query = range_query_point_3d();
info!(
"Performing 3D range search for query point {:?} with radius {}",
range_query, RADIUS
);
let range_results = tree.range_search(&range_query, RADIUS);
info!("3D range search returned {} points", range_results.len());
for pt in &range_results {
let d = distance_3d(&range_query, pt);
debug!("3D Range: Point {:?} at distance {}", pt, d);
assert!(
d <= RADIUS,
"Point {:?} is at distance {} exceeding radius {}",
pt,
d,
RADIUS
);
}
assert!(
range_results.len() >= 5,
"Expected at least 5 points in 3D range search, got {}",
range_results.len()
);
info!("test_octree_3d completed successfully");
}