主要内容
局部线性法
学习如何将切线平面的概念推广到标量值多变量函数的线性近似。
背景知识
我们要做什么
- 局部线性法将切平面的概念泛化到任何多变量函数. 在这里, 我将只讨论多变量的标量函数的情况.
- 这样做的目的是用一个简单函数去近似一个函数, 该函数在相同输入时有相同输出的, 以及相同的偏导数的值.
- 用向量的方式描述的近似函数的形式:
- 这就是所谓的在
的 附近的局部线性法,
切平面作为近似
在上一篇文章 中,我讲了如何找到双变量函数图像中的切平面.
切平面的公式最终形式如下.
这个函数 经常有不同的名称: 函数 在点 附近的"局部线性化",你可以将它视为满足两个属性的最简单的函数:
- 它与函数
在点 有相同的值. - 它与函数
在 有相同的偏导数,
与在多变量微积分中一样, 在不依赖图形直觉的情况下思考一个新概念是很棒的. 这并不是说你不应该尝试视觉思考,也许只是纯粹需要考虑输入空间, 或者考虑相关的变换而不是考虑图形.
从根本上说, 局部线性法是根据你在该点上可以从其导数(单个或多个) 中得到的信息, 去逼近该点附近的一个函数.
对于具有双变量输入和标量 (即非矢量) 输出的函数,可以将其可视化为切平面。 然而,对于更高的维度,我们就无法奢侈地可视化了,所以我们只能把它当作一个近似值来思考。
在多变量微积分的实际应用中, 你几乎从不关心空间中的实际平面. 相反, 你可能有一些复杂的功能, 比如,哦, 我不知道, 降落伞上的空气阻力是速度和方向的函数. 处理实际函数可能很棘手, 或者计算成本很高. 因此用更简单的方法, 如线性函数, 来近似它是很有帮助的.
我所说的 "线性函数" 是什么意思?
思考一个具有多维输入的函数.
如果在这个函数的定义中,所有的坐标都只是乘以一个常量,并没有其他的改变,这个函数就称为线性 .例如,它可能有如下形式:
关于线性我们会更深入的学习 (因此存在 "线性代数" 字段),但目前,了解这个概念就可以了.通常情况下,您应该将输入视为向量,而不是像这样写出所有变量:
你应该用点积定义函数:
出于本文的目的, 更通常的地说, 当您谈论局部线性法线时, 您可以在此表达式中添加一个常量:
如果你想要咬文嚼字一下, 那么这就不再是一个线性函数. 这是所谓的 "仿射" 函数. 但大多数人会说 "不论如何,这基本上就是线性的".
局部线性法
现在, 假设您的函数 不 是线性的. (粗体的 " " 仍然代表多维向量). 它可能是比点乘积更疯狂的表达方式定义的.
局部线性化的想法是在某些特定的输入值 附近近似这个函数,其函数 是 线性. 具体来说,下面是新函数的形式:
- 注意, 通过插入
, 你可看到函数 和 对于输入 具有相同的值. - 向量与变量
的点积是 对于特定输入的梯度, 。 这将保证两个函数 和 对于特定输入有同样的梯度 。换句话说,此时它们二者的偏导数相同。
我认为理解这个公式的最好方法是你自己在特定函数上下文中亲自求导.
示例 1: 寻找局部线性法。
问题: 你有一个函数:
找到一个线性函数 , 这个 的值及其所有偏导数在以下点与 的值相匹配:
步骤 1: 在选定的点计算 的值
步骤 2: 开始使用它来编写您的函数, 以下哪个函数将保证在输入 时与 相等?
步骤 3: 计算每个变量的偏导数
现在我们来计算每个偏导数在点 的值
步骤 4: 在表达式 中用这些偏导数值替换常量 、 和 , 你会得到什么?
现在请注意, 如果您使用向量表示它, 它会是什么样子.
它只是上述的一般公式的一种特定形式.
示例 2: 使用局部线性法进行估计
下面的内容决不是一个实际的应用,但通过它,将有助于让人们感受到局部线性法正在做什么.
问题: 假设你在一个没有计算器的荒岛上, 你需要估计 . 你会怎么做?
解析:
我们可以把这个问题看作是在点 计算一个特定的三变量函数,即
我不知道你是否懂得如何手工估算平方根, 反正我不懂. 要是这个函数是线性的就好了. 然后就可以手工解决它, 只需加法和乘法. 我们可以做的是在点的附近寻找局部线性化, 这样估计 更容易. 然后, 我们可以通过计算点 的线性化来接近正确的答案.
我们要找的点非常接近一个更简单得的点 ,所以我们要去找在该点附近的 的局部线性化.和以前一样, 我们必须找到
- 函数
在 的所有偏导数
其中第一个是
看来有人选择了一些方便计算的输入值, 是吗?
关于偏导数 (沉重的叹息).让我们自己写出 的导数.
好的, 让我们继续. 最简单的偏导数是
由于这里的 是复合函数, 需要应用链式规则:
进一步, 这个棘手的 将需要两次迭代的链式规则:
接下来, 用 带入来计算每一个偏导数. 他们看起很多, 但它们都由相同的三个基本组件组成:
把这些值带入偏导数表达式,我们得到
解开局部线性化的公式,我们得到
最后, 在完成所有这些工作之后, 我们可以带入 来计算我们的近似值
手工计算这个仍然不 容易, 但至少它是可行的. 当你算出来, 最终的答案是
如果我们用了计算器, 答案是
所以我们的近似值相当不错!
为什么重要?
虽然发现自己在荒岛上然后去估计平方根的情况并不常见 (至少在我老家),但在数学和工程的背景下, 在复杂但可区分的函数之间的争论, 可以是常见的. "将它线性化" 这句话随处可见, 不知道它的意思可能会很奇怪.
请记住, 局部线性法根据您可以从一个点的导数中获得的信息,去近似于该点附近的一个函数.即使你可以使用计算机来计算函数,但这并不总是足够的.
- 你可能需要每秒计算它千百次, 全部算出来需要的时间太长.
- 也许你甚至没有明确写出函数, 你只是在某个你想推断的点附近有些测量结果.
- 有时你关心的是反函数, 这可能很难甚至不可能找到一整个函数作为反函数, 而反线性函数是相对便捷的.
总结
- 局部线性法将切平面的概念泛化到任何多变量函数.
- 这样做的目的是用一个简单函数去近似一个函数, 该函数在相同输入时有相同输出的, 以及相同的偏导数的值.
- 用向量的方式描述的近似函数的形式:
- 这就是所谓的在
的 附近的局部线性法,