拉格朗日乘数

来自testwiki
跳转到导航 跳转到搜索

Template:Primarysources Template:NoteTA

Template:Expert Template:NoteTA Template:微积分学

图1:绿线标出的是约束g(x,y) = c的点的轨迹。蓝线是f的等高线。箭头表示梯度,和等高线的法线平行。

数学中的最优化问题中,拉格朗日乘数法Template:Lang-en,以数学家约瑟夫·拉格朗日命名)是一种寻找多元函数在其变量受到一个或多个条件的约束时的局部极值的方法。

方法說明

對一個有 n 个变量与 k 个约束条件的最优化问题,拉格朗日乘數法會將其转换成一个 n+k 个变量的方程组,稱作拉格朗日方程Template:Lang-en),這個方程組的解將包括所有最優化問題的解。拉格朗日乘數法將會引入一个或一组新的未知数,即拉格朗日乘数Template:Lang-en),又称拉格朗日乘子,或拉氏乘子,它们是在转换后的方程,即约束方程中作为梯度线性组合中各个向量的系数。

比如,求 f(x,y)g(x,y)=0 时的局部極值时,我们可以引入新变量拉格朗日乘数λ,这时我们只需要求下列拉格朗日函数的局部极值:

(x,y,λ)=f(x,y)λg(x,y)

更一般地,对含n个变量和k个约束的情况,有:

(x1,,xn,λ1,,λk)=f(x1,,xn)i=1kλigi(x1,,xn),

拉格朗日乘数法所得的臨界點会包含原问题的所有臨界點,但并不保证每个拉格朗日乘數法所得的臨界點都是原问题的臨界點。拉格朗日乘数法的正确性的证明牵涉到偏微分全微分連鎖律

介绍

微积分中最常见的问题之一是求一个函数的极大极小值(极值)。但是很多时候找到极值函数的显式表达是很困难的,特别是当函数有先决条件或约束时。拉格朗日乘数则提供了一个非常便利方法来解决这类问题,而避开显式地引入约束和求解外部变量。

先看一个三维的例子:假设有函数:f(x,y),要求其极值(最大值/最小值),且满足条件

g(x,y)=c

c为常数。對不同dn的值,不难想像出

f(x,y)=dn

的等高线。而方程g的可行集所构成的线正好是g(x,y)=c。想像我们沿着g=c的可行集走;因为大部分情况下f的等高线和g的可行集线不会重合,但在有解的情况下,这两条线会相交。想像此时我们移动g=c上的点,因为f是连续的方程,我们因此能走到f(x,y)=dn更高或更低的等高线上,也就是说dn可以变大或变小。只有当g(x,y)=cf(x,y)=dn相切,也就是说,此时,我们正同时沿着g(x,y)=cf(x,y)=dn走。这种情况下,会出现极值鞍点

气象图中就很常出现这样的例子,当温度和气压两列等高线同时出现的时候,切点就意味着约束极值的存在。

向量的形式来表达的话,我们说相切的性质在此意味着fg的切线在某点上平行,同时也意味着两者的梯度向量有如下关系(引入一个未知标量λ):

f(x,y)=λ(g(x,y)c)

即:

[f(x,y)+λ(g(x,y)c)]=0.

一旦求出λ的值,将其套入下式,易求在无约束条件下的极值和对应的极值点。

F(x,y,λ) = f(x,y)+λ(g(x,y)c)

新方程F(x,y,λ)在达到极值时与f(x,y)相等。因为F(x,y,λ)达到极值时F(x,y,λ)=0,而Fλ=g(x,y)c,也就是说g(x,y)c等于零。

证明

设函数f(x,y)A点处有极值κ,且在A点的邻域内连续。则在A点处有

f(x,y)=κ

另有一常值函数

g(x,y)=c

两函数在A点处的全微分为

df=fxdx+fydy=0
dg=gxdx+gydy=0

當中的等式右方等於零是由於極值會發生在兩者函數斜率完全相同且f(x,y)在區段內有極值的時候

由于dxdy是任取的无穷小量,故该线性方程组的系数成比例,有

fxgx=fygy=λ

fx+λgx=0
fy+λgy=0

将上二式分别乘以dxdy,再相加并积分,得到一新函数

(x,y,λ)=f(x,y)+λg(x,y)

那么,求原函数极值的问题就转化为求该函数极值的问题。

类似地,这种求极值的方法也可以推广到多维函数f(x1,,xn)

拉格朗日乘数的运用方法

f定义为在Rn上的方程,约束为gk(x)= ck(或将约束左移得到gk(x) − ck = 0)。定义拉格朗日Λ

Λ(𝐱,λ)=f+kλk(gkck)

注意极值的条件和约束现在就都被记录到一个式子里了:

Λ=0f=kλk gk,

λΛ=0gk=ck

拉格朗日乘数常被用作表达最大增长值。原因是从式子:

Λck=λk

中我们可以看出λk是当方程在被约束条件下,能够达到的最大增长率。拉格朗日力学就使用到这个原理。

拉格朗日乘数法在卡罗需-库恩-塔克条件被推广。

例子

  • 很简单的例子

求此方程的最小值:

f(x,y)=x2y

同时未知数满足

x2+y2=1

因为只有一个未知数的限制条件,我们只需要用一个乘数λ.

g(x,y)=x2+y21
Φ(x,y,λ)=f(x,y)+λg(x,y)=x2y+λ(x2+y21)

将所有Φ方程的偏微分设为零,得到一个方程组,最小值是以下方程组的解中的一个:

2xy+2λx=0
x2+2λy=0
x2+y21=0
  • 另一个例子

求此离散分布的最大

f(p1,p2,,pn)=k=1npklog2pk

所有概率的总和是1,因此我们得到的约束是g(p)= 1即

g(p1,p2,,pn)=k=1npk=1

可以使用拉格朗日乘数找到最高熵(概率的函数)。对于所有的k从1到n,要求

pk(f+λ(g1))=0,

由此得到

pk(k=1npklog2pk+λ(k=1npk1))=0

计算出这n个等式的微分,我们得到:

(1ln2+log2pk)+λ=0

这说明pi都相等(因为它们都只是λ的函数)。解出约束∑k pk = 1,得到

pk=1n

因此,使用均匀分布可得到最大熵的值。

经济学

约束最优化在经济学占有很重要的地位。例如一个消费者的选择问题可以被视为一个求效用方程预算约束下的最大值问题。拉格朗日乘数在经济学中被解释为影子价格,设定在某种约束下,在这里即收入的边际效用

拉格朗日乘数就是效用函数在最优解处对收入的偏导数,也就是在最优解处增加一个单位收入带来的效用增加,或者说在最优解处有效用衡量收入的价值,称之为收入的边际效用。

在企业生产问题中,拉格朗日乘数用来衡量要素投入变动所带来的收入变动,du/dm=λ,u表示效用函数或生产函数,m表示收入或要素投入。

在具体数学推导中还可以运用包络定理的内容。

参考

对外链接

参考拉格朗日原作或方法的命名:

更深入的介绍和互动applet:

Template:約瑟夫·拉格朗日