S形曲线加减速算法流程--7段式

7段S形加减速的算法流程.
7段S形加减速相对于5段,增加了匀加速过程,计算流程更加复杂一些,需要进行多次分类讨论。

加减速规划的流程:

曲线加减速规划是否存在匀速段取决于速度达到给定的指令速度口时,加速段和减速段位移之和s'是否小于待插补位移s.
加速及减速过程中是否存在匀加速段或匀减速段则由vs,ve,v,a,j决定。
规划后的S曲线可能出现下图中8中情况:

在这里插入图片描述

1.匀加速段存在的条件

若:

v − v s > a m 2 / j m v-v_s > a^2_m/j_m vvs>am2/jm

则:

{ t 1 = a m / j m t 2 = ( v − v s ) / a m − t 1 t 3 = t 1 \begin{cases} t_1 & = a_m/j_m \\ t_2 & = (v-v_s)/a_m-t_1 \\ t_3 & = t_1 \\ \end{cases} t1t2t3=am/jm=(vvs)/amt1=t1

若:

v − v s ≥ a m 2 / j m v-v_s \ge a^2_m/j_m vvsam2/jm

则:

{ t 1 = ( v − v s ) / j m t 2 = 0 t 3 = t 1 a m = ( v − v s ) / j m \begin{cases} &t_1 = \sqrt{(v-v_s)/j_m} \\ &t_2 = 0 \\ &t_3 = t_1\\ &a_m = \sqrt{(v-v_s)/j_m} \end{cases} t1=(vvs)/jm t2=0t3=t1am=(vvs)/jm

使用上述计算得到的参数,计算加速段位移,记为:

S a c S_{ac} Sac

按照相同的过程,可以计算减速段位移,记为:

S d e S_{de} Sde

2.匀速段存在的条件

若:

S a c + S d e < S S_{ac} + S_{de} < S Sac+Sde<S

则:

t 4 = ( S − S a c − S d e ) / v t_4 = (S - S_{ac} - S_{de})/v \\ t4=(SSacSde)/v

若:

S a c + S d e ≥ S S_{ac} + S_{de} \ge S Sac+SdeS

则:

t 4 = 0 实 际 能 达 到 的 最 大 速 度 小 于 v t_4 = 0\\ 实际能达到的最大速度小于v t4=0v

3.不存在匀速段

假设:

v m a x = m a x ( v s , v e ) + a m 2 / j m v_{max} = max(v_s,v_e)+a^2_m/j_m vmax=max(vs,ve)+am2/jm

取 v s , v e 中 较 大 的 速 度 计 算 , 带 入 步 骤 1 中 , 得 到 加 减 速 总 位 移 S m 取v_s,v_e中较大的速度计算,带入步骤1中,得到加减速总位移S_m vsve1Sm

若:

S m < S S_m < S Sm<S

则:

实 际 最 大 速 度 : v ′ = − a m 2 / ( 2 ∗ j m ) + a m 4 − 2 ∗ j m ∗ [ a m 2 ∗ ( v s + v e ) − j m ∗ ( v s 2 + v e 2 ) − 2 a m ∗ j m ∗ S ] 2 ∗ j m 实际最大速度:\\ v^{'} = -a^2_m/(2*j_m)+\sqrt{\frac{a^4_m-2*j_m*[a^2_m*(v_s+v_e)-j_m*(v^2_s+v^2_e)-2a_m*j_m*S]}{2*j_m}} :v=am2/(2jm)+2jmam42jm[am2(vs+ve)jm(vs2+ve2)2amjmS]

若:

S m = S S_m = S Sm=S

则 : 实 际 最 大 速 度 就 是 v = v ′ 则:实际最大速度就是v = v^{'} v=v

若:

S m > S S_m > S Sm>S

匀加速段和匀减速段不同时存在,需要重新计算最大速度,
假设:

v ′ ′ = m i n ( v s , v e ) + a m 2 / j m 继 续 根 据 此 最 大 速 度 计 算 加 减 速 总 位 移 S m v^{''} = min(v_s,v_e)+a^2_m/j_m\\ 继续根据此最大速度计算加减速总位移Sm v=min(vs,ve)+am2/jmSm

若:

S m = S 实 际 最 大 速 度 v = v ′ ′ S_m = S 实际最大速度v = v^{''} Sm=Sv=v

若:

S m < S S_m < S Sm<S

则实际只有匀加速段或者匀减速段,需重新计算最大速度,这种情况使用二分法,参考本博客中5段S形加减速中的方法计算即可
若:

S m > S S_m > S Sm>S

则实际不含匀加速段及匀减速段,需重新计算最大速度,这种情况使用二分法,参考本博客中5段S形加减速中的方法计算即可
  • 13
    点赞
  • 101
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
段式S曲线减速算法是一种常用的运动规划方法,可以在保证运动平滑的前提下,实现快速准确的运动控制。下面给出一个在MATLAB中实现五段式S曲线减速算法的示例代码: ``` function [t, q, qd, qdd] = s_curve_trajectory(q0, qf, vmax, amax, Ts) % 五段式S曲线减速算法 % 输入: % q0:起始位置 % qf:终止位置 % vmax:最大速度 % amax:最大速度 % Ts:采样时间 % 输出: % t:时间向量 % q:位置向量 % qd:速度向量 % qdd:速度向量 % 计算位移、速度、速度的变化量 delta_q = qf - q0; delta_qd = vmax^2 / amax; delta_t1 = vmax / amax; delta_t2 = (delta_q - delta_qd) / vmax; delta_t3 = delta_t1; % 计算总时间和采样点数 T = delta_t1 + delta_t2 + delta_t3; N = ceil(T / Ts); % 初始化时间和状态向量 t = linspace(0, T, N); q = zeros(1, N); qd = zeros(1, N); qdd = zeros(1, N); % 五段式S曲线减速运动规划 for i = 1:N if t(i) <= delta_t1 % q(i) = q0 + 0.5 * amax * t(i)^2; qd(i) = amax * t(i); qdd(i) = amax; elseif t(i) <= delta_t1 + delta_t2 % 匀速 q(i) = q0 + delta_qd * (t(i) - delta_t1); qd(i) = vmax; qdd(i) = 0; else % 减速 q(i) = qf - 0.5 * amax * (T - t(i))^2; qd(i) = amax * (T - t(i)); qdd(i) = -amax; end end end ``` 其中,输入参数为起始位置`q0`、终止位置`qf`、最大速度`vmax`、最大速度`amax`和采样时间`Ts`。输出参数为时间向量`t`、位置向量`q`、速度向量`qd`和速度向量`qdd`。 代码中的主要实现思路为:首先计算五段式S曲线减速运动规划中的位移、速度、速度的变化量,然后根据变化量计算总时间和采样点数,并初始化时间和状态向量。接着进行五段式S曲线减速运动规划,分别计算、匀速减速的位置、速度和速度,并将其保存在时间和状态向量中。最后,返回时间和状态向量作为函数的输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值