You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Dribble/scripts/utils/Fwd_Kinematics.py

115 lines
5.6 KiB
Python

9 months ago
from agent.Base_Agent import Base_Agent as Agent
from scripts.commons.Script import Script
from world.commons.Draw import Draw
import numpy as np
class Fwd_Kinematics():
def __init__(self,script:Script) -> None:
self.script = script
self.cycle_duration = 200 #steps
def draw_cycle(self):
#Draw position of body parts
for _ in range(self.cycle_duration):
self.script.batch_execute_behavior("Squat")
self.script.batch_commit_and_send()
self.script.batch_receive()
p : Agent
for p in self.script.players:
if p.world.vision_is_up_to_date and not p.world.robot.loc_is_up_to_date:
p.world.draw.annotation(p.world.robot.cheat_abs_pos, "Not enough visual data! Using IMU", Draw.Color.red,"localization")
for key, val in p.world.robot.body_parts.items():
rp = val.transform.get_translation()
pos = p.world.robot.loc_head_to_field_transform(rp,False)
label_rp = np.array([rp[0]-0.0001,rp[1]*0.5,0])
label_rp /= np.linalg.norm(label_rp) / 0.4 #labels at 0.4m from body part
label = p.world.robot.loc_head_to_field_transform(rp+label_rp,False)
p.world.draw.line(pos,label,2,Draw.Color.green_light,key,False)
p.world.draw.annotation(label,key,Draw.Color.red,key)
rp = p.world.robot.body_parts['lfoot'].transform((0.08,0,0))
ap = p.world.robot.loc_head_to_field_transform(rp,False)
p.world.draw.line(ap,ap+(0,0,0.1),1,Draw.Color.red,"soup",False)
rp = p.world.robot.body_parts['lfoot'].transform((-0.08,0,0))
ap = p.world.robot.loc_head_to_field_transform(rp,False)
p.world.draw.line(ap,ap+(0,0,0.1),1,Draw.Color.red,"soup",False)
rp = p.world.robot.body_parts['lfoot'].transform((0,0.04,0))
ap = p.world.robot.loc_head_to_field_transform(rp,False)
p.world.draw.line(ap,ap+(0,0,0.1),1,Draw.Color.red,"soup",False)
rp = p.world.robot.body_parts['lfoot'].transform((0,-0.04,0))
ap = p.world.robot.loc_head_to_field_transform(rp,False)
p.world.draw.line(ap,ap+(0,0,0.1),1,Draw.Color.red,"soup",True)
Draw.clear_all()
#Draw position of joints
for _ in range(self.cycle_duration):
self.script.batch_execute_behavior("Squat")
self.script.batch_commit_and_send()
self.script.batch_receive()
for p in self.script.players:
if p.world.vision_is_up_to_date and not p.world.robot.loc_is_up_to_date:
p.world.draw.annotation(p.world.robot.cheat_abs_pos, "Not enough visual data! Using IMU", Draw.Color.red,"localization")
zstep = 0.05
label_z = [0,0,0,0,zstep,zstep,2*zstep,2*zstep,0,0,0,0,zstep,zstep,0,0,zstep,zstep,2*zstep,2*zstep,3*zstep,3*zstep,0,0]
for j, transf in enumerate(p.world.robot.joints_transform):
rp = transf.get_translation()
pos = p.world.robot.loc_head_to_field_transform(rp,False)
j_name = str(j)
label_rp = np.array([rp[0]-0.0001,rp[1]*0.5,0])
label_rp /= np.linalg.norm(label_rp) / 0.4 #labels at 0.4m from body part
label_rp += (0,0,label_z[j])
label = p.world.robot.loc_head_to_field_transform(rp+label_rp,False)
p.world.draw.line( pos,label,2,Draw.Color.green_light,j_name,False)
p.world.draw.annotation( label,j_name,Draw.Color.cyan,j_name)
Draw.clear_all()
#Draw orientation of body parts
for _ in range(self.cycle_duration):
self.script.batch_execute_behavior("Squat")
self.script.batch_commit_and_send()
self.script.batch_receive()
p : Agent
for p in self.script.players:
if p.world.vision_is_up_to_date and not p.world.robot.loc_is_up_to_date:
p.world.draw.annotation(p.world.robot.cheat_abs_pos, "Not enough visual data! Using IMU", Draw.Color.red,"localization")
for key in p.world.robot.body_parts:
#Select only some body parts
if key not in ['head', 'torso', 'llowerarm', 'rlowerarm', 'lthigh', 'rthigh', 'lshank', 'rshank', 'lfoot', 'rfoot']: continue
bpart_abs_pos = p.world.robot.get_body_part_to_field_transform(key).translate((0.1,0,0)) #10cm in front of body part
x_axis = bpart_abs_pos((0.05,0,0),False)
y_axis = bpart_abs_pos((0,0.05,0),False)
z_axis = bpart_abs_pos((0,0,0.05),False)
axes_0 = bpart_abs_pos.get_translation()
p.world.draw.line( axes_0,x_axis,2,Draw.Color.green_light,key,False)
p.world.draw.line( axes_0,y_axis,2,Draw.Color.blue,key,False)
p.world.draw.line( axes_0,z_axis,2,Draw.Color.red,key)
Draw.clear_all()
def execute(self):
a = self.script.args
# Args: Server IP, Agent Port, Monitor Port, Uniform No., Robot Type, Team Name, Enable Log, Enable Draw
self.script.batch_create(Agent, ((a.i,a.p,a.m,u,u-1,a.t,True,True) for u in range(1,6)) )
#Beam players
self.script.batch_unofficial_beam( [(-2,i*4-10,0.5,i*45) for i in range(5)] )
print("\nPress ctrl+c to return.")
while True:
self.draw_cycle()