简述模型预测控制——Introduction to Model Predictive Control (MPC)

本文主要是介绍简述模型预测控制——Introduction to Model Predictive Control (MPC),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文简要介绍下模型预测控制的基本原理与简单应用方法。本文针对有一定控制理论背景的读者。

文章目录

  • 最优控制问题
  • 模型预测控制
    • MPC与最优控制
    • 典型的MPC问题
      • 显式MPC

最优控制问题

给定一个系统模型和控制目标,我们往往可以找到无穷多个控制器,使得该系统的输出收敛到控制目标。难么,我们如何从这无穷多个控制器中找到一个最优的呢?这便是最优控制问题。解决最优控制问题,或者说任何最优化问题,我们首先要明确定义一个优化目标,即一个衡量好坏的量化标准。随后,在该标准下找到一个控制器使得优化目标达到最小/最大。

有关优化问题的具体讨论可参考此文。
最优控制问题的具体细节亦可参考此文。

模型预测控制

在这里插入图片描述
模型预测控制(Model Predictive Control, 以下简称 MPC)是以优化方法来求解控制问题,或者说是以优化问题的求解来给出控制信号。如上图所示,MPC包含3个主要成分:模型、预测、控制,均取其字面意思。

MPC与最优控制

一般的最优控制,强调的是整个控制过程(时间域)的最优性。常用的最优控制方法包括变分法极大值原理动态规划。事实上也是常见的优化方法。最优控制问题存在两个挑战:

  1. 具有复杂约束的最优化问题难以求解;
  2. 最优控制要求系统模型精确已知。

针对上述两个挑战,MPC方法退而求其次地仅仅考虑未来有限个控制周期,这样一来最优控制问题便得到了简化,但是也牺牲了一定的最优性。

考虑下输简单离散LTI最优控制问题:
min ⁡ J = ∑ t = 0 ∞ ℓ ( x ( t ) , u ( t ) ) s.t. u ( t ) ∈ U , x ( t ) ∈ X , t = 0 , 1 , 2 , … x ( t + 1 ) = A x ( t ) + B u ( t ) , x ( 0 ) = z \begin{aligned} \min\quad & J = \sum_{t=0}^{\infty}\ell(x(t),u(t)) \\ \text{s.t.}\quad & u(t) \in \mathcal{U}, x(t)\in\mathcal{X}, t= 0,1,2,\dots \\ &x(t+1) = Ax(t) + Bu(t),\\ &x(0) = z \end{aligned} mins.t.J=t=0

这篇关于简述模型预测控制——Introduction to Model Predictive Control (MPC)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/415404

相关文章

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用DrissionPage控制360浏览器的完美解决方案

《使用DrissionPage控制360浏览器的完美解决方案》在网页自动化领域,经常遇到需要保持登录状态、保留Cookie等场景,今天要分享的方案可以完美解决这个问题:使用DrissionPage直接... 目录完整代码引言为什么要使用已有用户数据?核心代码实现1. 导入必要模块2. 关键配置(重点!)3.

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹

Spring Security注解方式权限控制过程

《SpringSecurity注解方式权限控制过程》:本文主要介绍SpringSecurity注解方式权限控制过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、摘要二、实现步骤2.1 在配置类中添加权限注解的支持2.2 创建Controller类2.3 Us

Python中如何控制小数点精度与对齐方式

《Python中如何控制小数点精度与对齐方式》在Python编程中,数据输出格式化是一个常见的需求,尤其是在涉及到小数点精度和对齐方式时,下面小编就来为大家介绍一下如何在Python中实现这些功能吧... 目录一、控制小数点精度1. 使用 round() 函数2. 使用字符串格式化二、控制对齐方式1. 使用