系统因果性

2024-06-23 21:20
文章标签 系统 因果性

本文主要是介绍系统因果性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、因果系统的定义
若系统当前输出仅由系统当前或过去的输入决定,则称该系统为因果系统。由于因果系统是物理课实现的,且具有稳定性和可预测性,所以得到广泛应用。设系统输入、输出分别为 x ( t ) x(t) x(t) y ( t ) y(t) y(t),系统冲激响应为 h ( t ) h(t) h(t)。则
y ( t ) = x ( t ) ∗ h ( t ) = ∫ τ h ( τ ) x ( t − τ ) d τ y(t)=x(t)*h(t)=\int_\tau h(\tau)x(t-\tau)d\tau y(t)=x(t)h(t)=τh(τ)x(tτ)dτ
 如果系统满足因果性,则 y ( t ) y(t) y(t) x ( t − τ ) x(t-\tau) x(tτ)决定,这意味着,系统冲激响应需满足:
h ( t ) = 0 , t < 0 h(t)=0, t<0 h(t)=0,t<0
 下图给出了不同系统冲激响应示意图,显然只有红色曲线对应的冲激响应才满足因果系统条件。
在这里插入图片描述

图1. 因果冲激响应示意图

2、因果系统频响需满足的条件
  从上面的分析可知,因果系统的冲激响应满足 h ( t ) = 0 , t < 0 h(t)=0,t<0 h(t)=0,t<0,它可以进一步表示为:
h ( t ) = h ( t ) s i g n ( t ) (1) h(t)=h(t)sign(t) \tag{1} h(t)=h(t)sign(t)(1)
  其中, s i g n ( t ) = { 1 , t ≥ 0 0 , t < 0 sign(t)=\left\{\begin{matrix}\ 1,t\geq 0 \\ 0,t<0\\ \end{matrix}\right. sign(t)={ 1,t00,t<0为符号函数。对 h ( t ) h(t) h(t)进行傅里叶变换,得到系统频响,此时有:
H ( ω ) = F ( h ( t ) s i g n ( t ) ) = 1 2 π F ( h ( t ) ) ∗ F ( s i g n ( t ) ) = 1 2 π H ( ω ) ∗ 2 j ω = 1 j π ∫ − ∞ ∞ H ( ω ′ ) ω − ω ′ d ω ′ (2) H(\omega)=\mathcal{F}(h(t)sign(t))=\frac{1}{2\pi}\mathcal{F}(h(t))*\mathcal{F}(sign(t))=\frac{1}{2\pi}H(\omega)* \frac{2}{j\omega}=\frac{1}{j\pi}\int_{-\infty}^{\infty} \frac{H(\omega')}{\omega - \omega'}d\omega' \tag{2} H(ω)=F(h(t)sign(t))=2π1F(h(t))F(sign(t))=2π1H(ω)2=1ωωH(ω)dω(2)
  令 H ( ω ) = U ( ω ) + j V ( ω ) H(\omega)=U(\omega)+j V(\omega) H(ω)=U(ω)+jV(ω),将其带入(2)中,可得:
H ( ω ) = U ( ω ) + j V ( ω ) = 1 j π ∫ − ∞ ∞ U ( ω ′ ) + j V ( ω ′ ) ω − ω ′ d ω ′ = 1 j π ∫ − ∞ ∞ U ( ω ′ ) ω − ω ′ d ω ′ + 1 j π ∫ − ∞ ∞ j V ( ω ′ ) ω − ω ′ d ω ′ = 1 π ∫ − ∞ ∞ V ( ω ′ ) ω − ω ′ d ω ′ − j 1 π ∫ − ∞ ∞ U ( ω ′ ) ω − ω ′ d ω ′ H(\omega)=U(\omega)+j V(\omega)=\frac{1}{j\pi}\int_{-\infty}^{\infty} \frac{U(\omega')+j V(\omega')}{\omega - \omega'}d\omega' \\=\frac{1}{j\pi}\int_{-\infty}^{\infty} \frac{U(\omega')}{\omega - \omega'}d\omega'+\frac{1}{j\pi}\int_{-\infty}^{\infty} \frac{j V(\omega')}{\omega - \omega'}d\omega' \\=\frac{1}{\pi}\int_{-\infty}^{\infty} \frac{V(\omega')}{\omega - \omega'}d\omega'-j\frac{1}{\pi}\int_{-\infty}^{\infty} \frac{U(\omega')}{\omega - \omega'}d\omega' H(ω)=U(ω)+jV(ω)=1ωωU(ω)+jV(ω)dω=1ωωU(ω)dω+1ωωjV(ω)dω=π1ωωV(ω)dωjπ1ωωU(ω)dω
  从上式可得:
U ( ω ) = 1 π ∫ − ∞ ∞ V ( ω ′ ) ω − ω ′ d ω ′ V ( ω ) = − 1 π ∫ − ∞ ∞ U ( ω ′ ) ω − ω ′ d ω ′ U(\omega) = \frac{1}{\pi}\int_{-\infty}^{\infty} \frac{V(\omega')}{\omega - \omega'}d\omega' \\ V(\omega)=-\frac{1}{\pi}\int_{-\infty}^{\infty} \frac{U(\omega')}{\omega - \omega'}d\omega' U(ω)=π1ωωV(ω)dωV(ω)=π1ωωU(ω)dω
 从上面的式子可知,因果系统频响的实部和虚部并不是相互独立的,由实部可以推出虚部,同样由虚部也可以推出实部。这称为Kramers-Kroningt条件。

3、时延因果系统
  上面讨论的均是无时延的因果系统,实际系统一般都是有时延的。设系统时延为 τ \tau τ,若该系统具备因果性,则需满足:
h ( t ) = 0 , t < τ h(t)=0,t<\tau h(t)=0,t<τ
  若 H ( ω ) H(\omega) H(ω)为对应 h ( t ) h(t) h(t)的频响,则 h ( t − τ ) → H ( ω ) e − j ω τ h(t-\tau) \rightarrow H(\omega)e^{-j\omega \tau} h(tτ)H(ω)eτ。此时其对应的Kramers-Kroningt条件为
R e ( H ( ω ) e − j ω τ ) = U ( ω ) c o s ( ω τ ) + V ( ω ) s i n ( ω τ ) = 1 π ∫ − ∞ ∞ I m ( H ( ω ′ ) e − j ω ′ τ ) ω − ω ′ d ω ′ I m ( H ( ω ) e − j ω τ ) = V ( ω ) c o s ( ω τ ) − U ( ω ) s i n ( ω τ ) = − 1 π ∫ − ∞ ∞ R e ( H ( ω ′ ) e − j ω ′ τ ) ω − ω ′ d ω ′ Re(H(\omega)e^{-j\omega \tau})=U(\omega)cos(\omega \tau)+V(\omega)sin(\omega \tau)= \frac{1}{\pi}\int_{-\infty}^{\infty} \frac{Im(H(\omega')e^{-j\omega' \tau})}{\omega - \omega'}d\omega' \\ Im(H(\omega)e^{-j\omega \tau})=V(\omega)cos(\omega \tau)-U(\omega)sin(\omega \tau)= -\frac{1}{\pi}\int_{-\infty}^{\infty} \frac{Re(H(\omega')e^{-j\omega' \tau})}{\omega - \omega'}d\omega' \\ Re(H(ω)eτ)=U(ω)cos(ωτ)+V(ω)sin(ωτ)=π1ωωIm(H(ω)ejωτ)dωIm(H(ω)eτ)=V(ω)cos(ωτ)U(ω)sin(ωτ)=π1ωωRe(H(ω)ejωτ)dω
  上面的表达式相对比较复杂,在实际计算中由于各种非理想因素或计算误差的影响,可能导致一个因果系统的也无法完全满足上面的条件。为此,需要对系统的因果性进行评估,必要时需要对系统响应进行处理,保证足够的因果性。

4、因果性大小的计算
  如下图所示,因果性通常用系统时延 τ \tau τ以前的冲激响应围成的面积和总面积的比值来衡量,具体地:
N o n C a u s a l i t y ( h ) = ∫ − ∞ τ h 2 ( t ) d t ∫ − ∞ ∞ h 2 ( t ) d t NonCausality(h)=\frac{\sqrt{\int_{-\infty}^\tau h^2(t)dt}}{\sqrt{\int_{-\infty}^{\infty}h^2(t)dt}} NonCausality(h)=h2(t)dt τh2(t)dt
在这里插入图片描述

图2. 因果性判断示意图

  考虑到除了冲激响应外,阶跃响应、脉冲响应等不同类型的响应也经常用到,类似地可以定义这些类型的响应的因果性衡量指标,具体地:
N o n C a u s a l i t y ( r ) = ∫ − ∞ τ r 2 ( t ) d t ∫ − ∞ ∞ r 2 ( t ) d t NonCausality(r)=\frac{\sqrt{\int_{-\infty}^\tau r^2(t)dt}}{\sqrt{\int_{-\infty}^{\infty}r^2(t)dt}} NonCausality(r)=r2(t)dt τr2(t)dt
  其中, r ( t ) = h ( t ) ∗ v ( t ) r(t)=h(t)*v(t) r(t)=h(t)v(t) v ( t ) v(t) v(t)表示阶跃信号或脉冲信号。
  用不同响应来计算因果性程度可能会得到明显不同的结果,如下图所示,红色表示系统的冲激响应,蓝色表示系统的脉冲响应。根据冲激响应计算得到的非因果度是11%,而根据脉冲响应计算得到的非因果度是0.01%。这说明有大约11%的非因果性是来源于系统的高频响应的(高于信号波特率),所以当要求系统工作在低频时,可以大致认为系统是因果的。
在这里插入图片描述

图3. 不同响应判断因果性的差异示意图

5、强制因果操作
  我们期望系统满足因果性,因为这样的系统是物理可实现的,具有稳定性且可预测。但是实际处理时,由于各种非理想因素的影响,导致系统无法完全满足因果性,此时往往需要通过一些处理手段,强制系统满足因果性。下面介绍常用的时域和频域方法。
5.1、频域方法
  频域方法的基本思路是基于Kramers-Kroningt条件构造满足要求的系统频响的实部和虚部。具体地,包含以下步骤:
(1)估计和补偿系统时延 τ \tau τ,即
H 1 ( ω ) = H ( ω ) e − j ω τ = U ( ω ) + j V ( ω ) H_1(\omega)=H(\omega)e^{-j\omega \tau}=U(\omega)+jV(\omega) H1(ω)=H(ω)eτ=U(ω)+jV(ω)
(2) 求系统频响的实部,并根据Kramers-Kroningt条件 V ( ω ) = − 1 π ∫ − ∞ ∞ U ( ω ′ ) ω − ω ′ d ω ′ V(\omega)=-\frac{1}{\pi}\int_{-\infty}^{\infty} \frac{U(\omega')}{\omega - \omega'}d\omega' V(ω)=π1ωωU(ω)dω利用系统实部构造系统虚部,该表达式本质上就是对实部进行希尔伯特变换。
(3) 将变换后的实部/虚部重新组合成完成频响,则该频响即满足因果性。

5.2、时域方法

未完待续…
未完待续…
未完待续…

这篇关于系统因果性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序