四舵轮车辆中的舵轮角度计算

news2024/10/4 4:21:58

对于四舵轮车辆,或者对角线安装的双舵轮车辆来说,当同时存在线速度与角速度的时候,它的两个轮子的角度值是不一样的,而它的角度值与其当时的瞬心相关(机器人模型与ICR(Instantaneous Center of Rotation))。关于这块的计算最近也花时间理解了一下,做个笔记。

1、瞬心的坐标计算

首先在瞬心的学习中可以知道对于四舵轮车辆,它的瞬心位置是任意的,但是满足以下条件:
1、瞬心到车体中心的距离满足下式:
r c = v c w ( w ≠ 0 ) r_c =\frac{ v_c}{w}(w\neq0) rc=wvc(w=0)
2、瞬心的角度与速度的朝向垂直
3、瞬心的位置与角速度的方向相关,当角速度为正时,瞬心的角度为速度方向逆时针旋转90度,当角速度为负时,瞬心的角度为速度方向顺时针旋转90度。
关于第二点的理解再于:当计算某一时刻的瞬心时,默认小车在这一时刻是一个完全的刚体,其按照一定的线速度角速度做圆周运动,则其圆周运动的半径为 r c r_c rc且垂直当前速度方向。
摘录一张示意图:
在这里插入图片描述
通过上述的约束,对于任意时刻当已知线速度与角速度的情况,我们可以计算出瞬心的坐标:
θ = a r c t a n v x v y ± π 2 \theta = arctan\frac{ v_x}{v_y}\pm\frac{ \pi}{2} θ=arctanvyvx±2π
R c = v c w ( w ≠ 0 ) R_c =\frac{ v_c}{w}(w\neq0) Rc=wvc(w=0)
i c c x = R c ∗ s i n θ i c c y = R c ∗ c o s θ \begin{align} icc_x = R_c*sin\theta\\ icc_y = R_c*cos\theta \end{align} iccx=Rcsinθiccy=Rccosθ
函数实现:

// 计算速度向量角
double vel_theta = std::atan2(linear_velocity_y, linear_velocity_x);
// 转成瞬心的角度
vel_theta += (angular_velocity > 0) ? (3.1415926 / 2) : -(3.1415926 / 2);
//半径
double R = fabs(v/angular_velocity);
// 计算瞬心位置的半径
double icc_x = R*cos(vel_theta);
// 计算瞬心的y坐标
double icc_y = R*sin(vel_theta);
// 假设车辆中心在原点(0, 0),瞬心在车辆的左侧或右侧
icc_position.point.x = icc_x;
icc_position.point.y = icc_y;
icc_position.point.z = 0;

2、舵轮角度计算

按照上式知道了舵轮的瞬心后,如何求出每个舵轮的角度?这个问题,思考了许久后发现它可以通过向量法快速的求解出来:

还是回到上面的图中,以车体中心建立机器人坐标系,假设四个轮子的位置分别为:( A x A_x Ax, A y A_y Ay)、( B x B_x Bx, B y B_y By)、( C x C_x Cx, C y C_y Cy)、( D x D_x Dx, D y D_y Dy),瞬心的坐标为:( I C R x ICR_x ICRx, I C R y ICR_y ICRy)。以瞬心为起点,四个轮子的坐标为终点作向量,即可以通过向量法求出四条线的角度:

θ A = a r c t a n I C R y − A y I C R x − A x θ B = a r c t a n I C R y − B y I C R x − B x θ C = a r c t a n I C R y − C y I C R x − C x θ D = a r c t a n I C R y − D y I C R x − D x \begin{align} \theta_A = arctan\frac{ ICR_y-A_y}{ICR_x-A_x}\\ \theta_B = arctan\frac{ ICR_y-B_y}{ICR_x-B_x}\\ \theta_C = arctan\frac{ ICR_y-C_y}{ICR_x-C_x}\\ \theta_D = arctan\frac{ ICR_y-D_y}{ICR_x-D_x} \end{align} θA=arctanICRxAxICRyAyθB=arctanICRxBxICRyByθC=arctanICRxCxICRyCyθD=arctanICRxDxICRyDy
然后,同样采用刚体的思想考虑每个轮子的状态,则在该时刻轮子的角度应与轮子到瞬心连线垂直,即 ± π 2 \pm\frac{ \pi}{2} ±2π。取正取负仍然是由角速度决定,当角速度为逆时针时,则角度值应当加 π 2 \frac{ \pi}{2} 2π,反之则减。

// 获取线速度和角速度
double linear_velocity = vel;
double angular_velocity = rad;
// 计算每个轮子的转向角度
//这里得到的是轮子指向瞬心的角度
double theta_FL = std::atan2(icc_y_ - FL_y, icc_x_ - FL_x);
double theta_FR = std::atan2(icc_y_ - FR_y, icc_x_ - FR_x);
double theta_BL = std::atan2(icc_y_ - BL_y, icc_x_ - BL_x);
double theta_BR = std::atan2(icc_y_ - BR_y, icc_x_ - BR_x);

//加减pi/2代表轮子的方向
if(rad>0)
{
    theta_FL -= 3.1415926/2;
    theta_FR -= 3.1415926/2;
    theta_BL -= 3.1415926/2;
    theta_BR -= 3.1415926/2;
}
else{
    theta_FL += 3.1415926/2;
    theta_FR += 3.1415926/2;
    theta_BL += 3.1415926/2;
    theta_BR += 3.1415926/2;
}

3、完整测试

运行上述完整代码并发布对应位置的数据,为了直观表示,对于舵轮的角度采用pose表示,对于瞬心采用point表示,使用rviz可以得到如下测试结果:
在这里插入图片描述
图中红色框为当前机器人位置,绿色框为机器人的运动趋势,红色箭头则表示当前右前轮与左后轮两个轮子的计算角度,右侧紫色球体为当前的瞬心,由于原素材中Y方向没有速度,所以瞬心在Y轴上,但是总体还是能体现出瞬心与轮子的角度间的关系的。

参考:
四驱四转移动机器人运动模型及应用分析
常见移动机器人运动学模型总结
四轮驱动(SSMR)移动机器人运动模型及应用分析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2187334.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IP6537_C_30W20V--移动设备快充的得力助手,集成 14 种快充协议的降压 SoC

IP6537_C_30W20V是一款集成同步开关的降压转换器、支 持 14 种输出快充协议、支持 Type-C 输出和 USB PD2.0/PD3.0(PPS)协议的 SoC,为车载充电器、 快充适配器、智能排插提供完整的解决方案。 IP6537_C_30W20V支持 USB Type-C 或者 USB A 输出, 5V 输出功…

火语言RPA流程组件介绍--模拟键盘输入

🚩【组件功能】:在浏览器网页中使用键盘操作模拟输入值 配置预览 配置说明 按键间隔(ms) 支持T或# 输入仅支持整型 两次输入按键的间隔,单位毫秒 输入内容 支持T或# 默认FLOW输入项 需要输入的内容 超时时间 支持T或# 输入仅支持整型 输入的超时时…

我们的赞赏码

每一位粉丝的认可,都是我们前进的动力。欢迎为我们点赞、转发和分享,让我们一起传递美好与快乐! 我们真诚地邀请您来赞赏我们,您的认可是我们前进的动力! 赞赏我们只要0.99,让我们一起在CSDN增长知识&…

OpenAI 开发者大会!实时语音功能有API了,GPT-4o支持多模态微调,上下文cache功能上线

家人们!十一假期第1天, OpenAI一年一度的开发者大会又来了惹!今年的开发者大会分成三部分分别在美国、英国、新加坡三个地点举办,刚刚结束的是第一场。 去年的OpenAI开发者大会公布了GPT-4 Turbo和GPTs,今年没有大更新…

【硬件模块】SG90舵机模块

SG90舵机模块实物图 180度舵机:可以控制旋转角度、有角度定位。上电后舵机自动复位到0度,通过一定参数的脉冲信号控制它的角度。 360舵机:不可控制角度,只能控制顺时针旋转、逆时针旋转、停止和调节转速。 如图所示为:…

仅用pygame+python实现植物大战僵尸-----完成比完美更重要

前言 其实这个项目再我上半年就想着做一下的,但是一直拖到现在,我现在深刻的理解到,不要想那么多,先做,因为永远不可能准备好,都是边做边学便准备的,完成比完美更重要;使用python&a…

【YOLO学习】YOLOv2详解

文章目录 1. 概述2. Better2.1 Batch Normalization(批归一化)2.2 High Resolution Classifier(高分辨率分类器)2.3 Convolutional With Anchor Boxes(带有Anchor Boxes的卷积)2.4 Dimension Clusters&…

每日一题|1928. 规定时间内到达终点的最小花费|动态规划、最小路径

本题需要使用动态规划进行解决。 分析: 求解最小值而且每一次的状态是由上一次的状态推导出来的,用动态规划。 难点:dp数组的定义和更新。 1、dp数组的定义 在时刻t,位置i处,此时的花费可以表示为如下的形式&#…

CNN卷积神经网络算法原理

全连接神经网络概述 输入层在左点自外,相应的输出层在右点之外, 这就像一个函数,yf(x),x即输入,f即隐藏层,y即输出,或者是ymodel(x) 全连接神经网络的结构单元 主要是从单元到整体&#xff0c…

杀疯啦!yolov11+strongsort的目标跟踪实现

目录 yolov11介绍——实时端到端物体检测 概述 主要特征 支持的任务和模式 性能指标 总结 strongsort介绍 指标图 系统定位 效果展示 训练与预测 UI设计 界面其他功能展示 完整代码实现UI界面 yolov11介绍——实时端到端物体检测 概述 YOLO11 是 Ultralytics Y…

基于yolov5 无人机检测包含:数据集➕训练好的代码模型训练了300轮 效果看下图 map97%以上

基于yolov5 无人机检测包含:数据集➕训练好的代码模型训练了300轮 效果看下图 map97%以上 基于YOLOv5的无人机检测项目 项目名称 基于YOLOv5的无人机检测 (Drone Detection with YOLOv5) 项目概述 该项目使用YOLOv5模型进行无人机目标检测。数据集包含大量带有标注的无人机…

wsl中安装ubuntu,vscode访问这个ubuntu

WSL1升级为WSL2 wsl --set-default-version 2 wsl --set-version Ubuntu-22.04 2在windows商店中也可以安装ubuntu,在这个ubuntu中windows的c盘在/mnt/c中

国庆刷题(day2)

C语言刷题: C刷题:

数据结构与算法——Java实现 27.双端队列

很多人觉得做一件事付出了10分的努力,却只得到5分的汇报。 其实剩下的五分,是在填补你过往的懒惰。 只有将过往的懒惰填满, 努力才会有正向结果 —— 24.10.3 一、概述 双端队列、队列、栈对比: 队列 一端删除(头&am…

计算机毕业设计 基于Python的个性化旅游线路推荐系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点…

C++基础补充(02)C++其他控制语句break continue goto等

文章目录 1. break2. continue 语句3. goto 语句goto的存在 4. 跳出多重循环4.1 goto 直接跳转4.2 C11及其后版本的 return 语句4.3 使用标志变量 在C中,控制语句用于管理程序的执行流程。常见有 break、continue 和 goto。 1. break break语句主要用于在循环或者s…

【GEE学习第一期】GEE介绍、注册及基本使用

【GEE学习第一期】GEE介绍、注册及基本使用 GEE基本介绍GEE架构编辑语言:JavaScript GEE注册GEE平台界面GEE编辑器API区详解 GEE环境配置本地Python环境配置在线Python环境配置 参考 GEE基本介绍 地球引擎代码编辑器(Google Earth Engine, GEE&#xff…

oauth2授权码模式单点登录

文章目录 前言一、单点登录是什么?二、oauth2授权码模式单点登录流程1.流程图2. 代码相关2. 验证流程 总结 前言 oauth2 有四种模式,常用的为密码和授权码,剩下两种几乎不用 密码模式,很好理解,就是根据输入的用户名/密码进行登录认证的,最终返回一个合法token授权…

Coze:如何使用主页对话框?

你好,我是三桥君 我们今天要介绍的功能模块是“主页对话框”。 目录 访问官网 登录首页 基本功能 主页对话框 第一个功能:如何与自己收藏的机器人进行对话? 第二个功能:如何请求主页对话框的机器人帮助创建一个新的机器人&#x…

C++11 异步操作 std::future类

阅读导航 引言一、异步的概念二、应用场景1. 异步任务处理2. 并发控制3. 结果获取 三、使用示例1. 使用std::async关联异步任务💻示例代码说明 2. 使用std::packaged_task和std::future配合(1)定义std::packaged_task(2&#xff0…