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 v−vs>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=(v−vs)/am−t1=t1
若:
v − v s ≥ a m 2 / j m v-v_s \ge a^2_m/j_m v−vs≥am2/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=(v−vs)/jmt2=0t3=t1am=(v−vs)/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=(S−Sac−Sde)/v
若:
S a c + S d e ≥ S S_{ac} + S_{de} \ge S Sac+Sde≥S
则:
t 4 = 0 实 际 能 达 到 的 最 大 速 度 小 于 v t_4 = 0\\ 实际能达到的最大速度小于v t4=0实际能达到的最大速度小于v
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 取vs,ve中较大的速度计算,带入步骤1中,得到加减速总位移Sm
若:
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/(2∗jm)+2∗jmam4−2∗jm∗[am2∗(vs+ve)−jm∗(vs2+ve2)−2am∗jm∗S]
若:
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/jm继续根据此最大速度计算加减速总位移Sm
若:
S m = S 实 际 最 大 速 度 v = v ′ ′ S_m = S 实际最大速度v = v^{''} Sm=S实际最大速度v=v′′
若:
S m < S S_m < S Sm<S
则实际只有匀加速段或者匀减速段,需重新计算最大速度,这种情况使用二分法,参考本博客中5段S形加减速中的方法计算即可
若:
S m > S S_m > S Sm>S
则实际不含匀加速段及匀减速段,需重新计算最大速度,这种情况使用二分法,参考本博客中5段S形加减速中的方法计算即可