-
Notifications
You must be signed in to change notification settings - Fork 6
/
test_tower_planner.py
108 lines (87 loc) · 4.03 KB
/
test_tower_planner.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
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
"""
Copyright 2020 Massachusetts Insititute of Technology
Izzy Brand
"""
import pytest
from tower_planner import TowerPlanner
from block_utils import *
from agents.teleport_agent import TeleportAgent
@pytest.fixture()
def vis(pytestconfig):
return pytestconfig.getoption("vis")
def tower_is_stable_in_pybullet(tower, vis=False, T=200):
init_poses = {block.name: block.pose for block in tower}
final_poses = TeleportAgent.simulate_tower(tower, vis=vis, T=T)
return pos_unchanged(init_poses, final_poses, eps=1e-2)
def test_stability_pair_is_stable():
tp = TowerPlanner()
a = Object.random('a')
b = Object.random('b')
# center the COM of the top object over the bottom object
stable_a_pos = Position(-a.com.x,
-a.com.y,
a.dimensions.z/2 + b.dimensions.z)
a.pose = Pose(stable_a_pos, ZERO_ROT)
assert tp.pair_is_stable(b, a)
# center the COM of the top object on the positive x edge of the bottom
# object, and then move it a tiny bit farther
unstable_a_pos = Position(b.dimensions.x/2 - a.com.x + 1e-5,
-a.com.y,
a.dimensions.z/2 + b.dimensions.z)
a.pose = Pose(unstable_a_pos, ZERO_ROT)
assert not tp.pair_is_stable(b, a)
def test_stability_tower_is_stable():
tp = TowerPlanner()
obj_a = Object('a', Dimensions(0.1,0.1,0.1), 1, Position(0,0,0), Color(0,1,1))
obj_b = Object('b', Dimensions(0.3,0.1,0.1), 3, Position(0,0,0), Color(1,0,1))
obj_c = Object('c', Dimensions(0.1,0.1,0.2), 2, Position(0,0,0), Color(1,1,0))
# the single block is stable
obj_a.pose = Pose(Position(0, 0, 0.05), ZERO_ROT)
assert tp.tower_is_stable([obj_a])
# this is stable
obj_b.pose = Pose(Position(0, 0, 0.15), ZERO_ROT)
assert tp.tower_is_stable([obj_a, obj_b])
# this is unstable
obj_b.pose = Pose(Position(0.06, 0, 0.15), ZERO_ROT)
assert not tp.tower_is_stable([obj_a, obj_b])
# it becomes stable when we add another block
obj_c.pose = Pose(Position(0.0, 0, 0.3), ZERO_ROT)
assert tp.tower_is_stable([obj_a, obj_b, obj_c])
# this tower is constructible, but not stable
obj_b.pose = Pose(Position(0, 0.04, 0.15), ZERO_ROT)
obj_c.pose = Pose(Position(0, 0.08, 0.3), ZERO_ROT)
assert not tp.tower_is_stable([obj_a, obj_b, obj_c])
def test_stability_tower_is_constructible():
tp = TowerPlanner()
obj_a = Object('a', Dimensions(0.1,0.1,0.1), 1, Position(0,0,0), Color(0,1,1))
obj_b = Object('b', Dimensions(0.3,0.1,0.1), 3, Position(0,0,0), Color(1,0,1))
obj_c = Object('c', Dimensions(0.1,0.1,0.2), 2, Position(0,0,0), Color(1,1,0))
# the single block is constructible
obj_a.pose = Pose(Position(0, 0, 0.05), ZERO_ROT)
assert tp.tower_is_constructible([obj_a])
# this is constructible
obj_b.pose = Pose(Position(0, 0, 0.15), ZERO_ROT)
assert tp.tower_is_constructible([obj_a, obj_b])
# this is unconstructible
obj_b.pose = Pose(Position(0.06, 0, 0.15), ZERO_ROT)
assert not tp.tower_is_constructible([obj_a, obj_b])
# it becomes stable, but remains unconstructible when we add another block
obj_c.pose = Pose(Position(0.0, 0, 0.3), ZERO_ROT)
assert not tp.tower_is_constructible([obj_a, obj_b, obj_c])
# this tower is constructible, but not stable
obj_b.pose = Pose(Position(0, 0.04, 0.15), ZERO_ROT)
obj_c.pose = Pose(Position(0, 0.08, 0.3), ZERO_ROT)
assert tp.tower_is_constructible([obj_a, obj_b, obj_c])
def test_stability_tower_is_stable_with_sim(vis):
tp = TowerPlanner()
for _ in range(10):
# sample three random blocks
blocks = [Object.random(str(i)) for i in range(3)]
# stack all the blocks on top of eachother (center of geometry, not COM)
prev_z = 0
for block in blocks:
pos = Position(0,0,block.dimensions.z/2+prev_z)
block.pose = Pose(pos, ZERO_ROT)
prev_z += block.dimensions.z
assert tp.tower_is_stable(blocks) ==\
tower_is_stable_in_pybullet(blocks, vis=vis, T=50)