日拱一卒之Wirtinger 导数

日拱一卒之Wirtinger 导数

Wirtinger 导数(Wirtinger derivatives),也称为 Wirtinger 微积分(Wirtinger calculus)或 CR-微积分(Cauchy-Riemann calculus),是一套用于处理复变函数的偏导数工具。

简单来说,它允许将一个复数变量 zzz 和它的共轭 zˉ\bar{z}zˉ 视为两个相互独立的变量来进行求导。

这在复数域的优化问题(如信号处理、通信工程、深度学习中的复数神经网络)中非常重要,特别是当目标函数是实数值(例如损失函数)但变量是复数时。


1. 为什么我们需要它?(背景)

在工程应用中,经常遇到这样的函数:

f(z)=∣z∣2=z⋅zˉ f(z) = |z|^2 = z \cdot \bar{z} f(z)=z2=zzˉ

这是一个实数值函数(通常作为代价函数或能量函数)。

这个函数在经典的复变函数意义下是不可导的(因为它不满足柯西-黎曼条件,除非 z=0z=0z=0)。

如果把 zzz 分解成实部 xxx 和虚部 yyy,即 z=x+iyz = x + iyz=x+iy,可以分别对 xxxyyy 求偏导。但这样做非常繁琐,公式也不优雅。

Wirtinger 的方法:直接定义针对 zzzzˉ\bar{z}zˉ 的导数,使得可以像做多项式求导一样简单地处理 ∣z∣2|z|^2z2

2. 数学定义

假设 z=x+iyz = x + iyz=x+iy,且 f(z)=u(x,y)+iv(x,y)f(z) = u(x, y) + i v(x, y)f(z)=u(x,y)+iv(x,y)
Wirtinger 导数定义如下:

zzz 的 Wirtinger 导数:

∂∂z=12(∂∂x−i∂∂y) \frac{\partial}{\partial z} = \frac{1}{2} \left( \frac{\partial}{\partial x} - i \frac{\partial}{\partial y} \right) z=21(xiy)

zˉ\bar{z}zˉ 的 Wirtinger 导数(共轭导数):

∂∂zˉ=12(∂∂x+i∂∂y) \frac{\partial}{\partial \bar{z}} = \frac{1}{2} \left( \frac{\partial}{\partial x} + i \frac{\partial}{\partial y} \right) zˉ=21(x+iy)

最核心的技巧是:可以假设 zzz zˉ\bar{z}zˉ 是两个完全无关的变量。

当求 ∂f∂z\frac{\partial f}{\partial z}zf 时,把 zˉ\bar{z}zˉ 看作常数。当求 ∂f∂zˉ\frac{\partial f}{\partial \bar{z}}zˉf 时,把 zzz 看作常数。

3. 举个例子

假设有一个函数 f(z)=∣z∣2=zzˉf(z) = |z|^2 = z \bar{z}f(z)=z2=zzˉ

方法 A:用实数坐标(笨办法)

f(z)=x2+y2 f(z) = x^2 + y^2 f(z)=x2+y2

∂f∂x=2x,∂f∂y=2y \frac{\partial f}{\partial x} = 2x, \quad \frac{\partial f}{\partial y} = 2y xf=2x,yf=2y

这给出了实数域的梯度,但并没有直接告诉复数方向的变化。

方法 B:用 Wirtinger 导数(聪明办法)
zzzzˉ\bar{z}zˉ 看作独立变量。

f(z,zˉ)=z⋅zˉ f(z, \bar{z}) = z \cdot \bar{z} f(z,zˉ)=zzˉ

  1. zzz 求导(把 zˉ\bar{z}zˉ 当常数):

    ∂f∂z=zˉ \frac{\partial f}{\partial z} = \bar{z} zf=zˉ

  2. zˉ\bar{z}zˉ 求导(把 zzz 当常数):

    ∂f∂zˉ=z \frac{\partial f}{\partial \bar{z}} = z zˉf=z

这个结果非常简洁,而且在推导复杂算法(如维纳滤波、复数反向传播)时极大地简化了代数运算。

特殊用法:

求极值的时候,对 zzz zˉ\bar{z}zˉ在数学上是等价的

对于实数值函数 JJJ(例如图中的误差平方和),有以下关系:

∂J∂α=(∂J∂α∗)‾ \frac{\partial J}{\partial \alpha} = \overline{\left( \frac{\partial J}{\partial \alpha^*} \right)} αJ=(αJ)

这两个导数互为共轭。

这就导致了一个非常有用的性质:
如果一个数为 0,那么它的共轭也一定是 0。

∂J∂α∗=0  ⟺  ∂J∂α=0 \frac{\partial J}{\partial \alpha^*} = 0 \iff \frac{\partial J}{\partial \alpha} = 0 αJ=0αJ=0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值