当前位置: 首页 > news >正文

探秘沃尔什-哈达玛变换(WHT)原理

沃尔什-哈达玛变换(WHT)起源

  1. 起源与命名(20世纪早期)

    • 数学基础:该变换的理论基础由法国数学家雅克·哈达玛(Jacques Hadamard)在1893年提出,其核心是哈达玛矩阵的构造。
    • 扩展与命名:20世纪20年代,德裔美国数学家Hans Rademacher和美国数学家Joseph L. Walsh进一步扩展了该理论,将正交直角函数引入变换基,形成了“沃尔什-哈达玛变换”的完整体系。因此,该变换以三位数学家的贡献共同命名。
  2. 理论发展与早期应用(20世纪中期)

    • 信号处理:20世纪50年代后,WHT因其计算效率(仅涉及加减运算)被用于通信系统的信号分析与编码,成为非正弦函数变换的代表。
    • 图像处理:随着数字图像处理技术的发展,WHT的“能量集中”特性被发现,即均匀分布的数据经变换后集中于矩阵边角,这推动了其在图像压缩中的应用。
  3. 标准化与工业应用(20世纪末至21世纪初)

    • 视频编码:自20世纪90年代起,WHT被国际视频编码标准(如MPEG-4、H.264/AVC)采用,用于计算SATD(绝对变换差之和),以评估视频残差信号的大小。
    • 数据加密:其正交性和对称性使其在加密算法中发挥作用,例如JPEG XR等格式的压缩加密。
  4. 现代跨学科应用(21世纪以来)

    • 量子计算:WHT成为量子算法(如Grover搜索算法、Shor因式分解算法)的核心组件,因其与量子位操作的天然兼容性。
    • 快速算法优化:基于Cooley-Tukey型信号流图的快速沃尔什变换(FWHT)被提出,计算复杂度降至O(N log N),并集成至MATLAB、Python等工具。

关键特性与影响

  • 计算优势:相比傅里叶变换,WHT无需复数运算,硬件实现成本低,特别适合实时处理场景。
  • 跨领域融合:从传统信号处理到量子信息科学,WHT持续推动多个学科的技术迭代,体现了数学工具在工程中的普适性。

一、基本定义与数学原理

  1. 核心概念
    哈达玛变换(Walsh-Hadamard Transform, WHT) 是一种基于正交直角函数的非正弦变换,其变换矩阵由+1和-1构成,具有与傅里叶变换类似的性质。它的本质是通过改变离散序列的符号并进行加减运算实现数据转换。

  2. 数学表达式

    • 一维变换:对于长度为 N=2n 的离散信号 f(x),其哈达玛变换定义为:
      在这里插入图片描述

    • 矩阵形式:哈达玛矩阵 Hn 的递推生成方式为:
      在这里插入图片描述


二、关键性质与优势

  1. 正交性
    哈达玛矩阵的每一行和每一列都是正交的,因此变换后的信号能量可能集中于矩阵边角,适用于数据压缩。

  2. 计算高效性

    • 仅需实数加减运算,无需复数或三角函数计算,比FFT快约30%。
    • 支持快速算法(FWHT),通过奇偶分组递归实现,时间复杂度为 (O(N \log N))。
  3. 能量集中特性
    数据分布越均匀,变换后能量越集中于矩阵边角,利于压缩和特征提取。


三、主要应用领域

  1. 图像压缩

    • 通过保留重要频域成分、舍弃冗余信息,减小存储空间和传输带宽。
    • 实验表明,压缩比例过大会导致失真和伪影,需权衡压缩率与质量。
  2. 通信与编码

    • 用于线性分组码识别,通过哈达玛变换将接收码字转换为矩阵,并与码本比对。
    • 支持信号特征提取和加密,如基于变换域的数据隐藏。
  3. 压缩感知
    在稀疏信号恢复中,哈达玛矩阵可作为观测矩阵,降低采样复杂度。


四、实现方法与代码示例

  1. Matlab实现

    n = 8; % 矩阵阶数
    H = hadamard(n); % 生成哈达玛矩阵
    x = sign(randn(n,1)); % 随机信号
    y = H * x; % 哈达玛变换
    

    输出包含输入信号和变换结果。

  2. OpenCV应用
    使用 cv::dct() 或自定义函数实现图像频域处理,支持压缩和去噪。


五、与其他变换的对比

特性哈达玛变换傅里叶变换
基函数正交直角函数(+1/-1)正弦/余弦函数
计算复杂度低(仅加减)高(复数运算)
适用场景均匀分布数据、实时处理非均匀频率分析

六、推理过程(以 4x4 像素块为例)

  1. 输入矩阵:
    在这里插入图片描述
  2. 第一层行变换:相邻两个像素相加相减
    在这里插入图片描述
  3. 中间矩阵 D 结果:
    在这里插入图片描述
  4. 转置下,列变换变成行变换继续套用上面行变换的公式
    在这里插入图片描述
    在这里插入图片描述
  5. 转置后列变换的结果矩阵:
    在这里插入图片描述
  6. 再转置回去,结果矩阵:
    在这里插入图片描述
  7. 归一化结果矩阵 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&#xff08…...

对开源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…...

前端倒计时误差!

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...

五年级数学知识边界总结思考-下册

目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...

linux 下常用变更-8

1、删除普通用户 查询用户初始UID和GIDls -l /home/ ###家目录中查看UID cat /etc/group ###此文件查看GID删除用户1.编辑文件 /etc/passwd 找到对应的行,YW343:x:0:0::/home/YW343:/bin/bash 2.将标红的位置修改为用户对应初始UID和GID: YW3…...

GitHub 趋势日报 (2025年06月08日)

📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)

骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术,它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton):由层级结构的骨头组成,类似于人体骨骼蒙皮 (Mesh Skinning):将模型网格顶点绑定到骨骼上,使骨骼移动…...

Spring AI与Spring Modulith核心技术解析

Spring AI核心架构解析 Spring AI(https://spring.io/projects/spring-ai)作为Spring生态中的AI集成框架,其核心设计理念是通过模块化架构降低AI应用的开发复杂度。与Python生态中的LangChain/LlamaIndex等工具类似,但特别为多语…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP

编辑-虚拟网络编辑器-更改设置 选择桥接模式&#xff0c;然后找到相应的网卡&#xff08;可以查看自己本机的网络连接&#xff09; windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置&#xff0c;选择刚才配置的桥接模式 静态ip设置&#xff1a; 我用的ubuntu24桌…...

Java毕业设计:WML信息查询与后端信息发布系统开发

JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发&#xff0c;实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构&#xff0c;服务器端使用Java Servlet处理请求&#xff0c;数据库采用MySQL存储信息&#xff0…...

Xela矩阵三轴触觉传感器的工作原理解析与应用场景

Xela矩阵三轴触觉传感器通过先进技术模拟人类触觉感知&#xff0c;帮助设备实现精确的力测量与位移监测。其核心功能基于磁性三维力测量与空间位移测量&#xff0c;能够捕捉多维触觉信息。该传感器的设计不仅提升了触觉感知的精度&#xff0c;还为机器人、医疗设备和制造业的智…...