探秘沃尔什-哈达玛变换(WHT)原理
沃尔什-哈达玛变换(WHT)起源
-
起源与命名(20世纪早期)
- 数学基础:该变换的理论基础由法国数学家雅克·哈达玛(Jacques Hadamard)在1893年提出,其核心是哈达玛矩阵的构造。
- 扩展与命名:20世纪20年代,德裔美国数学家Hans Rademacher和美国数学家Joseph L. Walsh进一步扩展了该理论,将正交直角函数引入变换基,形成了“沃尔什-哈达玛变换”的完整体系。因此,该变换以三位数学家的贡献共同命名。
-
理论发展与早期应用(20世纪中期)
- 信号处理:20世纪50年代后,WHT因其计算效率(仅涉及加减运算)被用于通信系统的信号分析与编码,成为非正弦函数变换的代表。
- 图像处理:随着数字图像处理技术的发展,WHT的“能量集中”特性被发现,即均匀分布的数据经变换后集中于矩阵边角,这推动了其在图像压缩中的应用。
-
标准化与工业应用(20世纪末至21世纪初)
- 视频编码:自20世纪90年代起,WHT被国际视频编码标准(如MPEG-4、H.264/AVC)采用,用于计算SATD(绝对变换差之和),以评估视频残差信号的大小。
- 数据加密:其正交性和对称性使其在加密算法中发挥作用,例如JPEG XR等格式的压缩加密。
-
现代跨学科应用(21世纪以来)
- 量子计算:WHT成为量子算法(如Grover搜索算法、Shor因式分解算法)的核心组件,因其与量子位操作的天然兼容性。
- 快速算法优化:基于Cooley-Tukey型信号流图的快速沃尔什变换(FWHT)被提出,计算复杂度降至O(N log N),并集成至MATLAB、Python等工具。
关键特性与影响
- 计算优势:相比傅里叶变换,WHT无需复数运算,硬件实现成本低,特别适合实时处理场景。
- 跨领域融合:从传统信号处理到量子信息科学,WHT持续推动多个学科的技术迭代,体现了数学工具在工程中的普适性。
一、基本定义与数学原理
-
核心概念
哈达玛变换(Walsh-Hadamard Transform, WHT) 是一种基于正交直角函数的非正弦变换,其变换矩阵由+1和-1构成,具有与傅里叶变换类似的性质。它的本质是通过改变离散序列的符号并进行加减运算实现数据转换。 -
数学表达式
-
一维变换:对于长度为 N=2n 的离散信号 f(x),其哈达玛变换定义为:

-
矩阵形式:哈达玛矩阵 Hn 的递推生成方式为:

-
二、关键性质与优势
-
正交性
哈达玛矩阵的每一行和每一列都是正交的,因此变换后的信号能量可能集中于矩阵边角,适用于数据压缩。 -
计算高效性
- 仅需实数加减运算,无需复数或三角函数计算,比FFT快约30%。
- 支持快速算法(FWHT),通过奇偶分组递归实现,时间复杂度为 (O(N \log N))。
-
能量集中特性
数据分布越均匀,变换后能量越集中于矩阵边角,利于压缩和特征提取。
三、主要应用领域
-
图像压缩
- 通过保留重要频域成分、舍弃冗余信息,减小存储空间和传输带宽。
- 实验表明,压缩比例过大会导致失真和伪影,需权衡压缩率与质量。
-
通信与编码
- 用于线性分组码识别,通过哈达玛变换将接收码字转换为矩阵,并与码本比对。
- 支持信号特征提取和加密,如基于变换域的数据隐藏。
-
压缩感知
在稀疏信号恢复中,哈达玛矩阵可作为观测矩阵,降低采样复杂度。
四、实现方法与代码示例
-
Matlab实现
n = 8; % 矩阵阶数 H = hadamard(n); % 生成哈达玛矩阵 x = sign(randn(n,1)); % 随机信号 y = H * x; % 哈达玛变换输出包含输入信号和变换结果。
-
OpenCV应用
使用cv::dct()或自定义函数实现图像频域处理,支持压缩和去噪。
五、与其他变换的对比
| 特性 | 哈达玛变换 | 傅里叶变换 |
|---|---|---|
| 基函数 | 正交直角函数(+1/-1) | 正弦/余弦函数 |
| 计算复杂度 | 低(仅加减) | 高(复数运算) |
| 适用场景 | 均匀分布数据、实时处理 | 非均匀频率分析 |
六、推理过程(以 4x4 像素块为例)
- 输入矩阵:

- 第一层行变换:相邻两个像素相加相减

- 中间矩阵 D 结果:

- 转置下,列变换变成行变换继续套用上面行变换的公式


- 转置后列变换的结果矩阵:

- 再转置回去,结果矩阵:

- 归一化结果矩阵 G: 即 1/4

相关文章:
探秘沃尔什-哈达玛变换(WHT)原理
沃尔什-哈达玛变换(WHT)起源 起源与命名(20世纪早期) 数学基础:该变换的理论基础由法国数学家雅克哈达玛(Jacques Hadamard)在1893年提出,其核心是哈达玛矩阵的构造。扩展与命名&…...
优雅拼接字符串:StringJoiner 的完整指南
在Java开发中,字符串拼接是高频操作。无论是日志格式化、构建CSV数据,还是生成动态SQL,开发者常需处理分隔符、前缀和后缀的组合。传统的StringBuilder虽然灵活,但代码冗余且易出错。Java 8推出的StringJoiner类,以简洁…...
AFL++安装
学习fuzzing也几天了,今天记录AFL的安装及使用 一、实验环境 虚拟机:ubuntu20.04 当然也可以uname -a去看自己的版本号 二、AFL安装 1.先更新一下工具 sudo apt update2.安装AFL必要的一些依赖,例如编译工具(如 build-essen…...
开发者社区测试报告(功能测试+性能测试)
功能测试 测试相关用例 开发者社区功能背景 在当今数字化时代,编程已经成为一项核心技能,越来越多的人开始学习编程,以适应快速变化的科技 环境。基于这一需求,我设计开发了一个类似博客的论坛系统,专注于方便程序员…...
如何优化 VS Code 远程开发环境?高效配置与性能提升策略
相关系列文章 《新手教学系列——善用 VSCode 工作区,让开发更高效》 《新手教学系列——用 VSCode 实现高效远程开发》 《Webpack 优化全攻略:彻底解决 Vue 项目 npm run dev 的内存泄露问题》 引言 随着开发环境不断进化,VS Code 作为一款轻量级的代码编辑器,已经成为…...
【二】JavaScript能力提升---this对象
目录 this的理解 this的原理 事件绑定中的this 行内绑定 动态绑定 window定时器中的this 相信小伙伴们看完这篇文章,对于this的对象可以有一个很大的提升! this的理解 对于this指针,可以先记住以下两点: this永远指向一个…...
YC 孵化项目 Pinch:实时语音翻译视频会议平台;Mistral OCR:能处理多语言多模态复杂文档丨日报
开发者朋友们大家好: 这里是 「RTE 开发者日报」 ,每天和大家一起看新闻、聊八卦。 我们的社区编辑团队会整理分享 RTE(Real-Time Engagement) 领域内「有话题的 技术 」、「有亮点的 产品 」、「有思考的 文章 」、「有态度的 …...
OSPF报文分析
OSPF报文分析 组播地址 224.0.0.0~224.0.0.255为预留的组播地址(永久组地址),地址224.0.0.0保留不做分配,其它地址供路由协议使用; 224.0.1.0~238.255.255.255为用户可用的组播地址(…...
蓝桥杯刷题周计划(第二周)
目录 前言题目一题目代码题解分析 题目二题目代码题解分析 题目三题目代码题解分析 题目四题目代码题解分析 题目五题目代码题解分析 题目六题目代码题解分析 题目七题目代码题解分析 题目八题目题解分析 题目九题目代码题解分析 题目十题目代码题解分析 题目十一题目代码题解分…...
PH热榜 | 2025-03-09
1. ResumeUp 2.0 标语:聊聊,几分钟内就能帮助你打造完美的ATS简历。 介绍:告别为写完美简历而烦恼的日子吧!只需与人工智能聊天,回答几个简单的问题,就能在几分钟内生成强有力的简历,不仅能通…...
《gradio :AI demos》
《gradio :AI demos》 Folders and files Name Last commit message Last commit date parent directory .. agent_chatbot Declare exports in __all__ for type checking (#10238) 3 months ago all_demos Fix deployed Spaces (#10271) 2 months ago …...
Interop_UdsProtocolStack之数据解析器使用方法
一、背景与需求 在汽车电子领域,UDS(Unified Diagnostic Services)协议栈的响应报文解析是实现ECU诊断功能的核心环节。本文提出一种基于配置驱动的通用解析器开发方案,满足以下行业需求: 多协议兼容性:支…...
从0开始完成基于异步服务器的boost搜索引擎
文章目录 前言一、本项目涉及的技术栈和环境二、boost是什么?三、项目的相关背景四、项目的相关原理五、正排索引 vs 倒排索引 - 搜索引擎具体原理六、 编写数据去标签与数据清洗的模块 Parser6.1 下载boost的文档库6.2 去标签6.3 代码编写 七、索引模块7.1. 整体框…...
炒菜本质是 “能量(火候)与食材特性”的动态平衡
炒菜看似简单,但想要做到色香味俱全,需遵循一套清晰的逻辑链条。以下从底层逻辑到实操步骤拆解: 一、核心逻辑:控制变量,精准匹配 炒菜本质是 “能量(火候)与食材特性”的动态平衡,…...
AI Copilot——维新派的贾维斯,守旧派的墓志铭(程序员视角)
6500万年前的那颗陨石好像要落下来了 这一段时间,伴随着claude sonnet 3.7的发布 以及cursor,windsurf 等一众AI智能编辑器的涌现,社区的programming自媒体坐不住了,有一个观点已经快要溢出屏幕:程序员这个岗位要黄&a…...
Java Spring MVC (2)
常见的Request Controller 和 Response Controller 的区别 用餐厅点餐来理解 想象你去一家餐厅吃饭: Request Controller(接单员):负责处理你的点餐请求,记录你的口味、桌号等信息。Response Controller(…...
对开源VLA sota π0的微调——如何基于各种开源数据集、以及你自己的私有数据集微调π0(含我司的微调实践)
前言 25年2.4日,几个月前推出π0的公司Physical Intelligence (π)宣布正式开源π0及π0-FAST,如之前所介绍的,他们对用超过 10,000 小时的机器人数据进行了预训练 该GitHub代码仓库「 π0及π0-FAST的GitHub地址:github.com/Ph…...
[排序算法]直接插入排序
1.基本思想 直接插入排序是一种简单的插入排序法,其基本思想是:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列。 实际中我们玩扑克牌时,就用…...
四、云原生应用监控-Etcd
Etcd 是 Kubernetes 内部核心组件之一,作为分布式键值存储,天然支持 Prometheus 监控,自带 /metrics 端点,可直接被 Prometheus 抓取。 Etcd监控需要使用到证书。 一、检查云原生Etcd 检查节点上的Etcd [root@k8s-master01 manifests]#netstat -lnpt |grep etcd tcp …...
STM32-I2C通信外设
目录 一:I2C外设简介 二:I2C外设数据收发 三:I2C的复用端口 四:主机发送和接收 五:硬件I2C读写MPU6050 相关函数: 1.I2C_ GenerateSTART 2.I2C_ GenerateSTOP 3.I2C_ AcknowledgeConfig 4.I2C…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
STM32+rt-thread判断是否联网
一、根据NETDEV_FLAG_INTERNET_UP位判断 static bool is_conncected(void) {struct netdev *dev RT_NULL;dev netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);if (dev RT_NULL){printf("wait netdev internet up...");return false;}else{printf("loc…...
《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
工程地质软件市场:发展现状、趋势与策略建议
一、引言 在工程建设领域,准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具,正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...
ip子接口配置及删除
配置永久生效的子接口,2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...
Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...
C#中的CLR属性、依赖属性与附加属性
CLR属性的主要特征 封装性: 隐藏字段的实现细节 提供对字段的受控访问 访问控制: 可单独设置get/set访问器的可见性 可创建只读或只写属性 计算属性: 可以在getter中执行计算逻辑 不需要直接对应一个字段 验证逻辑: 可以…...
MySQL 部分重点知识篇
一、数据库对象 1. 主键 定义 :主键是用于唯一标识表中每一行记录的字段或字段组合。它具有唯一性和非空性特点。 作用 :确保数据的完整性,便于数据的查询和管理。 示例 :在学生信息表中,学号可以作为主键ÿ…...
Qemu arm操作系统开发环境
使用qemu虚拟arm硬件比较合适。 步骤如下: 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载,下载地址:https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...
