多频相位展开(Multi-frequency Phase Unwrapping)”可以替代格雷码?

一、结论

k 的本质 = "需要加多少个 2π 才和低频一致"

多频相位展开通过不同频率的包裹相位建立约束关系,利用低频相位提供粗略位置估计,再通过高频相位精细匹配,从而计算出需要补偿的2π周期数k,实现绝对相位恢复。

对比 Gray Code 多频相位
类型 离散 连续
帧数 多(10+) 少(6~12)
精度 一般 更高
抗噪 稍弱
速度

二、多频相位的核心思想

理解

不用编码 k,而是:

用不同"频率"的相位去反推 k

复制代码
假设你有两个周期:

周期1:10 mm(低频)
周期2:2 mm(高频)

测量结果:

低频相位 → 粗位置
高频相位 → 精细位置

组合:

确定唯一位置

数学原理

多个相位

不同频率: f1 < f2

展开思想

双频展开

cpp 复制代码
假设
f1 = 1(低频)
f2 = 8(高频)
观测:
φ1 = 1.2 rad
φ2 = 2.5 rad
推导真实相位

先算:

Φ ≈ φ2 + 2πk

k 由 φ1 约束:

低频决定"在哪个大区间"

最终:

Φ 唯一确定

三频展开(工业级)

cpp 复制代码
频率:

f1 = 1
f2 = 8
f3 = 64

流程:

低频 → 粗定位
中频 → refine
高频 → 亚像素

类似:

GrayCode + Phase

但:

全是"连续相位"

三、工业为什么越来越多用多频?

1、速度快

少帧 → 高速扫描


2、更高精度

纯相位 → 连续模型


3、 无需二值判断

避免阈值误差

4、为什么一定能推出来?

cs 复制代码
因为:

低频限制范围
Φ ∈ 某个大区间
高频提供细节
φ2 精度高

 联立:

只有一个 k 满足

4、工程中更稳定写法

四、多频 通过多个 φ 如何推 k

1、问题:

2、数学推导(核心公式)

举例说明:

f1 = 1

f2 = 8

真实相位(未知):

Φ ≈ 15 rad

3、计算包裹相位

低频

高频

4、用 φ 推 k(核心步骤)

用低频估计 Φ
计算 k₂

5、恢复真实 Φ

6、误差分析

1、 φ噪声

φ误差 → k计算错误


2、 频率选择不合理

f2 太接近 f1 → 不稳定


3、 跳变点

φ 接近 π → 易错

4、什么多频相位展开在噪声下会"错误传播",以及如何用 Quality Map 避免?

相关推荐
yszaygr213844 分钟前
Verilog参数化游程编码RLE模块
算法
望易1 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络5 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron20 小时前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰1 天前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法
地平线开发者2 天前
J6B vio scenario sample
算法