- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
除了数值计算之外,是否有一种快速方法来获取协方差矩阵(我的网络激活)的导数?
我试图将其用作深度神经网络中成本函数中的惩罚项,但为了通过我的层反向传播误差,我需要获得导数。
在Matlab中,如果“a”是第i层的激活矩阵(神经元*样本),“da”是激活函数的导数:
covariance = a * a' / (size(a,2)-1);
到目前为止我已经尝试过:
covarDelta = (da*a' + a*da' ) / (size(a,2)-1);
但奇怪的是,当我导出 aa' 实际上是 aa=a.^2 时,我已经更接近数值计算的梯度(没有意义,但它改进了事情有点):
covarDelta = 2*a/size(a,1);
但是没有一个是正确的。知道如何近似协方差的导数吗?
编辑:我不使用协方差矩阵本身作为惩罚项,我取其所有元素的平均值并将该数字添加到成本函数中。我使用这种方法是因为我试图提出一个惩罚项,当信号之间总体协方差更大时,该惩罚项会更大。
注意:我的目标是在训练期间最小化信号之间的相似性(我也尝试过惩罚成对的互信息,但也找不到计算其导数的方法)。
编辑2:我最终使用了已接受答案提供的相同导数,但我已将成本项更改为mean(sqrt(x.^2))。这样负协方差和正协方差都会增加惩罚,并且导数是相同的。
最佳答案
编辑:
假设我们只有一个三维数据点a = [a1 a2 a3]'
,因为外积矩阵中所有元素的总和a*a'
code>相当于(a1+a2+a3)^2
的展开,矩阵的均值是(a1+a2+a3)^2/(3*3)
。因此在这种情况下,每个维度的导数具有相同的值2*(a1+a2+a3)/(3*3)
。
对于更多数据点,该术语变为 ((a1+a2+a3)^2+(b1+b2+b3)^2+...)/(3*3)
,并且数据点 x 的导数为 2*(x1+x2+x3)/(3*3)
(每个维度的值相同)。
简单地取平均值可能不适合您的需求,因为它会抵消协方差矩阵中的正值和负值。
目前我没有环境来验证我的答案,错误的地方请指正。
原帖:
通常人们会使用标量值作为成本,而不是(协方差)矩阵。
如果我们将协方差表示为函数cov(x),它接受一个矩阵作为输入并输出一个矩阵。
所以精确导数不是单个矩阵,因为它对输入矩阵每个元素的偏导数都是一个矩阵。
假设输入矩阵 A 的维度为 m*n,则输出矩阵 C 的维度为 m*m。导数 dA/dC 应该是 m*m*m*n 矩阵。请参阅http://mplab.ucsd.edu/tutorials/MatrixRecipes.pdf了解逐个矩阵微分的详细信息。
关于machine-learning - 如何计算协方差的导数/梯度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35084254/
我有一个随时间变化的数据流。如何使用 C# 确定变化率? 自从上微积分课已经很长时间了,但现在是我第一次真正需要它(15 年来)。现在,当我搜索“衍生品”这个词时,我会得到金融方面的东西,以及我认为并
假设我有以下数据和命令: clc;clear; t = [0:0.1:1]; t_new = [0:0.01:1]; y = [1,2,1,3,2,2,4,5,6,1,0]; p = interp1(
假设我有以下数据和命令: clc;clear; t = [0:0.1:1]; t_new = [0:0.01:1]; y = [1,2,1,3,2,2,4,5,6,1,0]; p = interp1(
我曾经使用这个公式来计算每秒记录的信号的导数,然后对其应用滚动平均值。 df.rolling(rollingWindow, center=True).mean().diff(rollingWindow
通过这里的一些帮助,我想出了一个函数,它似乎将索贝尔导数应用于 X 方向的图像 F(x,y) = F(x+1,y) - F( x,y)我无法使用任何 OpenCV 函数,并且我需要 2D 输出数组比
对于神经网络库,我实现了一些激活函数和损失函数及其衍生物。它们可以任意组合,输出层的导数只是损失导数和激活导数的乘积。 但是,我未能独立于任何损失函数实现 Softmax 激活函数的导数。由于归一化,
我要在使用 ReLU 的神经网络上进行反向传播。 在我之前的一个项目中,我在一个使用 Sigmoid 激活函数的网络上做了,但现在我有点困惑,因为 ReLU 没有导数。 这是一个 image关于 we
我的任务是制作自己的 Sobel 方法,而不是使用 OpenCV 中的 cv::Sobel。我尝试实现我在 Programming techniques 找到的一个 但是,当我运行该程序时,cv::M
我愿意计算一个不完全明确的函数的 Frechet/Gateaux 导数,我的问题是:最有效的方法是什么?您会推荐我使用哪种语言? 准确地说,我的问题是我有一个函数,比如 F,它是多维函数对(即从 R^
我想使用 Flux.jl 绘制函数及其梯度和 Plots.jl using Flux.Tracker using Plots f(x::Float64) = 3x^2 + 2x + 1 df(x::F
我已将 ReLu 导数实现为: def relu_derivative(x): return (x>0)*np.ones(x.shape) 我也尝试过: def relu_derivativ
我几乎没有关于 Scharr 导数及其 OpenCV 实现的问题。 我对具有 (3X3) 内核的二阶图像导数感兴趣。我从 Sobel 二阶导数开始,它未能在图像中找到一些细线。看完this page底
import numpy as np def relu(z): return np.maximum(0,z) def d_relu(z): z[z>0]=1 z[z 0).as
你好,我用 C++ 创建了一个小的运动模拟。我想向学生展示 Euler、Runge-Kutta 和 MidPoint 方法之间的差异,有些 Material 点在撞击球体时会移动和反弹。 但是当我切换
或者,目标:如何以声明方式从 Nix 不稳定中获取单个包? 我是 NixOS 的新手,目前正在尝试安装比默认版本更新的 Consul 0.5.2我的 NixOS 版本(最新稳定版)。我正在尝试通过覆盖
我已经为此苦苦挣扎了很长一段时间。我想要的只是一个 torch.diff() 函数。然而,许多矩阵运算似乎并不容易与张量运算兼容。 我已经尝试了大量不同的 pytorch 操作组合,但它们都不起作用。
我试图了解如何在 Swift 中创建 Vector,因为当我执行 CGVectorMake() 时,它告诉我将 dx 和 dy(导数)作为 CGFloat 传递。如何创建仅包含该信息的向量(线)? 谁
我希望你能帮助我。 我正在使用 QT 并尝试对图像的边缘进行简单检测。但是当我启动时我的程序崩溃了 cv::GaussianBlur( src, src, cv::Size(3,3), 0, 0, c
我正在计算信号的一阶和二阶导数,然后进行绘图。我选择了在 SciPy(信号模块)中实现的 Savitzky-Golay 滤波器。我想知道是否需要缩放输出 - 在同一过滤器的 Matlab 实现中,指定
我是一名优秀的程序员,十分优秀!