托普利兹矩阵(T矩阵)及其应用(Matlab demo测试)

托普利兹矩阵(T矩阵)及其应用(Matlab demo测试)

  • 1. 概念
  • 2. Matlab简单测试
    • 2.1 生成测试
    • 2.2 基本性质及原理
    • 2.3 性质验证
  • 3. 其他应用总结
    • 3.1 其他性质
    • 3.2 文献阅读看到的
  • 参考资料

1. 概念

托普利兹矩阵,简称为T型矩阵,托普利兹矩阵的主对角线上的元素相等,平行于主对角线的线上的元素也相等;矩阵中的各元素关于次对角线对称,即T型矩阵为次对称矩阵。即 a i j = a j i a_{ij}=a_{ji} aij=aji

2. Matlab简单测试

2.1 生成测试

Matlab中可以用toeplitz(x,y)。它生成一个以 x 为第一列,y 为第一行的托普利兹矩阵。
函数中x=(x1,x2,…,xk) y=(y1,y2,…,yj)为向量形式,代表托普利兹矩阵的第一行、第一列。

x=[1, 2, 3, 3, 4, 4];
y=[1, 3, 3, 2, 3, 4];
T=toeplitz(x,y)

生成结果如下:

ans =1     3     3     2     3     42     1     3     3     2     33     2     1     3     3     23     3     2     1     3     34     3     3     2     1     34     4     3     3     2     1

2.2 基本性质及原理

其中,最基础的性质,是托普利兹矩阵可以表示为前向位移矩阵和后向位移矩阵之和。

  • 前向位移矩阵
    F = ( 0 1 . . . 0 0 . . . . . . . . . . . . . . . . . . 1 0 . . . 0 0 ) ∈ R n × n F=\left( \begin{matrix} 0& 1& ...& 0\\ 0& ...& ...& ...\\ ...& ...& ...& 1\\ 0& ...& 0& 0\\ \end{matrix} \right) \in \mathbb{R} ^{n\times n} F= 00...01..................00...10 Rn×n
  • 后向位移矩阵
    B = ( 0 0 . . . 0 1 . . . . . . . . . . . . . . . . . . 0 0 . . . 1 0 ) ∈ R n × n B=\left( \begin{matrix} 0& 0& ...& 0\\ 1& ...& ...& ...\\ ...& ...& ...& 0\\ 0& ...& 1& 0\\ \end{matrix} \right) \in \mathbb{R} ^{n\times n} B= 01...00..................10...00 Rn×n
  • 基于性质 前向、后向矩阵幂次和

T = ∑ k − 1 n − 1 t − k B k + ∑ k = 0 n − 1 t k F k T=\sum_{k-1}^{n-1}{t_{-k}B^k+\sum_{k=0}^{n-1}{t_kF^k}}\,\, T=k1n1tkBk+k=0n1tkFk

式中, t − k t_{-k} tk t k t_k tk分别为(预先定义好的)系数。

2.3 性质验证

  • 简单前向后向矩阵 后向矩阵 的幂次性质
n = 5; % Define the size of the matrix
F = diag(ones(1, n-1), 1); % Create the forward matrix
B = F'

这性质确实有点意思… 位置变化了

>> B^2ans =0     0     0     0     00     0     0     0     01     0     0     0     00     1     0     0     00     0     1     0     0>> B^3ans =0     0     0     0     00     0     0     0     00     0     0     0     01     0     0     0     00     1     0     0     0>> B^4ans =0     0     0     0     00     0     0     0     00     0     0     0     00     0     0     0     01     0     0     0     0>> F^2ans =0     0     1     0     00     0     0     1     00     0     0     0     10     0     0     0     00     0     0     0     0>> F^3ans =0     0     0     1     00     0     0     0     10     0     0     0     00     0     0     0     00     0     0     0     0>> F^4ans =0     0     0     0     10     0     0     0     00     0     0     0     00     0     0     0     00     0     0     0     0
  • 生成 托普利兹矩阵
n = 5; % Define the size of the matrix
F = diag(ones(1, n-1), 1); % Create the forward matrix
B = F';% Define the coefficients t_{-k} and t_k
t_neg = [1, 2, 3, 4, 5]; % Example coefficients for t_{-k}
t_pos = [1, 3, 3, 2, 1]; % Example coefficients for t_kT = zeros(n); % Initialize the Toeplitz matrixfor k = 1:nT = T + t_neg(k) * (B^(k-1));
endfor k = 2:nT = T + t_pos(k) * (F^(k-1));
end

定义的信息如下:
t_neg = [1, 2, 3, 4, 5]; % Example coefficients for t_{-k}
t_pos = [1, 3, 3, 2, 1]; % Example coefficients for t_k

T =1     3     3     2     12     1     3     3     23     2     1     3     34     3     2     1     35     4     3     2     1

3. 其他应用总结

3.1 其他性质

  • Python实现版本可以参考哈工大 赵老师的博客。

  • 其他的一些性质,

    • 包括可以高效率的计算卷积…
    • 对于Ax=b的系统(线性代数中),当A为托普利兹矩阵时,可以称其为托普利兹系统, 且此时的系统自由度为2-1而不是n^2, (究其原因,和托普利兹矩阵的形式有关), 因此,可以用Levinson求解方法快速计算
    • 托普利兹矩阵可以被分解,如LU分解中的Bareiss算法

PS: LU分解,顾名思义,L 是单位下三角矩阵, U 是单位上三角矩阵。 LU分解有两种实现,分别是. Gauss消去法. 待定系数法.

    • 关于对称块矩阵(Block Toepliz)和对称矩阵(Toepliz) 虽然托普利茨矩阵具有与对角线恒定性相关的特定特征,但对称块矩阵的特征在于其子矩阵的对称性。

这些具体的性质,等到需要用的时候,再推导吧…

3.2 文献阅读看到的

对于一些工程应用,最近在一篇论文中,就用到了这个性质,需要分析一个能量传播矩阵,这个能量传播矩阵可以表示为一个近似的对称块托普利兹矩阵,因此,可以利用其卷积性质,得到不变卷积核:
在这里插入图片描述

参考资料

【1】-csdn 托普利兹矩阵

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/6418.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

H3C MSTP 实验

H3C MSTP 实验 实验拓扑 ​​ 实验需求 所有交换机上创建 Vlan10,Vlan20,Vlan30 和 Vlan40所有交换机之间的端口配置为 Trunk,并放行相关 VLAN按照图示分区域配置 MSTP,并配置主备根网桥 实验步骤 VLAN基础配置(…

力扣面试150 简化路径 栈 模拟

Problem: 71. 简化路径 思路 &#x1f469;‍&#x1f3eb; 三叶题解 复杂度 时间复杂度: O ( n ) O(n) O(n) 空间复杂度: O ( n ) O(n) O(n) Code class Solution {public String simplifyPath(String path){ArrayDeque<String> d new ArrayDeque<>();…

2022 亚马逊云科技中国峰会,对话开发者论坛

目录 前言 最近整理资料发现还有一些前 2 年的内容没发出来&#xff0c;故补发记录&#xff0c;每年都有新的感悟。 开发者论坛 1. 你认为什么是开发者社区&#xff0c;如何定义一个成功的开发者社区&#xff1f; 我认为可以把开发者社区看成一个 “产品” 来对待&#xff…

【RAG 论文】GenRead:“generate-read“ 可能比 “retrieve-read“ 更有效

论文&#xff1a;Generate rather than Retrieve: Large Language Models are Strong Context Generators ⭐⭐⭐⭐ ICLR 2023 Code: github.com/wyu97/GenRead 一、论文速读 该工作发现&#xff1a;由 LLM 生成的文档中&#xff0c;往往比 retrieved documents 更可能包含正确…

C++校招八股

c类的访问权限与继承方式 公有成员在任何地方都可以被访问&#xff0c;包括类的外部和派生类。受保护成员在类的内部和派生类中可以被访问&#xff0c;但在类的外部不可访问。 私有成员只能在类的内部访问&#xff0c;包括类的成员函数和友元函数&#xff0c;不允许在类的外部…

一步一步写线程之十一线程池应用内存池

一、内存池 内存池&#xff0c;非常好理解&#xff0c;就是存储内存的一个池子&#xff08;Pool&#xff09;&#xff0c;一般来说&#xff0c;都是使用各种容器或者自己实现的类似容器的内存管理类。内存池其实就是为了解决两个主要问题&#xff0c;一个是内存反复分配回收的…

关于“泼辣”DB 你应该知道的几件事

PolarDB PolarDB for PostgreSQL&#xff08;以下简称 PolarDB&#xff09;是一款阿里云自主研发的企业级数据库产品&#xff0c;采用计算存储分离架构&#xff0c;100% 兼容 PostgreSQL。 PolarDB 的存储与计算能力均可横向扩展&#xff0c;具有高可靠、高可用、弹性扩展等企…

文件(夹)批量重命名数字、字母、日期、中文数字大写小写

首先&#xff0c;需要用到的这个工具&#xff1a; 度娘网盘 提取码&#xff1a;qwu2 蓝奏云 提取码&#xff1a;2r1z 目标是重命名下面5个文件&#xff08;也可以是文件夹等&#xff0c;任意&#xff09;&#xff0c;从大写中文数字“贰”开始 打开工具&#xff0c;找到“文…

使用机器学习确定文本的编程语言

导入必要的库 norman Python 语句&#xff1a;import <span style"color:#000000"><span style"background-color:#fbedbb"><span style"color:#0000ff">import</span> pandas <span style"color:#0000ff&quo…

Java面试题:解释Java内存模型(JMM)是什么,它为何重要?

Java内存模型&#xff08;Java Memory Model, JMM&#xff09; 定义&#xff1a; Java内存模型是一个抽象的概念&#xff0c;它定义了Java程序中各种变量&#xff08;线程共享变量&#xff09;的访问规则&#xff0c;以及在并发环境下&#xff0c;这些变量的读写操作如何与内存…

基于OpenCv的图像Harris角点检测

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

使用D3.js进行数据可视化

D3.js介绍 D3.js是一个流行的JavaScript数据可视化库&#xff0c;全称为Data-Driven Documents&#xff0c;即数据驱动文档。它以数据为核心&#xff0c;通过数据来驱动文档的展示和操作。D3.js提供了丰富的API和工具&#xff0c;使得开发者能够创建出各种交互式和动态的数据可…

无界微前端项目实战

前言 微前端框架&#xff1a;无界 wujievue 微前端是什么 | 无界主应用&#xff1a;Vue 2 elementui子应用&#xff1a;Vue 3viteelement plus 前提 子应用的资源和接口的请求都在主域名发起&#xff0c;所以会有跨域问题&#xff0c;子应用必须做cors 设置vue3vite 项目跨…

爬取B站评论:Python技术实现详解

引言 在当今信息爆炸的互联网时代&#xff0c;用户生成的内容不断涌现&#xff0c;其中包括了各种各样的评论。而B站作为一个充满活力的视频分享平台&#xff0c;其评论区更是一个充满了各种各样精彩评论的宝藏地。那么&#xff0c;有没有一种简单的方法可以将这些评论收集起来…

大模型日报2024-05-03

大模型日报 2024-05-03 大模型资讯 马克扎克伯格宣布Meta发布Llama 3大型语言模型的重大AI新闻 摘要: Meta公司在周四发布了其Llama 3大型语言模型的首两个版本。该模型是Meta AI的动力核心&#xff0c;马克扎克伯格称其为“未来的...”。这一进展标志着Meta在人工智能领域的进…

深度学习心得

1. KL loss 其经常要与softmax一起使用&#xff0c;就是为了学习one-hot分布 2. 降维 Pooling层的作用是增加模型的鲁棒性&#xff0c;让模型对输入的少量变化不那么敏感。 如果真想通过降维&#xff0c;减少模型训练参数&#xff0c;那应该用PCA降维方法&#xff0c; skl…

Java中new一个对象内存区域如何变化?顺序是什么?

Java中new一个对象内存区域如何变化&#xff1f;顺序是什么&#xff1f; 如果你对Java内存区域了解的话&#xff0c;那么肯定会知道&#xff0c;创建对象如果是第一次的话&#xff0c;首先肯定是要加载对应的Class&#xff08;要创建对象的类&#xff09;,加载的类信息就是放在…

贪心-耍杂技的牛

问题描述 农民约翰的 N头奶牛&#xff08;编号为 1…N&#xff09;计划逃跑并加入马戏团&#xff0c;为此它们决定练习表演杂技。 奶牛们不是非常有创意&#xff0c;只提出了一个杂技表演&#xff1a; 叠罗汉&#xff0c;表演时&#xff0c;奶牛们站在彼此的身上&#xff0c;形…

Django之配置数据库

一&#xff0c;创建项目 二&#xff0c;将项目的setting.py中的 DATABASES {default: {ENGINE: django.db.backends.sqlite3,NAME: BASE_DIR / db.sqlite3,} }替换成如下&#xff08;以mysql为例&#xff09; DATABASES {default: {ENGINE: django.db.backends.mysql,NAME: …

力扣---二叉树的锯齿形层序遍历

给你二叉树的根节点 root &#xff0c;返回其节点值的 锯齿形层序遍历 。&#xff08;即先从左往右&#xff0c;再从右往左进行下一层遍历&#xff0c;以此类推&#xff0c;层与层之间交替进行&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,…