采纳答案成功!
向帮助你的同学说点啥吧!感谢那些助人为乐的人
在视频里n_iters的取值为样本数量的整数倍,但是这样随机梯度下降法的计算量可能会比批量梯度下降法大吧,那为什么不直接用批量梯度下降呢?
不会比梯度下降法大。课程中介绍了,随机梯度下降法的性能核心,在梯度的计算上。
注意:每一项都有一个sigma,每个sigma都是对 m个样本操作,如果数据规模比较大,m可以是100万,1000万,计算按一次提督的性能开销都是巨大的。
而随机梯度法,计算梯度,只用一个样本。计算一次梯度,性能开销近乎是批量梯度下降法的 1/m。如果m是100万,就是一百万分之一。
n_iters 虽然也是 m 的整数倍,但是整数倍,通常比批量梯度下降法的迭代次数要少很多,就可以得到比较令人满意的结果。印象中,课程里也针对一个数据集进行了实验,包括对使用的时间进行了计时。
如果感兴趣,你也可以尝试使用一个数据集,测试一下,获得同样的结果,两种梯度下降法的性能差别是怎样的?数据集越大,效果越明显。
继续加油!:)
哦,我好像明白了一点,但不知道这样解释对不对: 批量梯度是m个数据进行1到m的求和,复杂度是O(m^2); 随机梯度是m个数据进行k倍的遍历,复杂度是O(k*m)
严格地说,如果 Xb 是一个 m * n 的矩阵,Xb.T 是一个 n*m 的矩阵,批量梯度的下降法的那个公式,计算一个梯度,是O(n*m*m) 的。整体 iter 轮,就是 O(iter * n * m * m) 的。(矩阵运算岁仍然可以优化,但降不到 O(n*m) 的级别。是的,矩阵运算就是这么慢。)随机梯度度下降法的那个梯度计算公式,是 O(n) 的,整体对所有数据遍历 k 遍,整体时间复杂度是 O(k * m * n)。
sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma sigma
登录后可查看更多问答,登录/注册
Python3+sklearn,兼顾原理、算法底层实现和框架使用。
2.5k 19
3.5k 17
3.0k 15
1.6k 15
1.5k 14