2024-05-01 10:32:27 +08:00
|
|
|
{
|
|
|
|
"cells": [
|
|
|
|
{
|
|
|
|
"cell_type": "markdown",
|
|
|
|
"metadata": {},
|
|
|
|
"source": [
|
|
|
|
"# Lowlevel Interface Test"
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"cell_type": "code",
|
|
|
|
"execution_count": 1,
|
|
|
|
"metadata": {},
|
|
|
|
"outputs": [
|
|
|
|
{
|
|
|
|
"name": "stdout",
|
|
|
|
"output_type": "stream",
|
|
|
|
"text": [
|
|
|
|
"pygame 2.5.2 (SDL 2.28.2, Python 3.8.18)\n",
|
|
|
|
"Hello from the pygame community. https://www.pygame.org/contribute.html\n"
|
|
|
|
]
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"source": [
|
|
|
|
"from Go2Py.robot.interface.ros2 import GO2Real, ros2_init, ROS2ExecutorManager\n",
|
|
|
|
"from Go2Py.robot.interface.ros2 import ROS2TFInterface\n",
|
|
|
|
"import time\n",
|
|
|
|
"ros2_init()\n",
|
|
|
|
"vicon = ROS2TFInterface('vicon/World', 'vicon/GO2/GO2', 'vicon')\n",
|
|
|
|
"robot = GO2Real(mode='highlevel')\n",
|
|
|
|
"ros2_exec_manager = ROS2ExecutorManager()\n",
|
|
|
|
"ros2_exec_manager.add_node(robot)\n",
|
|
|
|
"ros2_exec_manager.add_node(vicon)\n",
|
|
|
|
"ros2_exec_manager.start()"
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"cell_type": "code",
|
|
|
|
"execution_count": 2,
|
|
|
|
"metadata": {},
|
|
|
|
"outputs": [],
|
|
|
|
"source": [
|
|
|
|
"for i in range(1000):\n",
|
|
|
|
" time.sleep(0.01)\n",
|
|
|
|
" imu = robot.getIMU()\n",
|
|
|
|
" accel = imu['accel']\n",
|
|
|
|
" gyro = imu['gyro']\n",
|
|
|
|
" q = imu['quat']\n",
|
|
|
|
" pose = vicon.get_pose()\n",
|
|
|
|
" stamp = time.time()"
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"cell_type": "code",
|
2024-05-05 02:03:03 +08:00
|
|
|
"execution_count": 2,
|
2024-05-01 10:32:27 +08:00
|
|
|
"metadata": {},
|
|
|
|
"outputs": [],
|
|
|
|
"source": [
|
|
|
|
"import time\n",
|
|
|
|
"import numpy as np\n",
|
|
|
|
"im = []\n",
|
|
|
|
"acc = []\n",
|
|
|
|
"gy = []\n",
|
|
|
|
"quaternion = []\n",
|
|
|
|
"pos = []\n",
|
|
|
|
"stamps = []\n",
|
|
|
|
"for i in range(2000):\n",
|
|
|
|
" time.sleep(0.01)\n",
|
|
|
|
" imu = robot.getIMU()\n",
|
|
|
|
" accel = imu['accel']\n",
|
|
|
|
" gyro = imu['gyro']\n",
|
|
|
|
" q = imu['quat']\n",
|
|
|
|
" pose = vicon.get_pose()\n",
|
|
|
|
" stamp = time.time()\n",
|
|
|
|
" im.append(imu)\n",
|
|
|
|
" acc.append(accel)\n",
|
|
|
|
" gy.append(gyro)\n",
|
|
|
|
" quaternion.append(q)\n",
|
|
|
|
" pos.append(pose)\n",
|
|
|
|
" stamps.append(stamp)\n",
|
|
|
|
"\n",
|
|
|
|
"imu = np.array(im)\n",
|
|
|
|
"accel = np.array(acc)\n",
|
|
|
|
"gyro = np.array(gy)\n",
|
|
|
|
"q = np.array(quaternion)\n",
|
|
|
|
"pose = np.array(pos)\n",
|
|
|
|
"stamp = np.array(stamps)"
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"cell_type": "code",
|
2024-05-05 02:03:03 +08:00
|
|
|
"execution_count": 3,
|
2024-05-01 10:32:27 +08:00
|
|
|
"metadata": {},
|
|
|
|
"outputs": [],
|
|
|
|
"source": [
|
|
|
|
"import pickle \n",
|
2024-05-05 02:03:03 +08:00
|
|
|
"with open('vicon2gt_5.pkl', 'wb') as f:\n",
|
2024-05-01 10:32:27 +08:00
|
|
|
" pickle.dump(\n",
|
|
|
|
" {\n",
|
|
|
|
" 'imu':imu,\n",
|
|
|
|
" 'accel':accel,\n",
|
|
|
|
" 'gyro':gyro,\n",
|
|
|
|
" 'q':q,\n",
|
|
|
|
" 'pose':pose,\n",
|
|
|
|
" 'stamp':stamp\n",
|
|
|
|
" }\n",
|
|
|
|
" ,f\n",
|
|
|
|
" )"
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"cell_type": "code",
|
|
|
|
"execution_count": null,
|
|
|
|
"metadata": {},
|
|
|
|
"outputs": [],
|
|
|
|
"source": []
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"metadata": {
|
|
|
|
"kernelspec": {
|
|
|
|
"display_name": "Python 3",
|
|
|
|
"language": "python",
|
|
|
|
"name": "python3"
|
|
|
|
},
|
|
|
|
"language_info": {
|
|
|
|
"codemirror_mode": {
|
|
|
|
"name": "ipython",
|
|
|
|
"version": 3
|
|
|
|
},
|
|
|
|
"file_extension": ".py",
|
|
|
|
"mimetype": "text/x-python",
|
|
|
|
"name": "python",
|
|
|
|
"nbconvert_exporter": "python",
|
|
|
|
"pygments_lexer": "ipython3",
|
|
|
|
"version": "3.8.18"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"nbformat": 4,
|
|
|
|
"nbformat_minor": 4
|
|
|
|
}
|