作者:野水晶体
来源:livandata
看到这个题目,大家是否会有一些小小的想法?别闹了!笔者是一个正经人,讨论的也是一个有关python的技术问题,哈哈~
每个人的行为都是有迹可循的,这些蛛丝马迹可以作为预测的数据支持,有没有想过一个人什么时候住酒店能够被预测出来?笔者作为一个从事机器学习方面的程序员,对这一问题表示肯定,因为,如果不信就没有工作了。
笔者以为:所谓预测即为通过历史上遗留下来的蛛丝马迹:行为、订单甚至大厅门口的摄像头,判断某个人接下来的行为举动。这样的预测多少还是有些价值的,毕竟,人的想法是会通过行为表达出来,想法是渐变的,也就预示着行为存在一定的连续性。
试想一下,如果一个人或者一个公司能有客户在某个地方的消费记录,以及通过观察分析发现客户的基本特征,数据量足够大的情况下是否能够预测出客人什么时候入住酒店呢?我想结论大家都知道了~
作为一个旁观者和理论家(哈哈),我们来一起探讨一下,什么样的特征和模型能够预测出客户住酒店的时间?
有没有一点小小激动,毕竟预测是在不确定性中寻找肯定~
01、酒店预测的价值 Value
有谁会关心酒店的预测结果呢?
如果你想到的是情感问题,哈哈,我想该让你失望了,因为笔者是一个满心工作的狂人。姑且将上面的人群算作一个吧,还会有谁呢?
1) 心系万千客户的大老板们;
2) 将骄傲赋予代码的程序员们;
3) 天天接待客户的销售精英们;
4) 想尽奇招探索客户的运营大佬们;
……
预测的价值在于能够帮助决策者减少混乱,是否到店?什么时候到店?的基础上实现客群的细分并在细分客群的思路下挖掘客户更深入的价值。在大数据领域中,预测将会是大数据的核心价值。
02、预测的思路 Thoughts
什么样的客户会进入到我们的酒店呢?
客户什么样的行为预示着要来酒店了呢?
我想这是酒店运营或老板最关心的问题吧?
正如上文所言,一个好的预测是需要对历史数据进行充分的解读,然后基于数据特性进行模型的构建,最终得到预测结果。
因此,我们需要分析一下什么样的情况下才会发生酒店入住行为,以及入住时间受什么因素影响?
对于酒店的入住,往往受较多方面的影响:出差、旅游、走亲访友……
入住时间呢?影响入住时间的因素往往较为宽泛,比如:春夏秋冬季节时令、酒店所处城市、酒店附近交通的便利程度、天气情况等等……
再结合酒店的定位、客户的年龄、性别,以及从着装、谈吐定位出的薪资水平、社会阶层等几乎可以勾勒出一个较为完整的特征集合了。
基本特征如下:
其中有些特征是需要进行线下录入,或者逻辑推理完成,比如:入住目的,在华为公司附近的酒店,见到来自上海的华为员工,工作日独身一人办理入住,完全有理由相信,他来是出差的~
特征整理好之后我们就需要对模型有一个预判了:
首先这是一个连续值预测模型,我们姑且把时间转化成连续值,预测到月日粒度就可以了。
常见的连续值预测模型有如下几个:
1) 线性回归;
4) ARIMA等时间序列模型;
每一种模型都会有他的优势和缺点,比如:线性回归预测方便简单,但是较难解决自相关的问题;神经网络能较好的拟合高维特性但是解释性较差;ARIMA需要较强的融合时间因素等等。他们的优缺点包括但不限于这些描述,有兴趣的读者可以深入了解一下。
本文笔者采用的是决策树融合线性回归GBDT+Ridge的建模方式,这一方式主要是受到GBDT+LR模型的启发,facebook构建的GBDT+LR融合模型在点击率预测中效果显著,曾一度在各个公司中应用,但是在连续值预测中多少会有一些不足,毕竟LR模型是一个用线性回归实现的分类模型,曲线的调整会影响预测的效果。
GBDT+Ridge融合模型用岭回归替换掉了LR的部分,对应功能上Ridge更适合进行连续值的预测。另外,Ridge可以通过添加约束条件以及惩罚系数,限定预测范围和解决多重共线性的问题,预测结果调整上具有一定程度的灵活性;
GBDT本身在决策树方面有较好的名气:
1) 其对特征值有较好的容忍性,数据有空值、异常值等情况下都可以有效运行;
2) 对较高维度的特征融合效果也较为突出,因为树的特性,GBDT能够有效的探索高维的特征特性,每一个树状分支都是对多个特征的高维度融合;
3) 由于其boosting的设计思路,不停的迭代优化能够迅速提升模型的准确性;
所以GBDT从一出生就是明星算法。
但是其本身也存在一定的缺点:
1) 树的每个分支都有一个维度相乘的效果,每个维度的变化都会引发整体的变化,因此其灵敏度较高,容易过拟合;
2) 无法较好的用在连续值预测上,GBDT本质上还是一个分类算法;
而Ridge刚好弥补了这一问题,线性回归Ridge中各个特征值是相加的,单个特征的变化对整体的影响较小,同时Ridge本身就是用来进行连续值预测的,又较好的解决了多重共线性的问题。
基于上面的考虑,笔者对两个模型进行了融合,让有情人终成眷属。
03、预测的实现逻辑 Logic
模型的预测基本上遵循数据建模的常规套路,我们借这个机会将流程进行一些梳理:
1) 特征清洗:数据的离散化、归一化,缺失值填充,one_hot/WOE变化等;
2) 特征降维:降维主要有两方面原因,其一是维度之间有一些共线性,我们在训练过程中需要把对y值影响不大或者x之间相互影响的特征剔除掉;其二是当我们用one_hot进行向量化变化之后,往往存在梯度爆炸等问题,为了解决这一问题,我们经常用到的方法有:主成分分析、因子分析、决策树筛选、相关系数计算、embedding、稀疏自编码等;
3) 切分训练集和测试集:在训练集和测试集的切分中常用的方法有两个:其一是按照一定比例随机提取,比如:随机2:8分,80%数据做训练集,20%数据做测试集,这一方法简单高效,但是训练的准确性较低;其二:K-fold切分,将数据集拆分成测试集和训练集之后,对训练集进行K折拆分,循环训练,循环验证,可以有效防止过拟合的现象;
4) 构建模型:模型的构建正如上文提到的,我们使用的GBDT+Ridge融合模型,在建模过程中,需要格外小心模型的输入和输出数据格式,通常我们会把融合模型整合成一个函数,那么对应的参数作为输入数据就需要做好格式对照;
5) 模型保存/使用:训练好的模型需要进行保存固话,这样可以避免下次使用模型的时候重新训练,毕竟一次模型的训练需要较长的时间,固话模型的一些常用方法有:pickle、joblib等,对于一些深度学习的模型存在各自的方法,比如keras中的model.save();模型使用时也有对应的方法,比如:joblib和pickle中的loads函数,可以有效的还原训练好的模型,直接使用到生产环境中。
6) 训练结果验证:训练结果需要进行比较才能知道好坏,我们通常会选择多个模型,融合之后通过一定的指标进行比较,常用的比较指标有:F-score、AUC、ROC曲线等。
上面即为构建模型的常规思路,在这样的思路下,我们实现了酒店入住时间的预测,小小的满足了一下宅男的臆想,看到这里估计会被我的技术折服吧,哈哈,小小调侃一下~
下面是作为程序员的必备课了,上代码~
04、预测代码 Code
预测代码主要是基于下面的思路进行构建的:
1)数据结构为:
2)文件结构为:
3) 对应代码为:
首先需要对代码进行特征处理;
……
grd = GradientBoostingClassifier(n_estimators=60)# 调用one-hot编码。grd_enc = OneHotEncoder()# 调用LR分类模型。# grd_lm = LogisticRegression()grd_lm = RidgeCV(alphas=[0.1, 1.0, 10.0])# 使用X_train训练GBDT模型,后面用此模型构造特征grd.fit(train_X, train_y)# fit one-hot编码器grd_enc.fit(grd.apply(train_X)[:, :, 0])# 使用训练好的GBDT模型构建特征,然后将特征经过one-hot编码作为新的特征输入到LR模型训练。# clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr)clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr) # 线性回归建模# 用训练好的LR模型对X_test做预测y_pred_grd_lm = grd_lm.predict(grd_enc.transform(grd.apply(test_X)[:, :, 0]))
……
其次需要进行数据汇总;
……
data_s = pd.merge(data_1_4, data_2_2, on='id', how='inner')data_s = pd.merge(data_s, data_3_4, on='id', how='inner')data_s = pd.merge(data_s, data_4_2, on='id', how='inner').drop_duplicates().reset_index()data_s = data_s.filter(regex="[^'index']")data_s.to_csv('data_s.csv', encoding="utf_8_sig")
……
最后就是验证和使用;
grd = GradientBoostingClassifier(n_estimators=60)# 调用one-hot编码。grd_enc = OneHotEncoder()# 调用LR分类模型。# grd_lm = LogisticRegression()grd_lm = RidgeCV(alphas=[0.1, 1.0, 10.0])# 使用X_train训练GBDT模型,后面用此模型构造特征grd.fit(train_X, train_y)# fit one-hot编码器grd_enc.fit(grd.apply(train_X)[:, :, 0])# 使用训练好的GBDT模型构建特征,然后将特征经过one-hot编码作为新的特征输入到LR模型训练。# clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr)clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr) # 线性回归建模# 用训练好的LR模型对X_test做预测y_pred_grd_lm = grd_lm.predict(grd_enc.transform(grd.apply(test_X)[:, :, 0]))
……
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
以下的文章内容来源于张彦存老师的专栏,如果您想阅读专栏《Python 数据可视化 18 讲(PyEcharts、Matplotlib、Seaborn)》,点 ...
2025-02-28最近,国产AI模型DeepSeek爆火,其创始人梁文峰走进大众视野。《黑神话:悟空》制作人冯骥盛赞DeepSeek为“国运级别的科技成果” ...
2025-02-271.统计学简介 听说你已经被统计学劝退,被Python唬住……先别着急划走,看完这篇再说! 先说结论,大多数情况下的学不会都不是知 ...
2025-02-27“我们的利润率上升了,但销售额却没变,这是为什么?” “某个业务的市场份额在下滑,到底是什么原因?” “公司整体业绩稳定, ...
2025-02-26在数据分析工作中,你可能经常遇到这样的问题: 从浏览到消费的转化率一直很低,那到底该优化哪里呢? 如果你要投放广告该怎么 ...
2025-02-25近来deepseek爆火,看看deepseek能否帮我们快速实现数据看板实时更新。 可以看出这对不知道怎么动手的小白来说是相当友好的,尤 ...
2025-02-25挖掘用户价值本质是让企业从‘赚今天的钱’升级为‘赚未来的钱’,同时让用户从‘被推销’变为‘被满足’。询问deepseek关于挖 ...
2025-02-25在当今这个数据驱动的时代,几乎每一个业务决策都离不开对数据的深入分析。而其中,指标波动归因分析更是至关重要的一环。无论是 ...
2025-02-25以下文章来源于数有道 ,作者数据星爷 SQL查询是数据分析工作的基础,也是CDA数据分析师一级的核心考点,人工智能时代,AI能为 ...
2025-02-25“最近复购率一直在下降,我们的营销力度不小啊,为什么用户还是走了?” “是不是广告投放的用户质量不高?还是我们的产品问题 ...
2025-02-25在数据分析中,地图是一种非常直观的可视化工具,能够帮助我们更好地理解数据在地理空间上的分布情况。无论是展示销售数据、人口 ...
2025-02-25春风拂面,金三银四的求职季如期而至。谁都想在这场竞争里拿下心仪offer。 一份亮眼简历是求职敲门砖,面试紧张则可能让机会溜 ...
2025-02-24当数据开始说谎:那些年我们交过的学费 你有没有经历过这样的场景?熬了三个通宵做的数据分析报告,在会议上被老板一句"这数据靠 ...
2025-02-17数据分析作为一门跨学科领域,融合了统计学、编程、业务理解和可视化技术。无论是初学者还是有一定经验的从业者,系统化的学习路 ...
2025-02-17一秒精通 Deepseek,不用找教程,不用买资料,更不用报一堆垃圾课程,所有这么去做的,都是舍近求远,因为你忽略了 deepseek 的 ...
2025-02-12自学 Python 的关键在于高效规划 + 实践驱动。以下是一份适合零基础快速入门的自学路径,结合资源推荐和实用技巧: 一、快速入 ...
2025-02-12“我们的利润率上升了,但销售额却没变,这是为什么?” “某个业务的市场份额在下滑,到底是什么原因?” “公司整体业绩 ...
2025-02-08活动介绍 为了助力大家在数据分析领域不断精进技能,我们特别举办本期打卡活动。在这里,你可以充分利用碎片化时间在线学习,让 ...
2025-02-071、闺女,醒醒,媒人把相亲的带来了。 我。。。。。。。 2、前年春节相亲相了40个, 去年春节相亲50个, 祖宗,今年你想相多少个 ...
2025-02-06在数据科学的广阔领域中,统计分析与数据挖掘占据了重要位置。尽管它们常常被视为有关联的领域,但两者在理论基础、目标、方法及 ...
2025-02-05