Cartesian commands

<< return to examples index

This section contains examples showing cartesian commands on NAO’s body.

Arms

Arm trajectories examples.

Trajectory 1

motion_cartesianArm1.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Arm trajectory example '''

import config
import motion
import almath

def main():
    ''' Example showing a path of two positions
    Warning: Needs a PoseInit before executing
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    effector   = "LArm"
    space      = motion.SPACE_NAO
    axisMask   = almath.AXIS_MASK_VEL    # just control position
    isAbsolute = False

    # Since we are in relative, the current position is zero
    currentPos = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]

    # Define the changes relative to the current position
    dx         =  0.03      # translation axis X (meters)
    dy         =  0.03      # translation axis Y (meters)
    dz         =  0.00      # translation axis Z (meters)
    dwx        =  0.00      # rotation axis X (radians)
    dwy        =  0.00      # rotation axis Y (radians)
    dwz        =  0.00      # rotation axis Z (radians)
    targetPos  = [dx, dy, dz, dwx, dwy, dwz]

    # Go to the target and back again
    path       = [targetPos, currentPos]
    times      = [2.0, 4.0] # seconds

    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Trajectory 2

motion_cartesianArm2.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Arm trajectory example '''

import config
import motion

def main():
    ''' Example showing a hand ellipsoid
    Warning: Needs a PoseInit before executing
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    effector   = "LArm"
    space      = motion.SPACE_NAO
    path       = [
     [0.0, -0.05, +0.00, 0.0, 0.0, 0.0],        # point 1
     [0.0, +0.00, +0.04, 0.0, 0.0, 0.0],        # point 2
     [0.0, +0.04, +0.00, 0.0, 0.0, 0.0],        # point 3
     [0.0, +0.00, -0.02, 0.0, 0.0, 0.0],        # point 4
     [0.0, -0.05, +0.00, 0.0, 0.0, 0.0],        # point 5
     [0.0, +0.00, +0.00, 0.0, 0.0, 0.0]]        # point 6
    axisMask   = 7                              # just control position
    times      = [0.5, 1.0, 2.0, 3.0, 4.0, 4.5] # seconds
    isAbsolute = False
    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Feet

Control NAO’s left foot.

motion_cartesianFoot.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Torso and Foot trajectories '''

import config
import motion
import almath

def main():
    ''' Example of a cartesian foot trajectory
    Warning: Needs a PoseInit before executing
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    space      = motion.SPACE_NAO
    axisMask   = almath.AXIS_MASK_ALL   # full control
    isAbsolute = False

    # Lower the Torso and move to the side
    effector   = "Torso"
    path       = [0.0, -0.07, -0.03, 0.0, 0.0, 0.0]
    time       = 2.0                    # seconds
    motionProxy.positionInterpolation(effector, space, path,
                                axisMask, time, isAbsolute)

    # LLeg motion
    effector   = "LLeg"
    path       = [0.0,  0.06,  0.00, 0.0, 0.0, 0.8]
    times      = 2.0                    # seconds

    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Torso

Make NAO’s torso take different positions.

Trajectory 1

motion_cartesianTorso1.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Torso trajectory '''

import config
import motion
import almath

def main():
    ''' Example showing a path of five positions
    Needs a PoseInit before execution
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    effector   = "Torso"
    space      =  motion.SPACE_WORLD

    # Position Only
    axisMask   = almath.AXIS_MASK_ALL           # full control
    isAbsolute = False

    # Define the changes relative to the current position
    dx         = 0.045                          # translation axis X (meter)
    dy         = 0.050                          # translation axis Y (meter)

    path       = [
      [+dx, 0.0, 0.0, 0.0, 0.0, 0.0],           # point 1
      [0.0, -dy, 0.0, 0.0, 0.0, 0.0],           # point 2
      [-dx, 0.0, 0.0, 0.0, 0.0, 0.0],           # point 3
      [0.0, +dy, 0.0, 0.0, 0.0, 0.0],           # point 4
      [+dx, 0.0, 0.0, 0.0, 0.0, 0.0],           # point 5
      [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]           # point 6

    times      = [1.0, 2.0, 3.0, 4.0, 5.0, 6.0] # seconds
    motionProxy.positionInterpolation(effector, space, path,
                                axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Hula Hoop

motion_cartesianTorso2.py

#-*- coding: iso-8859-15 -*-

import config
import motion
import almath

def main():
    ''' 
		 Example showing a Hula Hoop Motion
         with the NAO cartesian control of torso
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    # Define the changes relative to the current position
    dx         = 0.07                    # translation axis X (meter)
    dy         = 0.07                    # translation axis Y (meter)
    dwx        = 0.15                    # rotation axis X (rad)
    dwy        = 0.15                    # rotation axis Y (rad)

    # Define a path of two hula hoop loops
    path = [ [+dx, 0.0, 0.0,  0.0, -dwy, 0.0],  # point 01 : forward  / bend backward
             [0.0, -dy, 0.0, -dwx,  0.0, 0.0],  # point 02 : right    / bend left
             [-dx, 0.0, 0.0,  0.0,  dwy, 0.0],  # point 03 : backward / bend forward
             [0.0, +dy, 0.0,  dwx,  0.0, 0.0],  # point 04 : left     / bend right

             [+dx, 0.0, 0.0,  0.0, -dwy, 0.0],  # point 01 : forward  / bend backward
             [0.0, -dy, 0.0, -dwx,  0.0, 0.0],  # point 02 : right    / bend left
             [-dx, 0.0, 0.0,  0.0,  dwy, 0.0],  # point 03 : backward / bend forward
             [0.0, +dy, 0.0,  dwx,  0.0, 0.0],  # point 04 : left     / bend right

             [+dx, 0.0, 0.0,  0.0, -dwy, 0.0],  # point 05 : forward  / bend backward
			 [0.0, 0.0, 0.0,  0.0,  0.0, 0.0] ] # point 06 : Back to init pose

    timeOneMove  = 0.4 #seconds
    times = []
    for i in range(len(path)):
        times.append( (i+1)*timeOneMove )

    # call the cartesian control API
    effector   = "Torso"
    space      =  motion.SPACE_NAO

    axisMask   = almath.AXIS_MASK_ALL
    isAbsolute = False

    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Arms and torso

Control multiple effectors with cartesian commands.

Trajectory 1

motion_cartesianTorsoArm1.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Multiple Effector Trajectories '''

import config
import motion
import almath

def main():
    ''' Simultaneously control three effectors :
    the Torso, the Left Arm and the Right Arm
    Warning: Needs a PoseInit before executing
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send Robot to Pose Init
    config.PoseInit(motionProxy)

    space      = motion.SPACE_NAO
    coef       = 0.5                   # motion speed
    times      = [coef, 2.0*coef, 3.0*coef, 4.0*coef]
    isAbsolute = False

    # Relative movement between current and desired positions
    dy         = +0.06                 # translation axis Y (meters)
    dz         = -0.03                 # translation axis Z (meters)
    dwx        = +0.30                 # rotation axis X (radians)

    # Motion of Torso with post process
    effector   = "Torso"
    path       = [
      [0.0, -dy,  dz, -dwx, 0.0, 0.0], # point 1
      [0.0, 0.0, 0.0,  0.0, 0.0, 0.0], # point 2
      [0.0, +dy,  dz, +dwx, 0.0, 0.0], # point 3
      [0.0, 0.0, 0.0,  0.0, 0.0, 0.0]] # point 4
    axisMask   = almath.AXIS_MASK_ALL  # control all the effector axes
    motionProxy.post.positionInterpolation(effector, space, path,
                                           axisMask, times, isAbsolute)

    # Motion of Arms with block process
    axisMask   = almath.AXIS_MASK_VEL  # control just the position
    times      = [1.0*coef, 2.0*coef]  # seconds

    dy         = +0.03                 # translation axis Y (meters)
    # Motion of Right Arm during the first half of the Torso motion
    effector   = "RArm"
    path       = [
      [0.0, -dy, 0.0, 0.0, 0.0, 0.0],  # point 1
      [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]  # point 2
    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

    # Motion of Left Arm during the last half of the Torso motion
    effector   = "LArm"
    path       = [
      [0.0,  dy, 0.0, 0.0, 0.0, 0.0],  # point 1
      [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]  # point 2
    motionProxy.positionInterpolation(effector, space, path,
                                      axisMask, times, isAbsolute)

if __name__ == "__main__":
    main()

Trajectory 2

motion_cartesianTorsoArm2.py

#-*- coding: iso-8859-15 -*-

''' Cartesian control: Multiple Effector Trajectories '''

import config
import motion
import almath

def main():
    ''' Move the torso and keep arms fixed in nao space
    Warning: Needs a PoseInit before executing
    '''

    motionProxy = config.loadProxy("ALMotion")

    # Set NAO in Stiffness On
    config.StiffnessOn(motionProxy)

    # Send NAO to Pose Init
    config.PoseInit(motionProxy)

    space      = motion.SPACE_NAO
    isAbsolute = False

    effectorList = ["LArm", "RArm"]

    # Motion of Arms with block process
    axisMaskList = [almath.AXIS_MASK_VEL, almath.AXIS_MASK_VEL]

    timesList    = [[1.0], [1.0]]         # seconds
    pathList     = [[[0.0, -0.04, 0.0, 0.0, 0.0, 0.0]],
                    [[0.0,  0.04, 0.0, 0.0, 0.0, 0.0]]]
    motionProxy.positionInterpolations(effectorList, space, pathList,
                                       axisMaskList, timesList, isAbsolute)


    effectorList = ["LArm", "RArm", "Torso"]

    # Motion of Arms and Torso with block process
    axisMaskList = [almath.AXIS_MASK_VEL,
                    almath.AXIS_MASK_VEL,
                    almath.AXIS_MASK_ALL]

    timesList    = [[4.0],                  # LArm  in seconds
                    [4.0],                  # RArm  in seconds
                    [1.0, 2.0, 3.0, 4.0]]   # Torso in seconds

    dx           = 0.03                  # translation axis X (meters)
    dy           = 0.04                  # translation axis Y (meters)

    pathList     = [[[0.0, 0.0, 0.0, 0.0, 0.0, 0.0]], # LArm do not move
                    [[0.0, 0.0, 0.0, 0.0, 0.0, 0.0]], # RArm do not move
                    [[0.0, +dy, 0.0, 0.0, 0.0, 0.0],  # Torso point 1
                     [-dx, 0.0, 0.0, 0.0, 0.0, 0.0],  # Torso point 2
                     [0.0, -dy, 0.0, 0.0, 0.0, 0.0],  # Torso point 3
                     [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]  # Torso point 4
                    ]
    motionProxy.positionInterpolations(effectorList, space, pathList,
                                       axisMaskList, timesList, isAbsolute)


if __name__ == "__main__":
    main()