Realsense-Realman手眼标定

硬件设备

Realsense D405
Realman 65b

软件环境搭建

软件环境依赖:

librealsense
		https://github.com/IntelRealSense/librealsense.git
ROS1.0
	ros-noetic-aruco
		sudo apt-get install ros-noetic-aruco*
	realsense_ros
		https://github.com/IntelRealSense/realsense-ros.git
	rm_robot
		https://github.com/RealManRobot/rm_robot.git

下载标定软件

mkdir -p handeye_ws/src && cd handeye_ws/src

​git clone https://github.com/HenryWJL/hand_eye_calibration

cd ../catkin_make

这里软件使用jaka虚拟机械比进行标定,因系需要进行适配。进入/home/kyle/ROS_Packages/handeye_ws/src/hand_eye_calibration/scripts修改hand_to_eye_calib.py代码以适配睿尔曼机械臂:

### 导入Pose包
from geometry_msgs.msg import TwistStamped, Pose

### 注释原有的位姿订阅callback

# def get_end2base_mat(pose):
#     # Calculating the gripper-to-base transformation matrix
#     tran = np.array((pose.twist.linear.x, pose.twist.linear.y, pose.twist.linear.z))
#     rot = tfs.euler.euler2mat(pose.twist.angular.x, pose.twist.angular.y, pose.twist.angular.z)
#     return rot, tran

### 订阅睿尔曼机械臂消息,并使用geometry_msgs.msg/Pose
### 有可能需要解算逆坐标
def get_end2base_mat(pose):
    # Calculating the gripper-to-base transformation matrix
    tran = np.array((pose.position.x, pose.position.y, pose.position.z))
    # rot = tfs.euler.euler2mat(pose.orientation.x, pose.orientation.y, pose.orientation.z)
    rot = tfs.quaternions.quat2mat([pose.orientation.w, pose.orientation.x, pose.orientation.y, pose.orientation.z])
    # invert
    # tran = -np.array(rot).T * tran
    # rot = np.array(rot).T
    return rot, tran

...
	### 机械臂订阅睿尔曼位姿话题
	rospy.Subscriber('/rm_driver/Pose_State', Pose, end_pose_callback, queue_size=10)

...
	### 打印不同形式位姿,方便检查
                    print("="*60)
                    print("R_cam2end")
                    print("Transform:")
                    print(cam2base)  # Transformation matrix
                    R_cam2base_quaternions = tfs.quaternions.mat2quat(R_cam2base)
                    cam2base_quaternions = np.concatenate((T_cam2base.reshape(3),
                                                           R_cam2base_quaternions.reshape(4)), axis=0)
                    print("Quaternions:")
                    print(cam2base_quaternions.tolist())  # Quaternions

                    R_cam2base_euler = tfs.euler.mat2euler(R_cam2base)
                    print("Euler angles:")
                    print(R_cam2base_euler[0]/np.pi*180, R_cam2base_euler[1]/np.pi*180, R_cam2base_euler[2]/np.pi*180)
                 

修改标定板识别参数,这里使用的是棋盘格标定板。/home/kyle/ROS_Packages/handeye_ws/src/hand_eye_calibration/launchcheckerboard_start.launch文件:

    <arg name="image_topic"       default="/camera/color/image_raw"/>
    <arg name="camera_info"       default="/camera/color/camera_info"/> 
    <arg name="cornerX"          default="6"/>
    <arg name="cornerY"          default="3"/>    
    <arg name="gridLength"        default="0.05"/> 

标定过程(眼在手上)

原理见下图,总的过程为采集数据,解一个方程 AX=XB。
原理图

#console1
roslaunch rm_control rm_65_control.launch &
roslaunch rm_bringup rm_65_robot.launch

#console2
roslaunch realsense2_camera rs_camera.launch

#console3
roslaunch hand_eye_calibration checkerboard_start.launch

#console4
rosrun hand_eye_calibration hand_to_eye_calib.py

标定程序启动后,不停摆动机械臂位姿,均使相机拍摄标定板。采集样本输入r命令,计算位姿输入c命令,退出输入q命令,采集样本>3个。

Record: r, Calculate: c, Save: s, Quit: q
r
[[-0.7599338   0.0060974   0.64997188]
 [ 0.04182341  0.99834257  0.03953361]
 [-0.64865354  0.05722697 -0.75892928]]
1 samples have been recorded

record1

Record: r, Calculate: c, Save: s, Quit: q
r
[[-0.74060468  0.49582793  0.45349683]
 [ 0.56793266  0.82259485  0.02811064]
 [-0.35910612  0.27837454 -0.89081447]]
2 samples have been recorded

record2

rRecord: r, Calculate: c, Save: s, Quit: q

[[-0.81163333 -0.14185728  0.56668144]
 [-0.26747336  0.95265154 -0.14461342]
 [-0.51933548 -0.26894526 -0.81114679]]
3 samples have been recorded
Record: r, Calculate: c, Save: s, Quit: q
r
[[-0.67410916  0.1870448   0.71455657]
 [ 0.22764802  0.97292509 -0.03991421]
 [-0.70267576  0.13576085 -0.69843809]]
4 samples have been recorded
c
Record: r, Calculate: c, Save: s, Quit: q
============================================================
R_cam2end
Transform:
[[ 0.02341403  0.96697815  0.25378148 -0.08822873]
 [-0.99964886  0.01949493  0.01794709  0.00566516]
 [ 0.01240699 -0.25411258  0.96709506  0.07756586]
 [ 0.          0.          0.          1.        ]]
Quaternions:
[-0.08822872609559883, 0.005665157492463942, 0.07756585852038214, 0.7088730522093655, -0.09594795174349201, 0.08512613400089308, -0.6935751781297171]
Euler angles:
-14.72216660609419 -0.7108864356472807 -88.65824916327023

通过结构数据对比标定参数,可知rotation误差基本在0.3度以内,translation误差在3mm左右。

  • 15
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值