gaphas/tests/test_quadtree.py
2019-12-28 22:07:58 -05:00

90 lines
3.0 KiB
Python

import pytest
from gaphas.geometry import Rectangle
from gaphas.quadtree import Quadtree
@pytest.fixture()
def qtree():
qtree = Quadtree((0, 0, 100, 100))
for i in range(0, 100, 10):
for j in range(0, 100, 10):
qtree.add(item=f"{i:d}x{j:d}", bounds=Rectangle(i, j, 10, 10))
return qtree
def test_lookups(qtree):
for i in range(100, 10):
for j in range(100, 10):
assert qtree.find_intersect(rect=(i + 1, j + 1, 1, 1)) == [
f"{i:d}x{j:d}"
], qtree.find_intersect(rect=(i + 1, j + 1, 1, 1))
def test_with_rectangles(qtree):
assert len(qtree._ids) == 100, len(qtree._ids)
for i in range(100, 10):
for j in range(100, 10):
assert qtree.find_intersect(rect=(i + 1, j + 1, 1, 1)) == [
f"{i:d}x{j:d}"
], qtree.find_intersect(rect=(i + 1, j + 1, 1, 1))
def test_moving_items(qtree):
qtree.capacity = 10
assert len(qtree._ids) == 100, len(qtree._ids)
assert qtree._bucket._buckets, qtree._bucket._buckets
for i in range(4):
assert qtree._bucket._buckets[i]._buckets
for j in range(4):
assert not qtree._bucket._buckets[i]._buckets[j]._buckets
# Check contents:
# First sub-level contains 9 items. second level contains 4 items
# ==> 4 * (9 + (4 * 4)) = 100
assert len(qtree._bucket.items) == 0, qtree._bucket.items
for i in range(4):
assert len(qtree._bucket._buckets[i].items) == 9
for item, bounds in qtree._bucket._buckets[i].items.items():
assert qtree._bucket.find_bucket(bounds) is qtree._bucket._buckets[i]
for j in range(4):
assert len(qtree._bucket._buckets[i]._buckets[j].items) == 4
assert qtree.get_bounds("0x0")
# Now move item '0x0' to the center of the first quadrant (20, 20)
qtree.add("0x0", (20, 20, 10, 10))
assert len(qtree._bucket.items) == 0
assert len(qtree._bucket._buckets[0]._buckets[0].items) == 3, (
qtree._bucket._buckets[0]._buckets[0].items
)
assert len(qtree._bucket._buckets[0].items) == 10, qtree._bucket._buckets[0].items
# Now move item '0x0' to the second quadrant (70, 20)
qtree.add("0x0", (70, 20, 10, 10))
assert len(qtree._bucket.items) == 0
assert len(qtree._bucket._buckets[0]._buckets[0].items) == 3, (
qtree._bucket._buckets[0]._buckets[0].items
)
assert len(qtree._bucket._buckets[0].items) == 9, qtree._bucket._buckets[0].items
assert len(qtree._bucket._buckets[1].items) == 10, qtree._bucket._buckets[1].items
def test_get_data(qtree):
"""Test extra data added to a node.
"""
for i in range(0, 100, 10):
for j in range(0, 100, 10):
qtree.add(item=f"{i:d}x{j:d}", bounds=(i, j, 10, 10), data=i + j)
for i in range(0, 100, 10):
for j in range(0, 100, 10):
assert i + j == qtree.get_data(item=f"{i:d}x{j:d}")
def test_clipped_bounds(qtree):
qtree.capacity = 10
qtree.add(item=1, bounds=(-100, -100, 120, 120))
assert (0, 0, 20, 20) == qtree.get_clipped_bounds(item=1)