File: human_ik.py

package info (click to toggle)
morse-simulator 1.4-8
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 187,116 kB
  • sloc: ansic: 108,311; python: 25,694; cpp: 786; makefile: 126; xml: 34; sh: 7
file content (100 lines) | stat: -rwxr-xr-x 4,466 bytes parent folder | download | duplicates (3)
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
#! /usr/bin/env python
"""
This script tests the inverse kinematics of the human model.
"""

from morse.testing.testing import MorseTestCase
from pymorse import Morse

# Include this import to be able to use your test file as a regular
# builder script, ie, usable with: 'morse [run|exec] <your test>.py
try:
    from morse.builder import *
except ImportError:
    pass

class HumanIkTest(MorseTestCase):

    TESTED_JOINTS = ["neck03","lowerleg01_L","lowerleg01_R","upperarm02_L","upperarm02_R"]

    def _print_ik_joints_state(self, skeleton):
        print("---")
        for j in self.TESTED_JOINTS:
            print("%s: %s" % (j, skeleton.joint_states.get_state().result()[j]))
        print("---")

    def _ik_joint(self, skeleton, name):
        return skeleton.joint_states.get_state().result()[name.split(".")[-1]]

    def _check_pose(self, skeleton, neck, leg_l, leg_r, arm_l, arm_r):
        self.assertAlmostEqual(self._ik_joint(skeleton, self.TESTED_JOINTS[0]), neck, delta = 0.05)
        self.assertAlmostEqual(self._ik_joint(skeleton, self.TESTED_JOINTS[1]), leg_l, delta = 0.05)
        self.assertAlmostEqual(self._ik_joint(skeleton, self.TESTED_JOINTS[2]), leg_r, delta = 0.05)
        self.assertAlmostEqual(self._ik_joint(skeleton, self.TESTED_JOINTS[3]), arm_l, delta = 0.05)
        self.assertAlmostEqual(self._ik_joint(skeleton, self.TESTED_JOINTS[4]), arm_r, delta = 0.05)

    def setUpEnv(self):
        """ Defines the test scenario, using the Builder API.
        """

        human = Human()
        human.add_interface('socket')

        env = Environment('empty', fastmode=True)
        env.set_camera_location([2.6,-0.3,1.2])
        env.set_camera_rotation([1.3,0,1.4])
        env.add_service('socket')

    def test_ik_motion(self):

        IK_TARGET_HEAD = "ik_target.human.skeleton.head"
        IK_TARGET_FOOT_L = "ik_target.human.skeleton.foot_L"
        IK_TARGET_FOOT_R = "ik_target.human.skeleton.foot_R"
        IK_TARGET_WRIST_L = "ik_target.human.skeleton.wrist_L"
        IK_TARGET_WRIST_R = "ik_target.human.skeleton.wrist_R"
        IK_TARGETS = set((IK_TARGET_HEAD, IK_TARGET_FOOT_L, IK_TARGET_FOOT_R, IK_TARGET_WRIST_L, IK_TARGET_WRIST_R))

        with Morse() as morse:
            skeleton = morse.human.skeleton

            self.assertEqual(set(skeleton.list_IK_targets().result()), IK_TARGETS)

            # Set the human in a resting position
            skeleton.place_IK_target(IK_TARGET_HEAD, [0.04,0.,1.58], [1.57,0.05,1.58], False)
            skeleton.place_IK_target(IK_TARGET_FOOT_L, [0.02,0.10,0.07], [-2.65,-0.32,1.43], False)
            skeleton.place_IK_target(IK_TARGET_FOOT_R, [0.02,-0.13,0.07], [-2.65,0.32,1.70], False)
            skeleton.place_IK_target(IK_TARGET_WRIST_L, [0.03,0.29,0.87], [-1.97,0.,1.47], False)
            skeleton.place_IK_target(IK_TARGET_WRIST_R, [0.05,-0.25,0.88], [1.33,2.91,-1.11], False)

            morse.sleep(1)
            self._check_pose(skeleton, -0.006, -0.016, -0.013, 0., 0.01)

            # left hand, palm facing up
            skeleton.move_IK_target(IK_TARGET_WRIST_L, [0.44,0.31,1.1], [-3,1.6,1.5], False).result()
            self._check_pose(skeleton, -0.087, -0.016, -0.013, 0.33, -0.01)

            # back to rest pose
            skeleton.move_IK_target(IK_TARGET_WRIST_L, [0.03,0.29,0.87], [-1.97,0.,1.47], False).result()
            self._check_pose(skeleton, -0.006, -0.016, -0.013, 0., 0.01)

            # right hand above head
            skeleton.move_IK_target(IK_TARGET_WRIST_R, [0.04,-0.15,1.76], [-1.41,1.8,-1.33], False).result()
            self._check_pose(skeleton, 0.35, -0.011,-0.013, -0.059, 0.26)

            # back to rest pose
            skeleton.move_IK_target(IK_TARGET_WRIST_R, [0.05,-0.25,0.88], [1.33,2.91,-1.11], False).result()
            self._check_pose(skeleton, -0.006, -0.016, -0.013, 0., 0.01)

            # head looking left (relative motion)
            skeleton.move_IK_target(IK_TARGET_HEAD, [0.,0.,0.], [0.,0.,1.], True).result()
            self._check_pose(skeleton, 0.35, -0.016, -0.013, 0.01, 0.02)

            # head looking right (relative motion)
            skeleton.move_IK_target(IK_TARGET_HEAD, [0.,0.,0.], [0.,0.,-2.], True).result()
            self._check_pose(skeleton, -0.34, -0.016, -0.013, -0.01, 0.02)


########################## Run these tests ##########################
if __name__ == "__main__":
    from morse.testing.testing import main
    main(HumanIkTest)