Arduino PID Library
Arduino PID Library
by Brett Beauregard,contact: br3ttb@gmail.com
What Is PID? PID是什么
From Wikipedia: "A PID controller calculates an 'error' value as the difference between a measured [Input] and a desired setpoint. The controller attempts to minimize the error by adjusting [an Output]."
So, you tell the PID what to measure (the "Input",) Where you want that measurement to be (the "Setpoint",) and the variable to adjust that can make that happen (the "Output".) The PID then adjusts the output trying to make the input equal the setpoint.
For reference, in a car, the Input, Setpoint, and Output would be the speed, desired speed, and gas pedal(踏板) angle respectively.
Functions
Description 建立一个PID控制器
Creates a PID controller linked to the specified Input, Output, and Setpoint. The PID algorithm is in parallel form.
Syntax
PID(&Input, &Output, &Setpoint, Kp, Ki, Kd, Direction)
PID(&Input, &Output, &Setpoint, Kp, Ki, Kd, POn, Direction)
Parameters:
Input: The variable we're trying to control (double)
Output: The variable that will be adjusted by the pid (double)
Setpoint: The value we want to Input to maintain (double)
Kp, Ki, Kd: Tuning Parameters. these affect how the pid will chage the output. (double>=0)
Direction: Either DIRECT or REVERSE. determines which direction the output will move when faced with a given error. DIRECT is most common.
POn: Either P_ON_E (Default) or P_ON_M. Allows Proportional on Measurement to be specified.
Returns:None
Description 在loop()中做PID运算
Contains the pid algorithm. it should be called once every loop(). Most of the time it will just return without doing anything. At a frequency specified by SetSampleTime it will calculate a new Output.
Syntax:
Compute()
Parameters:None
Returns:
True: when the output is computed
False: when nothing has been done
Description 工作模式设定(自动/手动)
Specifies whether the PID should be on (Automatic) or off (Manual.) The PID defaults to the off position when created.
Syntax:
SetMode(mode)
Parameters:
mode: AUTOMATIC or MANUAL
Returns:None
Description:输出限幅
The PID controller is designed to vary its output within a given range. By default this range is 0-255: the arduino PWM range. There's no use sending 300, 400, or 500 to the PWM. Depending on the application though, a different range may be desired.
Syntax:
SetOutputLimits(min, max)
Parameters:
min: Low end of the range. must be < max (double)
max: High end of the range. must be > min (double)
Returns:None
Description:PID参数实时调整
Tuning parameters (or "Tunings") dictate(决定) the dynamic behavior of the PID. Will it oscillate or not? Will it be fast or slow? An initial set of Tunings is specified when the PID is created. For most users this will be enough. There are times however, tunings need to be changed during run-time. At those times this function can be called.
Syntax:
SetTunings(Kp, Ki, Kd)
SetTunings(Kp, Ki, Kd, POn)
Parameters:
Kp: Determines how aggressively the PID reacts to the current amount of error (Proportional) (double >=0)
Ki: Determines how aggressively the PID reacts to error over time (Integral) (double>=0)
Kd: Determines how aggressively the PID reacts to the change in error (Derivative) (double>=0)
POn: Either P_ON_E (Default) or P_ON_M. Allows Proportional on Measurement to be specified.
Returns:None
Decription:采样时间设定(毫秒)
Determines how often the PID algorithm evaluates. The default is 200mS. For robotics applications this may need to be faster, but for the most part 200mS is plenty fast.
Syntax:
SetSampleTime(SampleTime)
Parameters:
SampleTime: How often, in milliseconds, the PID will be evaluated. (int>0)
Returns:None
Description: 控制方向设定(正作用/逆作用)
If my Input is above Setpoint, should the output be increased or decreased? Depending on what the PID is connected to, either could be true. With a car, the output should be decreased to bring the speed down. For a refrigerator, the opposite is true. The output (cooling) needs to be increased to bring my temperature down.
This function specifies which type of process the PID is connected to. This information is also specified when the PID constructed. Since it's unlikely that the process will switch from direct to reverse, it's equally unlikely that anyone will actually use this function.
Syntax:
SetControllerDirection(Direction);
Parameters:
Direction:DIRECT (like a car,输出减弱) or REVERSE (like a refrigerator,输出增强)
Returns:None
Decription:PID 参数询问显示
These functions query(询问) the PID internals to get current values. These are useful for display purposes.
GetKp()
GetKi()
GetKd()
GetMode()
GetDirection()
Syntax:
GetKp()
GetKi()
GetKd()
GetMode()
GetDirection()
Parameters:None
Returns:The corresponding internal value
Examples PID控制举例
Basic 模拟量输入控制模拟量输出
1 /********************************************************
2 * PID Basic Example
3 * Reading analog input 0 to control analog PWM output 3
4 ********************************************************/
5 #include <PID_v1.h>
6 //Define Variables we'll be connecting to double Setpoint, Input, Output;
7 //Specify the links and initial tuning parameters
8 PID myPID(&Input, &Output, &Setpoint,2,5,1, DIRECT);
9
10 void setup()
11 {
12 Input = analogRead(0); //initialize the variables we're linked to
13 Setpoint = 100;
14 myPID.SetMode(AUTOMATIC); //turn the PID on
15 }
16
17 void loop()
18 {
19 Input = analogRead(0);
20 myPID.Compute();
21 analogWrite(3,Output);
22 }
AdaptiveTunings 自动调整PID参数
1 /********************************************************
2 * PID Adaptive Tuning Example
3 * One of the benefits of the PID library is that you can
4 * change the tuning parameters at any time. this can be
5 * helpful if we want the controller to be aggressive(进取的) at some
6 * times, and conservative(保守的) at others. in the example below
7 * we set the controller to use Conservative Tuning Parameters
8 * when we're near setpoint and more aggressive Tuning
9 * Parameters when we're farther away.
10 ********************************************************/
11 #include <PID_v1.h>
12 //Define Variables we'll be connecting to double Setpoint, Input, Output;
13 //Define the aggressive and conservative Tuning Parameters
14 double aggKp=4, aggKi=0.2, aggKd=1;
15 double consKp=1, consKi=0.05, consKd=0.25;
16 //Specify the links and initial tuning parameters
17 PID myPID(&Input, &Output, &Setpoint, consKp, consKi, consKd, DIRECT);
18
19 void setup()
20 {
21 Input = analogRead(0); //initialize the variables we're linked to
22 Setpoint = 100;
23 myPID.SetMode(AUTOMATIC); //turn the PID on
24 }
25
26 void loop()
27 {
28 Input = analogRead(0);
29 double gap = abs(Setpoint-Input); //distance away from setpoint
30 if(gap<10)
31 {
32 myPID.SetTunings(consKp, consKi, consKd);
33 //we're close to setpoint, use conservative tuning parameters
34 }
35 Else
36 {
37 myPID.SetTunings(aggKp, aggKi, aggKd);
38 //we're far from setpoint, use aggressive tuning parameters
39 }
40 myPID.Compute();
41 analogWrite(3,Output);
42 }
Arduino PID Library的更多相关文章
- Brett Beauregard大神的Arduino PID算法
大神的全部PID http://brettbeauregard.com/blog/category/pid/ Improving the Beginner’s PID – Introduction I ...
- 手把手教你看懂并理解Arduino PID控制库——引子
介绍 本文主要依托于Brett Beauregard大神针对Arduino平台撰写的PID控制库Arduino PID Library及其对应的帮助博客Improving the Beginner’s ...
- 【技术】Arduino PID自整定库
最近看到了Brett Beauregard发表的有关PID的系列文章,感觉对于理解PID算法很有帮助,于是将系列文章翻译过来!在自我提高的过程中,也希望对同道中人有所帮助.作者Brett Beaure ...
- Arduino LiquidCrystal Library Bug Report #174181
Arduino LiquidCrystal Character LCD Driver Library BUG Report #174181 by Conmajia Effected Devices H ...
- 使用Arduino Wire Library读取温湿度传感器AM2321
AM2321是采用I2C总线或单总线通讯的国产温湿度传感器.在AM2321手册中,当采用I2C通讯时,手册指定了多处需要主机等待的时间间隔,包括: (1)唤醒传感器时,从机不回复ACK,但主机主要等待 ...
- PID控制器(比例-积分-微分控制器)- I
形象解释PID算法 小明接到这样一个任务: 有一个水缸点漏水(而且漏水的速度还不一定固定不变),要求水面高度维持在某个位置,一旦发现水面高度低于要求位置,就要往水缸里加水. 小明接到任务后就一直守在水 ...
- Project 03- STM32F4xx PID controller
Project 03- STM32F4xx PID controller CMSIS files from ARM provides ARM Math functions. There are als ...
- Arduino I2C + 温湿度传感器AM2321
(2015.5.17:本日志的内容有所更新,参见<使用Arduino Wire Library读取温湿度传感器AM2321>.) AM2321是广州奥松电子生产的数字式温湿度传感器.虽是国 ...
- 用Arduino+OSC建立一个iPad铁路王国巡视机
翻译自:http://blog.mydream.com.hk/howto/build-up-a-ipad-plarail-patrol-with-arduino-osc 简单介绍 这个教程告诉你怎样建 ...
随机推荐
- 程序员软件开发最好的IDE集成工具eclipse各个版本的详细介绍。详细介绍,送给初学者的朋友
对于刚接触软件开发的初学者,在下载eclipse时,对官网上面提供的各种版本的选择犹豫不决.下面将对常用的几个版本进行介绍. Eclipse版本 Eclipse Standard 该版本是eclips ...
- Pytest allure自定义特性场景功能
@allure.feature @allure.story allure支持用户对测试用例进行功能模块的自定义,并展示在报告中 需要在测试用例代码中加上装饰器@allure.feature[加在测试类 ...
- python小白入门基础(二:变量)
#变量:可以改变的量就是变量,实际上是由内存开辟的一块空间,临时存在内存中,以便后续代码使用.#作用:代指内存中某个地址中的内容. #1.变量的概念name = "王五"name ...
- Redis数据类型读写语法
---字符类型的用法(语法大小写不做限制)1.创建string字符串写:SET 列名 "键值"读:get 列名特性:可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存 ...
- hadoop不能互相访问和linux防火墙守护进程
前言——作为装过几次集群的菜鸟,对于hadoop集群的安装还是比较有心得的:只要配置文件够好,集群配置就非常容易,否则也容易出现莫名其妙的问题!总结了一份3台机器搭建较完好的集群的一份配置文件. 在我 ...
- fake_useragent.errors.FakeUserAgentError: Maximum amount of retries reached解决方法!
UserAgent 就是用户代理,又叫报头,是一串字符串,相当于浏览器的身份证号,在利用爬虫爬取网站数据时,频繁更换它可以避免触发相应的反爬机制. fake-useragent对频繁更换UserAge ...
- ios网络访问官方演示程序
官方演示程序 AppDelegate 设置缓存 NSURLCache *URLCache = [[NSURLCache alloc] initWithMemoryCapacity:4 * 1024 * ...
- 使用PXE+VNC方式安装CentOS 7
U盘坏了,用个下面的方法安装 安装配置dhcp yum -y install dhcp tftp-server 修改如下,网段改为你自己的网段 vim /etc/dhcp/dhcpd.conf sub ...
- Proxy使用详解
文档:Proxy 基本使用就不赘述,看文档即可 通用 1.Proxy可以包装任何形式的对象:包括原生数组,函数,甚至另一个代理 2.代理实例中没有指定的handler,实际就是操作原对象target: ...
- 正则表达式与SQL
在我心中正则表达式和SQL就是一样的东西. SQL是结构化查询语言,是根据某个查询.修改规则来查询修改数据,是描述一个规则给数据库,数据库来执行, 数据库返回结果,过程不需要考虑,不算是编程语言. 正 ...