侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

python实现PID算法及测试的例子

Python  /  管理员 发布于 7年前   212

PID算法实现

import timeclass PID:  def __init__(self, P=0.2, I=0.0, D=0.0):    self.Kp = P    self.Ki = I    self.Kd = D    self.sample_time = 0.00    self.current_time = time.time()    self.last_time = self.current_time    self.clear()  def clear(self):    self.SetPoint = 0.0    self.PTerm = 0.0    self.ITerm = 0.0    self.DTerm = 0.0    self.last_error = 0.0    self.int_error = 0.0    self.windup_guard = 20.0    self.output = 0.0  def update(self, feedback_value):    error = self.SetPoint - feedback_value    self.current_time = time.time()    delta_time = self.current_time - self.last_time    delta_error = error - self.last_error    if (delta_time >= self.sample_time):      self.PTerm = self.Kp * error#比例      self.ITerm += error * delta_time#积分      if (self.ITerm < -self.windup_guard):        self.ITerm = -self.windup_guard      elif (self.ITerm > self.windup_guard):        self.ITerm = self.windup_guard      self.DTerm = 0.0      if delta_time > 0:        self.DTerm = delta_error / delta_time      self.last_time = self.current_time      self.last_error = error      self.output = self.PTerm + (self.Ki * self.ITerm) + (self.Kd * self.DTerm)  def setKp(self, proportional_gain):    self.Kp = proportional_gain  def setKi(self, integral_gain):    self.Ki = integral_gain  def setKd(self, derivative_gain):    self.Kd = derivative_gain  def setWindup(self, windup):    self.windup_guard = windup  def setSampleTime(self, sample_time):    self.sample_time = sample_time

测试PID算法

import PIDimport timeimport matplotlibmatplotlib.use("TkAgg")import matplotlib.pyplot as pltimport numpy as npfrom scipy.interpolate import spline#这个程序的实质就是在前九秒保持零输出,在后面的操作中在传递函数为某某的系统中输出1def test_pid(P = 0.2, I = 0.0, D= 0.0, L=100):  """Self-test PID class  .. note::    ...    for i in range(1, END):      pid.update(feedback)      output = pid.output      if pid.SetPoint > 0:        feedback += (output - (1/i))      if i>9:        pid.SetPoint = 1      time.sleep(0.02)    ---  """  pid = PID.PID(P, I, D)  pid.SetPoint=0.0  pid.setSampleTime(0.01)  END = L  feedback = 0  feedback_list = []  time_list = []  setpoint_list = []  for i in range(1, END):    pid.update(feedback)    output = pid.output    if pid.SetPoint > 0:      feedback +=output# (output - (1/i))控制系统的函数    if i>9:      pid.SetPoint = 1    time.sleep(0.01)    feedback_list.append(feedback)    setpoint_list.append(pid.SetPoint)    time_list.append(i)  time_sm = np.array(time_list)  time_smooth = np.linspace(time_sm.min(), time_sm.max(), 300)  feedback_smooth = spline(time_list, feedback_list, time_smooth)  plt.figure(0)  plt.plot(time_smooth, feedback_smooth)  plt.plot(time_list, setpoint_list)  plt.xlim((0, L))  plt.ylim((min(feedback_list)-0.5, max(feedback_list)+0.5))  plt.xlabel('time (s)')  plt.ylabel('PID (PV)')  plt.title('TEST PID')  plt.ylim((1-0.5, 1+0.5))  plt.grid(True)  plt.show()if __name__ == "__main__":  test_pid(1.2, 1, 0.001, L=80)#  test_pid(0.8, L=50)

结果

以上这篇python实现PID算法及测试的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


  • 上一条:
    详解python中的index函数用法
    下一条:
    python开头的coding设置方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客