149 lines
4.5 KiB
Python
149 lines
4.5 KiB
Python
'''
|
|
This demo show the communication interface of MR813 motion control board based on Lcm.
|
|
Dependency:
|
|
- robot_control_cmd_lcmt.py
|
|
- robot_control_response_lcmt.py
|
|
'''
|
|
import lcm
|
|
import sys
|
|
import os
|
|
import time
|
|
import subprocess
|
|
from threading import Thread, Lock
|
|
|
|
from robot_control_cmd_lcmt import robot_control_cmd_lcmt
|
|
from robot_control_response_lcmt import robot_control_response_lcmt
|
|
|
|
def main():
|
|
Ctrl = Robot_Ctrl()
|
|
Ctrl.run()
|
|
msg = robot_control_cmd_lcmt()
|
|
try:
|
|
msg.mode = 12 # Recovery stand
|
|
msg.gait_id = 0
|
|
msg.life_count += 1 # Command will take effect when life_count update
|
|
Ctrl.Send_cmd(msg)
|
|
Ctrl.Wait_finish(12, 0)
|
|
|
|
msg.mode = 11
|
|
msg.gait_id =3
|
|
msg.vel_des = [0.0,0.0,0.4]
|
|
msg.duration = 4600
|
|
msg.step_height = [0.06, 0.06]
|
|
msg.life_count += 1
|
|
Ctrl.Send_cmd(msg)
|
|
time.sleep(15)
|
|
|
|
# 获取当前脚本所在目录
|
|
current_dir = os.path.dirname(os.path.abspath(__file__))
|
|
limit_script_path = os.path.join(current_dir, "limit.py")
|
|
|
|
# 确保文件存在
|
|
if not os.path.exists(limit_script_path):
|
|
print(f"错误:找不到脚本 {limit_script_path}")
|
|
return
|
|
|
|
print(f"准备执行脚本: {limit_script_path}")
|
|
|
|
# 使用导入方式执行脚本
|
|
try:
|
|
# 动态导入 limit.py
|
|
spec = importlib.util.spec_from_file_location("limit_module", limit_script_path)
|
|
limit_module = importlib.util.module_from_spec(spec)
|
|
|
|
# 执行模块
|
|
spec.loader.exec_module(limit_module)
|
|
|
|
# 检查模块中是否有 run_limit_script 函数
|
|
if hasattr(limit_module, 'run_limit_script'):
|
|
limit_module.run_limit_script()
|
|
else:
|
|
# 如果模块没有这个函数,尝试直接调用 main
|
|
limit_module.main()
|
|
|
|
print("脚本执行完成")
|
|
|
|
except Exception as e:
|
|
print(f"执行脚本时出错: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
|
|
print("另一个脚本程序执行完成,继续执行当前文件")
|
|
|
|
msg.mode = 7 # PureDamper
|
|
msg.gait_id = 1
|
|
msg.life_count += 1
|
|
Ctrl.Send_cmd(msg)
|
|
Ctrl.Wait_finish(7, 0)
|
|
time.sleep(10)
|
|
|
|
except KeyboardInterrupt:
|
|
pass
|
|
finally:
|
|
Ctrl.quit()
|
|
sys.exit()
|
|
|
|
class Robot_Ctrl(object):
|
|
def __init__(self):
|
|
self.rec_thread = Thread(target=self.rec_responce)
|
|
self.send_thread = Thread(target=self.send_publish)
|
|
self.lc_r = lcm.LCM("udpm://239.255.76.67:7670?ttl=255")
|
|
self.lc_s = lcm.LCM("udpm://239.255.76.67:7671?ttl=255")
|
|
self.cmd_msg = robot_control_cmd_lcmt()
|
|
self.rec_msg = robot_control_response_lcmt()
|
|
self.send_lock = Lock()
|
|
self.delay_cnt = 0
|
|
self.mode_ok = 0
|
|
self.gait_ok = 0
|
|
self.runing = 1
|
|
|
|
def run(self):
|
|
self.lc_r.subscribe("robot_control_response", self.msg_handler)
|
|
self.send_thread.start()
|
|
self.rec_thread.start()
|
|
|
|
def msg_handler(self, channel, data):
|
|
self.rec_msg = robot_control_response_lcmt().decode(data)
|
|
if(self.rec_msg.order_process_bar >= 95):
|
|
self.mode_ok = self.rec_msg.mode
|
|
else:
|
|
self.mode_ok = 0
|
|
|
|
def rec_responce(self):
|
|
while self.runing:
|
|
self.lc_r.handle()
|
|
time.sleep( 0.002 )
|
|
|
|
def Wait_finish(self, mode, gait_id):
|
|
count = 0
|
|
while self.runing and count < 2000: #10s
|
|
if self.mode_ok == mode and self.gait_ok == gait_id:
|
|
return True
|
|
else:
|
|
time.sleep(0.005)
|
|
count += 1
|
|
|
|
def send_publish(self):
|
|
while self.runing:
|
|
self.send_lock.acquire()
|
|
if self.delay_cnt > 20: # Heartbeat signal 10HZ, It is used to maintain the heartbeat when life count is not updated
|
|
self.lc_s.publish("robot_control_cmd",self.cmd_msg.encode())
|
|
self.delay_cnt = 0
|
|
self.delay_cnt += 1
|
|
self.send_lock.release()
|
|
time.sleep( 0.005 )
|
|
|
|
def Send_cmd(self, msg):
|
|
self.send_lock.acquire()
|
|
self.delay_cnt = 50
|
|
self.cmd_msg = msg
|
|
self.send_lock.release()
|
|
|
|
def quit(self):
|
|
self.runing = 0
|
|
self.rec_thread.join()
|
|
self.send_thread.join()
|
|
|
|
# 防止被导入时执行
|
|
if __name__ == '__main__':
|
|
main() |