#! /usr/bin/env python # -*- encoding: UTF-8 -*- """Example: Walk - Small example to make Nao walk""" import qi import argparse import sys import motion import time import almath def userArmsCartesian(motion_service): effector = ["LArm", "RArm"] frame = motion.FRAME_TORSO useSensorValues = False # just control position axisMask = [motion.AXIS_MASK_VEL, motion.AXIS_MASK_VEL] # LArm path pathLArm = [] initTf = almath.Transform(motion_service.getTransform("LArm", frame, useSensorValues)) targetTf = almath.Transform(motion_service.getTransform("LArm", frame, useSensorValues)) targetTf.r1_c4 += 0.04 # x targetTf.r2_c4 -= 0.10 # y targetTf.r3_c4 += 0.10 # z pathLArm.append(list(targetTf.toVector())) pathLArm.append(list(initTf.toVector())) pathLArm.append(list(targetTf.toVector())) pathLArm.append(list(initTf.toVector())) # RArm path pathRArm = [] initTf = almath.Transform(motion_service.getTransform("RArm", frame, useSensorValues)) targetTf = almath.Transform(motion_service.getTransform("RArm", frame, useSensorValues)) targetTf.r1_c4 += 0.04 # x targetTf.r2_c4 += 0.10 # y targetTf.r3_c4 += 0.10 # z pathRArm.append(list(targetTf.toVector())) pathRArm.append(list(initTf.toVector())) pathRArm.append(list(targetTf.toVector())) pathRArm.append(list(initTf.toVector())) pathList = [] pathList.append(pathLArm) pathList.append(pathRArm) # Go to the target and back again timesList = [[1.0, 2.0, 3.0, 4.0], [1.0, 2.0, 3.0, 4.0]] # seconds motion_service.transformInterpolations(effector, frame, pathList, axisMask, timesList) def userArmArticular(motion_service): # Arms motion from user have always the priority than walk arms motion JointNames = ["LShoulderPitch", "LShoulderRoll", "LElbowYaw", "LElbowRoll"] Arm1 = [-40, 25, 0, -40] Arm1 = [ x * motion.TO_RAD for x in Arm1] Arm2 = [-40, 50, 0, -80] Arm2 = [ x * motion.TO_RAD for x in Arm2] pFractionMaxSpeed = 0.6 motion_service.angleInterpolationWithSpeed(JointNames, Arm1, pFractionMaxSpeed) motion_service.angleInterpolationWithSpeed(JointNames, Arm2, pFractionMaxSpeed) motion_service.angleInterpolationWithSpeed(JointNames, Arm1, pFractionMaxSpeed) def main(session): """ Walk - Small example to make Nao walk This example is only compatible with NAO """ # Get the services ALMotion & ALRobotPosture. motion_service = session.service("ALMotion") posture_service = session.service("ALRobotPosture") # Wake up robot motion_service.wakeUp() # Send robot to Stand posture_service.goToPosture("StandInit", 0.5) ##################### ## Enable arms control by Motion algorithm ##################### motion_service.setMoveArmsEnabled(True, True) # motion_service.setMoveArmsEnabled(False, False) ##################### ## FOOT CONTACT PROTECTION ##################### #motion_service.setMotionConfig([["ENABLE_FOOT_CONTACT_PROTECTION", False]]) motion_service.setMotionConfig([["ENABLE_FOOT_CONTACT_PROTECTION", True]]) #TARGET VELOCITY X = -0.5 # backward Y = 0.0 Theta = 0.0 Frequency =0.0 # low speed try: motion_service.moveToward(X, Y, Theta, [["Frequency", Frequency]]) except Exception, errorMsg: print str(errorMsg) print "This example is not allowed on this robot." exit() userArmsCartesian(motion_service) #TARGET VELOCITY X = 0.8 Y = 0.0 Theta = 0.0 Frequency =1.0 # max speed try: motion_service.moveToward(X, Y, Theta, [["Frequency", Frequency]]) except Exception, errorMsg: print str(errorMsg) print "This example is not allowed on this robot." exit() time.sleep(4.0) #TARGET VELOCITY X = 0.2 Y = -0.5 Theta = 0.2 Frequency = 1.0 try: motion_service.moveToward(X, Y, Theta, [["Frequency", Frequency]]) except Exception, errorMsg: print str(errorMsg) print "This example is not allowed on this robot." exit() time.sleep(2.0) userArmArticular(motion_service) time.sleep(2.0) ##################### ## End Walk ##################### #TARGET VELOCITY X = 0.0 Y = 0.0 Theta = 0.0 motion_service.moveToward(X, Y, Theta) motion_service.waitUntilMoveIsFinished() # Go to rest position motion_service.rest() if __name__ == "__main__": parser = argparse.ArgumentParser() parser.add_argument("--ip", type=str, default="127.0.0.1", help="Robot IP address. On robot or Local Naoqi: use '127.0.0.1'.") parser.add_argument("--port", type=int, default=9559, help="Naoqi port number") args = parser.parse_args() session = qi.Session() try: session.connect("tcp://" + args.ip + ":" + str(args.port)) except RuntimeError: print ("Can't connect to Naoqi at ip \"" + args.ip + "\" on port " + str(args.port) +".\n" "Please check your script arguments. Run with -h option for help.") sys.exit(1) main(session)