一文教你快速搞懂 FOC ramp function 斜坡函数的作用和实现
定义
x(t)={0,t<0At,t≥0 x(t) = \begin{cases}
0,t<0\\
At,t \ge 0\\
\end{cases}x(t)={0,t<0At,t≥0
其中A为增益,相当于给定一个速度,在时间 [0,t][0, t ][0,t]期间内,按照A作为加速度,匀加速或者匀减速到速度给定值 vrefv_{ref}vref

如上图所示,这种函数就相当于控制系统中均速变换的位置信号,在三环控制的位置中,相当于这样一个过程;
- 设定最终的位置量为x(t0)x(t_0)x(t0);
- 系统按照A的速度进行均匀的位置变换,A=dxdtA = \cfrac{dx}{dt}A=dtdx;
- 最终到达 t0t_0t0 时刻,系统到达设定的位置x(t0)x(t_{0})x(t0);
同样的,也适用于速度环,对于不同的被控对象,增益AAA的物理意义也不同,但是斜坡函数的最终目的就是让输入信号变得更加平缓,减少系统超调,从而优化系统的时间响应。
进行离散化
将方程进行离散化,按照 △T\bigtriangleup_{T}△T的时间采样,那么可以将输入离散化:
x(i)={0,i<0Ai,i≥0 x(i) = \begin{cases}
0,i<0\\
Ai,i \ge 0\\
\end{cases}x(i)={0,i<0Ai,i≥0

程序的实现
首先这里简单讲一下斜坡函数实现的思路:
- 采样时间,需要根据采样时间对系统进行离散;
- 当前值,系统当前状态被控量的值,即 x(i)x(i)x(i);
- 目标值,系统最终期望到达的值,即x(i0)x(i_0)x(i0);
- 延迟时间,系统到达目标值所需要的时间;
- 步数,系统达到目标值的步数,通常为 i=tdelay△Ti = \cfrac{t_{delay}}{\bigtriangleup_{T}}i=△Ttdelay;
- 斜率,斜率为 Xtarget−Xinitalstep\cfrac{X_{target} - X_{inital}}{step}stepXtarget−Xinital,也就是每一步需要增加的值,最终一步一步增加到目标值;
通常在实际控制系统中,在定时器中断或者事件函数中,需要根据系统当前值,目标值,和延迟时间进行一次计算,得到斜坡函数需要执行的步数和斜坡函数的斜率。
下面用matlab先用模拟一下斜坡函数的生成,另外实际测试了一下C语言在实际硬件上的运行情况。
matlab 程序
以下程序模拟了采样时间为1,并且在delay时间(delay为sample_time的整数倍)之后最终到达target,具体程序如下所示;
function ramp_func()
%采样时间为1
sample_time = 1;
current = 0;
%到达目标值期望的时间
delay = 10;
%需要步数
step = delay/sample_time;
fprintf('step:%d\n',step);
%目标值
target = 20;
%斜率 增益A
inc_dec = (target - current)/step;
output = 1:1:step;
i=1;
while i <= step
output(i) = current + inc_dec;
current = output(i);
fprintf('output(%d):%d\n',i,output(i));
i = i+1;
end
plot(output);
end
最终的运行结果如下;


C语言程序
下面是一个速度的斜坡函数,相关参数封装到speed_ramp_mod中,具体如下所示;
struct speed_ramp_mod{
int16_t target_val; //目标参考值
int16_t present_ref; //当前参考值
int16_t step_val; //当前参考值到目标参考值所需要的步数
int16_t inc_val; //步长/斜率
int16_t freq_hz; //速度环频率
};
typedef struct speed_ramp_mod speed_ramp_mod_t;
speed_ramp_mod_t user_ramp = {
.target_val = 0, //目标参考值
.present_ref = 0, //当前参考值
.step_val = 0, //当前参考值到目标参考值所需要的步数
.inc_val = 0, //步长
.freq_hz = RAMP_SPEED_FREQ //速度采样频率
};
int16_t speed_ramp_calc(speed_ramp_mod_t *p){
int32_t ref;
ref = p->present_ref;
if(p->step_val > 1){
ref += p->inc_val;
p->step_val--;
}else if(p->step_val == 1){
ref = p->target_val;
p->step_val = 0;
}else{
/**
Do Nothing
*/
}
p->present_ref = ref;
return ref;
}
uint8_t speed_ramp_exec(speed_ramp_mod_t *p,int16_t target_val,int16_t durationms){
int32_t inc = 0;
int16_t ref = 0;
ref = p->present_ref;
if(durationms == 0){
p->step_val = 0;
p->inc_val = 0;
p->present_ref = target_val;
}else{
p->target_val = target_val;
//计算步长度
p->step_val = (int32_t)durationms*p->freq_hz / 1000;
p->inc_val = (p->target_val - ref)/p->step_val;
}
}
uint8_t speed_ramp_completed(speed_ramp_mod_t *p){
uint8_t retval = 0;
if(p->step_val == 0){
retval = 1;
}
return retval;
}
void speed_ramp_stop(speed_ramp_mod_t *p){
p->step_val = 0;
p->inc_val = 0;
}
下面是测试程序,可以将程序放到定时器中进行周期性执行;
int16_t spd_ref = 0;
int16_t speed_ramp_ref = 0;
int16_t rpm_speed_set = 0;
void test(void){
if(speed_ramp_completed(&user_ramp)){
speed_ramp_exec(&user_ramp,rpm_speed_set,USER_RAMP_DELAY);
}
speed_ramp_ref = speed_ramp_calc(&user_ramp);
printf("%d\r\n", speed_ramp_ref);
}
最终给定的速度曲线和实际的速度采样曲线如下图所示;

一文教你快速搞懂 FOC ramp function 斜坡函数的作用和实现的更多相关文章
- 一文教你快速搞懂速度曲线规划之S形曲线(超详细+图文+推导+附件代码)
本文介绍了运动控制终的S曲线,通过matlab和C语言实现并进行仿真:本文篇幅较长,请自备茶水: 请帮忙点个赞
- 一文教你快速搞懂速度曲线规划之T形曲线(超详细+图文+推导+附件代码)
运动控制中常用的T速度曲线规划的原理和程序实现,最后给出了测试结果: 如果本文帮到了您,请帮忙点个赞
- 一文带你快速搞懂动态字符串SDS,面试不再懵逼
目录 redis源码分析系列文章 前言 API使用 embstr和raw的区别 SDSHdr的定义 SDS具体逻辑图 SDS的优势 更快速的获取字符串长度 数据安全,不会截断 SDS关键代码分析 获取 ...
- 一篇文章快速搞懂Qt文件读写操作
导读:Qt当中使用QFile类对文件进行读写操作,对文本文件也可以与QTextStream一起使用,这样读写操作会更加简便.QFileInfo可以用来获取文件的信息.QDir可以用于对文件夹进行操作. ...
- android基于口令加密快速搞懂(一)
import java.util.Random; import javax.crypto.Cipher;import javax.crypto.SecretKey;import javax.crypt ...
- [转]快速搞懂Gson的用法
原文地址:http://coladesign.cn/fast-understand-the-usage-of-gson/ 谷歌gson这个Java类库可以把Java对象转换成JSON,也可以把JSON ...
- 一文快速搞懂MySQL InnoDB事务ACID实现原理(转)
这一篇主要讲一下 InnoDB 中的事务到底是如何实现 ACID 的: 原子性(atomicity) 一致性(consistency) 隔离性(isolation) 持久性(durability) 隔 ...
- 一文教你快速读懂MQTT网关
MQTT是一种发布(publish)/订阅(subscribe)协议,MQTT协议采用发布/订阅模式,所有的物联网终端都通过TCP连接到云端,云端通过主题的方式管理各个设备关注的通讯内容,负责将设备与 ...
- 一篇文章快速搞懂Redis的慢查询分析
什么是慢查询? 慢查询,顾名思义就是比较慢的查询,但是究竟是哪里慢呢?首先,我们了解一下Redis命令执行的整个过程: 发送命令 命令排队 命令执行 返回结果 在慢查询的定义中,统计比较慢的时间段指的 ...
随机推荐
- SpeedButton
SpeedButton是一个图形控件,本身没有句柄.因此它不能具有焦点.你可以使用TBitBtn,调整一些属性,可以使他们的外形很接近. 只有从TWinControl派生的控件,才具有Handle.你 ...
- 漫谈LiteOS-Huawei_IoT_Link_SDK_OTA 开发指导
1概述 在应用升级过程中,无线下载更新(OTA)是一种常用,且方便的升级方式.Liteos采用的OTA升级方案基于LwM2M协议,实现了固件升级(FOTA)和软件升级(SOTA)两种升级方案.用户可根 ...
- Python巩固 - 第N天
一.函数解释: def fact(n, m = 1): s = 1 for j in range(1, n+1): s = s*j return n, m, s//m print(fact(10, 5 ...
- Python - 生成随机验证码的3种实现方式
生成6位随机验证码的3种实现方式如下: 1. 简单粗暴型:所有数字和字母都放入字符串: 2. 利用ascii编码的规律,遍历获取字符串和数字的字符串格式: 3. 引用string库. 方法1代码: i ...
- <algorithm>中常用函数
先说一下STL操作的区间是 [a, b),左边是闭区间,右边是开区间,这是STL的特性,所以<algorithm>里面的函数操作的区间也都是 [a, b). 先声明一下, sort()函数 ...
- 2019-2020-1 20199310《Linux内核原理与分析》第四周作业
1.问题描述 在前面的文章中,已经接触过一些Linux内核的知识,本文将进一步从Linux内核源代码的目录结构入手,在Oracle VM VirtualBox的Linux环境中构造一个简单的操作系统M ...
- (五)PL/SQL条件控制
简述 决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. PL/SQL编程语言提供了以下几 ...
- 修改CENTOS7的网卡ens33修改为eth0
1.先编辑网卡的配置文件将里面的NAME DEVICE项修改为eth0 vim /etc/sysconfig/network-scripts/ifcfg-ens33 2.[root@linux-nod ...
- JAVA企业级应用TOMCAT实战(一)
一. Tomcat简介 Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache.Sun和其他一些公司及个人共 ...
- Scala教程之:Scala基础
文章目录 常量 变量 代码块 函数 方法 类 case类 对象 trait main方法 这篇文章我们大概过一下Scala的基础概念,后面的文章我们会有更详细的讲解Scala的具体内容. 常量 在Sc ...