冷夜寒池
机器学习方面的面试主要分成三个部分:1.算法和理论基础2.工程实现能力与编码水平3.业务理解和思考深度1.理论方面,我推荐最经典的一本书《统计学习方法》,这书可能不是最全的,但是讲得最精髓,薄薄一本,适合面试前突击准备。我认为一些要点是:统计学习的核心步骤:模型、策略、算法,你应当对logistic、SVM、决策树、KNN及各种聚类方法有深刻的理解。能够随手写出这些算法的核心递归步的伪代码以及他们优化的函数表达式和对偶问题形式。非统计学习我不太懂,做过复杂网络,但是这个比较深,面试可能很难考到。数学知识方面,你应当深刻理解矩阵的各种变换,尤其是特征值相关的知识。算法方面:你应当深刻理解常用的优化方法:梯度下降、牛顿法、各种随机搜索算法(基因、蚁群等等),深刻理解的意思是你要知道梯度下降是用平面来逼近局部,牛顿法是用曲面逼近局部等等。2.工程实现能力与编码水平机器学习从工程实现一般来讲都是某种数据结构上的搜索问题。你应当深刻理解在1中列出的各种算法对应应该采用的数据结构和对应的搜索方法。比如KNN对应的KD树、如何给图结构设计数据结构?如何将算法map-red化等等。一般来说要么你会写C,而且会用MPI,要么你懂Hadoop,工程上基本都是在这两个平台实现。实在不济你也学个python吧。3.非常令人失望地告诉你尽管机器学习主要会考察1和2但是实际工作中,算法的先进性对真正业务结果的影响,大概不到30%。当然算法必须要足够快,离线算法最好能在4小时内完成,实时算法我没搞过,要求大概更高。机器学习大多数场景是搜索、广告、垃圾过滤、安全、推荐系统等等。对业务有深刻的理解对你做出来的系统的结果影响超过70%。这里你没做过实际的项目,是完全不可能有任何体会的,我做过一个推荐系统,没有什么算法上的高大上的改进,主要是业务逻辑的创新,直接就提高了很明显的一个CTR(具体数目不太方便透露,总之很明显就是了)。如果你做过实际的项目,一定要主动说出来,主动让面试官知道,这才是最大最大的加分项目。最后举个例子,阿里内部机器学习挑战赛,无数碾压答主10000倍的大神参赛。最后冠军没有用任何高大上的算法而是基于对数据和业务的深刻理解和极其细致的特征调优利用非常基本的一个算法夺冠。所以啥都不如真正的实操撸几个生产项目啊。
爱笑的眼乌珠
机器学习工程师大部分先考你的代码能力和算法能力。你先需要了解算法基础和数据结构,能熟练的在纸上写出代码,并能够顾及到边界或者安全性检验。然后你才会到第二关。一般会根据你以前的工作或者项目经历,延展出一些模型的基本目标函数以及求解方式。有时候我们也会问你一些基本问题,比如为什么SVM保证边界最大化,L1regression为什么可以锐减featurespace,LDA、EM的基本思路等。如果你ML基础很牛,代码或者算法较差,会犹豫;算法、代码很牛,ML知道一点一般让过。有一定算法能力且ML有一定基础,比较受欢迎。
优质工程师考试问答知识库