现在很多想从事于机器学习的朋友都存在很多困惑,主要是很多相关的书看不懂,尤其是数学部分,机器学习的基础是数学。数学并非是一个可选可不选的理论方法,而是不可或缺的支柱。对于机器学习算法工程师而言,微积分、线性代数、概率论毫无疑问是需要掌握的。
为什么要强调数学?
毫无疑问机器学习中数学是重要的,例如你需要:
1.选择合适的算法,包括考虑精度、训练时间、模型的复杂性、参数和数量特征;
2.选择参数设置和验证策略;
3.通过了解偏差方差权衡来识别拟合不足与过度拟合;
4.估计正确的置信区间和不确定性。
你必需具备的数学知识
概率论
概率是机器学习算法中频繁用到的。不过基础的概率知识在统计学中已经包括了,而比较深入的概率知识其实在机器学习算法设计的时候并不经常用到。
线性代数
向量和矩阵
矩阵的行列式
特征向量和特征值
矩阵分解(如 SVD)
线性代数在深度学习领域有着举足轻重的作用,它是深度学习各种算法的基本数学工具。尤其是矩阵的各种变换,因为大量机器学习算法都是在和矩阵打交道。
微积分
比如,现在无比热门的神经网络,优化方法几乎全是基于梯度下降,而梯度下降,其实就是链式求导。不过,理工科应该都学过这方面的课程。
最好要掌握:
离散数学:毕竟离散数学是描述计算机问题的基础。许多算法的思想也是基于离散数学的。离散数学研究的一些问题对于描述计算机问题也有很大启发。
随机过程,实分析:机器学习往深里做肯定需要用这种,高级的数学语言去对问题进行描述。
泛函:泛函分析是一门非常抽象的课程。泛函的很多内容都是从数学分析,线性代数,实分析等抽象出来的,同时也是它们的推广,泛函研究更广泛更一般的空间,研究共性的问题。而数学分析,高等代数研究的是个性的问题,都很具体。
各种算法和理论用到的数学知识
下面我们一张图来看典型算法和理论结论所用到的数学知识:
本文作者:王奶奶卖瓜 来源:知乎
CIO之家 www.ciozj.com 微信公众号:imciow