匿名
未登录
创建账户
登录
ENPG_Wiki
搜索
查看“非线性系统最优估计”的源代码
来自ENPG_Wiki
名字空间
页面
讨论
更多
更多
页面选项
阅读
查看源代码
历史
←
非线性系统最优估计
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
<blockquote>为什么处理线性系统,原因很简单,因为我们只会解它——费曼</blockquote>线性系统的最优估计可以通过卡尔曼滤波来快速精确处理(它是递推的),而非线性系统就难很多。 对于非线性系统,我们先分别就离散系统和连续系统介绍其最优估计的精确解(即贝叶斯估计,但这一般是没法直接实际使用的),然后介绍扩展卡尔曼滤波、Unscented卡尔曼滤波和粒子滤波这三种实用的处理方法 == 离散—非线性系统最优估计 == === 问题表述 === ==== 状态方程和观测方程 ==== 假设离散非线性系统的状态方程和观测方程为 \[ \begin{align} \vec{x}_{k+1} & = \vec{f}(\vec{x}_{k},\vec{u}_k,k) + \vec{w}_{k+1} \\ \vec{z}_k & = \vec{h}(\vec{x}_k,k) + \vec{v}_k \end{align} \] 其中,$$\vec{x} _ k$$为$$n$$维状态向量,$$\vec{u}_k$$为$$r$$维控制向量,$$z_k$$为$$m$$维观测向量。$$\vec{w}_k,\vec{w}_k,\vec{x}_0$$为独立的随机变量。$$\vec{w}_k$$和$$\vec{v}_k$$ 分别为$$n$$,$$m$$维噪声(一般考虑是零均值高斯白噪声),其概率密度分别为$$P_w(\vec{w}_k)$$和$$P_v(\vec{v}_k)$$。初始状态$$\vec{x}_0$$的概率密度函数为$$P_x(\vec{x}_k)$$。 假设在$$k$$时刻已经获得实时信息$$\mathrm{Z}^*(k)=\{\mathrm{Z}_1^k,\mathrm{U}_1^{k-1}\}$$,其中$$\mathrm{Z}_1^k=\{\vec{z}_1,\cdots,\vec{z}_k\}, \mathrm{U}_1^k=\{\vec{u}_1,\cdots,\vec{u}_k\}$$ ==== 贝叶斯估计 ==== 贝叶斯估计,即在给定$$k$$时刻实时信息$$\mathrm{Z}^*(k)$$的情况下,求出状态$$\vec{x}_k$$的条件概率密度 \[ p(\vec{x}|\mathrm{Z}^*(k)) \] $$\vec{x}_k$$的条件期望也就是在实时信息下$$\vec{x}_k$$的最小方差估计,即 $$\newcommand{\d}{\mathrm{d}}$$ \[ \hat{\vec{x}}_{k|k} = E[\vec{x}_k|\mathrm{Z}^*(k)] = \int_{-\infty}^\infty \vec{x}_k p(\vec{x}|\mathrm{Z}^*(k)) \d\vec{x}_k \] 而估计误差$$ \tilde{\vec{x}}_k \equiv \vec{x}_k - \hat{\vec{x}}_{k|k} $$ 的条件协方差矩阵为 \[ \begin{align} \mathrm{P}_{k|k} = Cov[\tilde{\vec{x}}_k,\tilde{\vec{x}}_k|\mathrm{Z}^*(k)] = \int_{-\infty}^\infty (\vec{x}_k - \hat{\vec{x}}_{k|k})(\vec{x}_k - \hat{\vec{x}}_{k|k})^T p(\vec{x}|\mathrm{Z}^*(k)) \d\vec{x}_k \end{align} \] 问题归结于,如何递推地求出条件概率密度$$p(\vec{x}|\mathrm{Z}^*(k))$$ === 求解 === 首先根据状态方程和测量方程有: \[ \begin{align} &p(\vec{x}_{k+1}|\vec{x}_{k},\vec{u}_{k}) = p_w(\vec{x}_{k+1} - \vec{f}(k,\vec{x}_k,\vec{u}_k)) \\ &p(\vec{z}_{k+1}|\vec{x}_{k+1}) = p_v(\vec{z}_{k+1} - \vec{h}(k+1,\vec{x}_{k+1})) \end{align} \] 当进行到第$$k$$步,我们有了$$ \mathrm{Z}^{*}(k) $$和$$ \vec{u}_{k} $$后,可以得到$$\vec{x}_{k+1},\vec{z}_{k+1}$$的条件概率('''预测'''): \[ \begin{align} &p(\vec{x}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_{k}) = \int_{-\infty}^\infty p_w(\vec{x}_{k+1} - \vec{f}(k,\vec{x}_k,\vec{u}_k)) p(\vec{x}_{k}|\mathrm{Z}^{*}(k)) \d\vec{x}_{k} \\ &p(\vec{z}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_k) = \int_{-\infty}^\infty p_v(\vec{z}_{k+1}-\vec{h}(k+1,\vec{x}_{k+1}))p(\vec{x}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_{k}) \d\vec{x}_{k+1} \end{align} \] 在进一步得到测量值$$\vec{z}_{k+1}$$后,可以得到$$\vec{x}_{k+1}$$的后验概率: \[ \begin{align} \label{eq:BayesFilter} { \begin{aligned} p(\vec{x}_{k+1}|\mathrm{Z}^{*}(k+1)) &= \frac{p(\vec{x}_{k+1},\vec{z}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_k)} {p(\vec{z}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_k)} \\ &=\frac{p_v(\vec{z}_{k+1} - \vec{h}(k+1,\vec{x}_{k+1})) p(\vec{x}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_{k})} {\int_{-\infty}^\infty p_v(\vec{z}_{k+1}-\vec{h}(k+1,\vec{x}_{k+1}))p(\vec{x}_{k+1}|\mathrm{Z}^{*}(k),\vec{u}_{k}) \d\vec{x}_{k+1} } \end{aligned} } \end{align} \] 上式被称为'''贝叶斯滤波公式''',虽然是直观精确的表达式,但其中每一步的积分都是非常困难的,很可能得不到解析表达式,因而没有重要的应用价值。 == 连续—非线性系统最优估计 == 假设系统的状态方程和观测方程为: \[ \begin{align} & \dot{\vec{x}}(t) = \vec{f}(\vec{x}(t),t)+\mathrm{g}(\vec{x}(t),t) \vec{w}(t) \\ & \vec{z}(t) = \vec{h}(\vec{x}(t),t) + \vec{v}(t) \end{align} \] 其中$$\vec{w}(t)$$和$$\vec{v}(t)$$均为零均值高斯白噪声,且与初始状态$$\vec{x}(t_0)$$不相关,即 \[ \begin{align} & E[\vec{w}(t)] = E[\vec{v}(t)] = 0 \\ & \Cov[\vec{w}(t),\vec{w}(\tau)] = \mathrm{Q}(t)\delta(t-\tau)\\ & \Cov[\vec{v}(t),\vec{v}(\tau)] = \mathrm{R}(t)\delta(t-\tau) \\ & \Cov[\vec{w}(t),\vec{v}(\tau)] = \Cov[\vec{w}(t),\vec{x}(t_0)] = \Cov[\vec{v}(t),\vec{x}(t_0)] = 0 \end{align} \] 状态方程和观测方程也可以改写微分形式: \[ \begin{align} \label{dynamic} & \d\vec{x}(t) = \vec{f}(\vec{x}(t),t)\d t+\mathrm{g}(\vec{x}(t),t) \d \vec{N}(t) \\ \label{measure} & \d\vec{y}(t) = \vec{h}(\vec{x}(t),t)\d t + \d\vec{M}(t) \end{align} \] 其中$$\vec{N}(t),\vec{M}(t),\vec{y}(t)$$满足: \[ \begin{align} & E[\d\vec{M}(t)] = 0, \Var[\d\vec{M}(t)] = \vec{R}(t)\d t \\ & E[\d\vec{N}(t)] = 0, \Var[\d\vec{N}(t)] = \vec{Q}(t)\d t \\ & \d\vec{y}(t) = \vec{z}(t)\d t \end{align} \] 其中\ref{dynamic}是有名的随机微分方程,解为Fokker-Planck方程,于是 \[ \begin{align} p&(\vec{x},t+\d t|\mathrm{Y}^*(t+\d t))- p(\vec{x},t|\mathrm{Y}^*(t)) \\ =& p(\vec{x},t+\d t|\mathrm{Y}^*(t+\d t))-p(\vec{x},t+\d t|\mathrm{Y}^*(t))+ p(\vec{x},t+\d t|\mathrm{Y}^*(t))- p(\vec{x},t|\mathrm{Y}^*(t)) \\ \label{FP_term} =&{\color{blue}{ - \sum_i \frac{\partial}{\partial x_i} [f_i(\vec{x},t)p(\vec{x},t|\mathrm{Y}^*(t))] \d t + \frac{1}{2} \sum_{ij} \frac{\partial^2}{\partial x_i\partial x_j}\{\mathrm{g(\vec{x}(t),t)}\mathrm{Q(t)}\mathrm{g(\vec{x}(t),t)}^T p(\vec{x},t|\mathrm{Y}^*(t)) \} \d t }} \\ \label{Bayes_term} & \color{green}{+ (\vec{h}(\vec{x},t) - E(\vec{h}(\vec{x},t | \mathrm{Y}^*(t)) )^T \mathrm{R}^{-1}(\d\vec{y}(t) - E(\vec{h}(\vec{x},t | \mathrm{Y}^*(t))\d t ) p(\vec{x},t|\mathrm{Y}^*(t)) \} \d t } \end{align} \] 其中\ref{FP_term} 项就对应Fokker-Planck方程,\ref{Bayes_term}项是新观测的信息$$ \d\vec{y}(t) $$带来的,可通过贝叶斯条件概率公式取$$ \d t\to0 $$得到,这一项的证明见([https://epubs.siam.org/doi/pdf/10.1137/0302009 Kushner H J,1964]) 如果能通过上式求得$$p(\vec{x}(t),t|\mathrm{Y}^*(t))$$,则可以得到状态$$\vec{x}(t)$$的最小方差估计也就是关于$$\mathrm{Y}^*(t)$$的条件均值。 == 扩展卡尔曼滤波(EKF) == === 连续-离散型系统 === 实际问题中得到的系统状态模型往往是连续的,而测量方差是离散的,即 \[ \begin{align} \dot{\vec{x}}(t) = \vec{f}(\vec{x}(t),t) + \vec{w}(t) \\ \vec{z}_k = \vec{h}_k(\vec{x}(t_k)) + \vec{v}_k \end{align} \] 由于方程的非线性,导致概率密度函数非常复杂,计算$$p(x,t)$$往往是不现实的,为了得到实用的估计算法,应该采用绕过$$p(x,t)$$来计算$$\vec{x}(t)$$的条件均值和误差协方差矩阵的方法。扩展卡尔曼滤波就是将$$\vec{f},\vec{h}$$在适当位置进行泰勒展开的方法。 先对$$ \vec{f}(\vec{x}(t),t) $$在当前条件均值$$\hat{\vec{x}}(t)$$处泰勒展开: \[ \begin{align} \vec{f}(\vec{x},t) = \vec{f}(\hat{\vec{x}},t) +\frac{\partial f}{\partial x}\bigg|_{\hat{\vec{x}}}(\vec{x} - \hat{\vec{x}})+ \cdots \end{align} \] 记 $$ \mathrm{F}(\hat{\vec{x}},t) = \frac{\partial \vec{f}(\vec{x},t)}{\partial \vec{x}(t)}\bigg|_{\hat{\vec{x}}}$$,其元素$$ \mathrm{F}(\hat{\vec{x}},t)_{ij} = \frac{\partial f_i(\vec{x},t)}{\partial x_j(t)}\bigg|_{\hat{\vec{x}}}$$ 扩展卡尔曼滤波一般将泰勒展开保留至一阶(保留更改多项可推导出更高阶更精确的滤波器,如二阶滤波器),于是对$$t\in[t_{k-1},t_k)$$,也就是两次测量间的动力学阶段,有 \[ \begin{align} \dot{\hat{\vec{x}}}(t) &= \vec{f}(\hat{\vec{x}},t),t\in[t_{k-1},t_k) \\ \dot{\mathrm{P}}(t) &= E[\hat{\vec{x}}(t)-\vec{x}(t)][\hat{\vec{x}}(t)-\vec{x}(t)]^T\\ &= \mathrm{F}(\hat{\vec{x}},t)\mathrm{P}(t) + \mathrm{P}(t)\mathrm{F}^T(\hat{\vec{x}},t) + \mathrm{Q}(t), t\in[t_{k-1},t_k) \end{align} \] 下面建立测量后的修正方程,定义估计$$\hat{\vec{x}}_{k|m}$$,要求估计为线性无偏估计,则有 $$\hat{\vec{x}}_{k|k} = \hat{\vec{x}}_{k|k-1} + \mathrm{K}_{k}[\vec{z}_k - \hat{\vec{h}}_k(\vec{x}_k)] $$, 其中$$\mathrm{K}_k$$为增益矩阵,我们可以要求$$\mathrm{K}_k$$使得估计误差协方差矩阵$$\mathrm{P}_{k|k}$$最小。 先定义 \[ \begin{align} \mathrm{P}_{k|k} &= E[\tilde{\vec{x}}_{k|k}\tilde{\vec{x}}_{k|k}^T]\\ \mathrm{P}_{k|k} &= E[\tilde{\vec{x}}_{k|k-1}\tilde{\vec{x}}_{k|k-1}^T]\\ \mathrm{R}_k &= E[\vec{v}_k\vec{v}_k^T] \end{align} \] 可得 \[ \begin{align} \mathrm{P}_{k|k} = & \mathrm{P}_{k|k-1} + \mathrm{K}_k E\{[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)][\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]^T\}\mathrm{K}_k^T\\ & + E\{\tilde{x}_{k|k-1}[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]^T\}\mathrm{K}_k^T \\ & + \mathrm{K}_k E\{[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]\tilde{x}_{k|k-1}^T\} \\ & + \mathrm{K}_k \mathrm{R}_k \mathrm{K}_k^T \end{align} \] 令$$\mathrm{K}_k$$使得$$Tr[\mathrm{P}_{k|k}]$$最小,即 $$ \frac{\partial Tr[\mathrm{P}_{k|k}] }{\partial \mathrm{K}_k } =0 $$ , 得: \[ \begin{align} \mathrm{K}_k = & -E\{\tilde{x}_{k|k-1}[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]^T\}\\ & \times \{E[[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)][\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]^T] + \mathrm{R}_k \}^{-1} \end{align} \] 注: \[ \begin{align} &\frac{\partial }{\partial \mathrm{A}} Tr(\mathrm{AB}) = \mathrm{B}^T \\ &\frac{\partial }{\partial \mathrm{A}} Tr(\mathrm{BA^T}) = \mathrm{B} \\ &\frac{\partial }{\partial \mathrm{A}} Tr(\mathrm{ABA^T}) = 2\mathrm{AB} \end{align} \] 于是 \[ \begin{align} \mathrm{P}_{k|k} = & \mathrm{P}_{k|k-1} + \mathrm{K}_k E\{[\vec{h}_k(\vec{x}_k)-\hat{\vec{h}}_k(\vec{x}_k)]\tilde{x}_{k|k-1}^T\}\ \end{align} \] 上面的几个式子就构成了新测量量的修正算法。但由于计算$$\hat{\vec{h}}_k(\vec{x}_k)$$要依赖 == Unscented卡尔曼滤波(UKF) == 综上,UKF与EKF相比,有如下优点: 1. 无需计算非线性函数的导数矩阵 2. 可以处理不可导的非线性函数 3. 计算量与EKF相当 4. 对高斯输入的非线性函数近似时,使均值精确到三阶,方差精确到二阶 == 粒子滤波 ==
返回至“
非线性系统最优估计
”。
导航
导航
首页
根目录
最近更改
随机页面
全部页面
如何编辑
MediaWiki帮助
Wiki工具
Wiki工具
特殊页面
页面工具
页面工具
用户页面工具
更多
链入页面
相关更改
页面信息
页面日志