机器学习A-Z~分类模型性能评价及选择

本篇文章将给大家介绍一些宏观的核心概念和测度来评价分类算法和分类器的表现,尤其是如何评价分类器预测中会产生的一些错误。

伪阳性(False Positives)和伪阴性(False Positives)

首先讲的是伪阳性和伪阴性,英文叫做False Positives和False Negatives。先回到之前逻辑回归的例子,下图画出了sigmod函数,用来预测某件事情是否会发生,比如用户是否会购买产品。

image

我们把概率小于0.5的视作不会买,超过0.5的用户会购买。假设现在已知四个用户,13没有购买,24购买了。但我们依然可以用分类器去尝试预测结果。

image

我们将数据点投射到头像上,会发现有两种不同的错误,对于3号用户的错误,我们称作伪阳性,或者叫做1型错误,对于2号错误,称作伪阴性或者叫做2型错误。一般来说2型错误比1型错误要严重的多。比如判断艾滋病,假设如果我们判断一个没有疾病的人是阳性的,这个结果有一定的严重性,但会做再次的检测最终解决掉。但如果实际上是病毒携带者但判断成阴性,这个结果相对来说要严重的多,因为可能会耽误对疾病的治疗。

混淆矩阵(Confusion Matrix)

混淆矩阵在之前的文章有提及过,这里再大致解释一下。如下图所示,横轴指的是实际的值,纵轴是预测的值。

混淆矩阵

35代表的就是实际值是0我们预测也是0的个数,50指的是实际1预测也是1的个数。显然这里也可以看出5代表伪阳性的个数,10代表伪阴性的个数。此时可以得到两个比值,一个是正确率即正确的判断个数35+50=85除以总的个数100,一个是错误的个数10+5=15除以总个数100。

准确率悖论

混淆矩阵中有时候这两个比值并不能说明太大的问题,有时候需要更加高级的方法评价分类器的好坏。来看看下面的矩阵:

image

很显然可以计算出正确率等于98%,这时是否能说明这个分类器的质量很好?现在我们给出一个新的分类方法,不管什么养的数据,都预测为0.就相当于右边一列的数字都加到左边一列中。现在再计算准确率,会发现准确率变成了98.5%。也就是说虽然用的方法很简单粗暴,但实际准确率却比前一个更好。这说明通过这种方式在这种情景下不适合判断分类的结果,需要使用其他更好的方法。

累计准确曲线(Cumulative Accuracy Profile)

上面的案例中可以看出通过混淆矩阵有时候不能很好的判断分类结果的质量,现在来看一个更加高级的判断方法,叫做累计准确曲线(CAP)。来看下面的例子,横走为我们联系的客户,纵轴为后买的客户数量。

image

那么这时可以得到一条直线,这些客户都是通过我们随机抽样联系的客户,随着抽样人数的增加,会购买的用户数量会逐渐变多。此时假设我们使用训练好的算法来判断用户是否会购买产品,得到预测的结果后,我们可以优先去联系预测结果是会购买产品的客户,这样我们刚开始联系的客户会有很大概率是会购买产品的,随着联系人数的增加,比如到了60000,预测剩下的人不会购买产品,此时从公司的角度出发实际上是可以不去联系这剩下的客户,因为他们购买的概率比较小。但这里为了完整画出曲线,还是继续画出后面的点。也就是说不管用什么样的模型,当我们完整的联系所有的客户群,也就是100000个客户,最后的点一定是重合的。

image

很显然这条曲线在之前的图像之上,因为我们使用了机器学习算法,使得公司的运营更加的有效率。这个模型越好,那么这个模型就会越凸。现在将横纵轴上的值变成百分比。横轴的100%指的是百分百的客户群,纵轴的100%指的是估算出的会购买的用户总数。

image

假设现在有另一个模型,没有红色的模型好。那么它可能的图像就会如上面绿色曲线。因为如果用更好的模型,那么某个点中实际上会购买的用户的量应该是比较靠上的。相对于之前的混淆矩阵,这是提供了更多的信息来判断模型的好坏。假设这时有个非常好的模型,我们称作做Crystal Ball,这个图像会是什么样子?我们之前随机抽样中知道10000中大约有10000个人会购买产品,也就是说有百分之十的人会购买,那么这个最好的模型就是一开始就找到这百分之十的人。

image

如上图黑色的线,在10%的位置就达到图像的顶点,后面是一条与横轴平行的直线。这种模型可以说是最完美的模型,几乎不可能达到的,所以叫做水晶球模型。如果我们有条曲线出现在蓝色的曲线下方的话,这说明这个模型非但没取到更好的预测效果,甚至不如一个随机的抽样,这是比较容易发现的。

除了CAP曲线,实际生活中,还有一种可能用到的曲线和其类似,叫做ROC(Receiver Operating Characteristic),大家可以自行去查询资料。

那么我们知道上图中红色的曲线是越靠近完美曲线说明模型越好,现在来看看如何来量化这种好与不好。我们定义a_P表示完美曲线和蓝色曲线所包含的面积,定义a_R为自己机器学习模型和蓝色曲线的面积。此时再定义AR=\frac{a_R}{a_P},则这个比值越接近1说明我们建立的模型效果越好。现在已经有一些统计学上的工具来计算这个比值。但自己手动计算或者用机器来计算都比较麻烦,那么现在提供一个简单的经验法则来判断模型的好坏。

这时要用到一个50%的阈值,就是在x轴上找到50%的点,看看在模型上的点y轴坐标是多少。通过这个点就能提供很好的信息。

image

如上图所示,我们将X的值划分不同的区间,当X的值坐落于不同区间时,给出不同的评价。由于随机模型它在50%的点达到了50%,则X<60%说明比随机好不了多少,则判定其是个特别差的模型。再好一点就是一个比较差的模型,继续往上就是好的模型,随着X的增大则这个模型越来越好。

但超过90%时,这个模型就好的夸张了,这时候要引起注意。这并不是我们想要的结果。第一种情况,如果有个自变量和因变量有着非常紧密的因果关系时,比如跟用户打电话的次数,这是有着非常强的因果关系,那么这个时候就需要把这个特征从我们的自变量中剔除。第二种情况就是过拟合,就是模型过多的注意到训练集中的噪音,这也是需要注意的。但也有一些情况坐落的大于90%是因为训练集质量非常高,或者说建的模型非常好。

分类算法总结

分类算法目前已经讲了6个,下面提供各个分类模型优劣的汇总于说明(此部分主要节选于于机器学习A-Z课程的第三部分小结):

image

对于不同的案例,如何选择模型,首先第一步判断线性还是非线性:

  • 假如是线性的问题,您应该选择逻辑回归(logistic regression)或者支持向量机SVM。
  • 假如是非线性的问题,您应该选择朴素贝叶斯(naive bayes),决策树(decision tree)或者是随机森林(random forest)。在接下来的课程中我们会讲到神经网络(neural network),也是一个十分强大的方法。

从实际操作的角度也有一些规则:

  • 假如您想要给最终预测概率进行排序,您应该选择逻辑回归(logistic regression)或是朴素贝叶斯(Naive Bayes)。举个例子:您想要预测不同客户购买某项产品的概率,并将这些概率从大到小进行排序,以便锁定目标客户群。在这样的情形下,如果您的问题是线性的,您应该运用逻辑回归(logistic regression);假如您的问题是非线性的,您应该选择朴素贝叶斯(naive bayes)模型。
  • 假如您想要预测每一个客户属于哪一个划分(segment),您应该选择SVM。市场和客户群体的划分可以是已完成的市场调研或者集群分析(clustering)的结果。
  • 假如您想要非常直观地展示/阐述模型,那么决策树(Decision Tree)是最佳选择。
  • 假如您想要最好的模型的分类表现,并且不太在意模型的展示/阐述,那么随机森林(random forest)是不错的选择。

以上,就是对分类模型的性能评价及选择的相关基础知识点。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270