forked from stepjam/PyRep
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_octrees.py
43 lines (36 loc) · 1.53 KB
/
test_octrees.py
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
import unittest
from pyrep.const import ObjectType
from tests.core import TestCore
from pyrep.objects.object import Object
from pyrep.objects.shape import Shape
from pyrep.objects.octree import Octree
class TestOctrees(TestCore):
def setUp(self):
super().setUp()
self.octree = Octree.create(0.025)
self.shape = Shape('Panda_link0_visual')
def test_octree_insert_and_remove_voxels(self):
point = [0.0, 0.0, 0.0]
self.octree.insert_voxels(point)
voxels = self.octree.get_voxels()
# As many as 8 voxels may be added from a single point insertion.
self.assertTrue(1 <= len(voxels)//3 and len(voxels)/3 <= 8)
self.assertTrue(self.octree.check_point_occupancy(point))
self.octree.remove_voxels(point)
voxels = self.octree.get_voxels()
self.assertTrue(len(voxels)//3 is 0)
self.assertFalse(self.octree.check_point_occupancy(point))
def test_octree_insert_and_subtract_object(self):
self.octree.insert_object(self.shape)
voxels = self.octree.get_voxels()
self.assertTrue(1 <= len(voxels)//3)
self.octree.subtract_object(self.shape)
voxels = self.octree.get_voxels()
self.assertTrue(len(voxels)//3 is 0)
def test_octree_insert_and_clear(self):
self.octree.insert_object(self.shape)
voxels = self.octree.get_voxels()
self.assertTrue(1 <= len(voxels)//3)
self.octree.clear_voxels()
voxels = self.octree.get_voxels()
self.assertTrue(len(voxels)//3 is 0)