数据分享|R语言交互可视化分析Zillow房屋市场:arima、VAR时间序列、XGBoost、主成分分析、LASSO报告

简介: 数据分享|R语言交互可视化分析Zillow房屋市场:arima、VAR时间序列、XGBoost、主成分分析、LASSO报告

全文链接:http://tecdat.cn/?p=32427

分析师:Xueyan Liu


在当前海量数据和资源的情况下,面对客户需求,如何找准需求标的和问题核心,并围绕该目标问题挖掘数据、确定市场重要关联因素、分层分类筛选可能关联因素,是当前数据分析运用的关键点击文末“阅读原文”获取完整数据


解决方案


任务/目标

此项目根据全美房地产相关多源数据查看文末了解数据免费获取方式,旨在用数据创建一个报告, 全方面多维度展示美国房屋市场现状。以房屋售价为核心,梳理主要相关指标,并挖掘其他可能相关性指标,通过对单一或多个指标,精准选择合理算法建模,对房屋市场未来发展作出预测,用以更好的展现市场的全貌。

数据准备:

前期数据来源:通过搜过官方或者新闻媒体的行业报告中的数据来源,初始数据包括:月度房地产相关数据

后期数据来源:根据探索性分析后的结果,有针对性的在开源数据库进行关键词搜索,包括

探索性数据分析(EDA):

通过对数据进行清洗,将数据可视化;从统计分布,地域分布,时间分布等多维度进行分析、寻找数据之间的关系,并由此分析出更多可能相关因素,以进一步深入挖掘。

为了更清晰的表现数据,采用R中flexdashboard制作可互动性报告,并尽可能采用多种不同的图表,以最大效用可视化数据。例如:创建条形图,对比房屋挂牌价和实际售价的分布;或者创建地图,以示不同地区房屋售价或者租金分布的差异。

 

创建预测模型:

使用预测模型,以更好的了解行业未来的发展趋势:

SARIMA 时间序列模型

基于arima时间序列模型之上,考虑了季节性因素。把过去的值(AR)、过去的预测误差(MA)、过去值之间的差异(I)和季节长度(S)作为预测参数。通过对PACF和ACF的分析,找到最优参数,来进行预测。

VAR 时间序列模型

VAR也称为向量自回归模型, 是一种在自回归模型的基础上扩展模型。VAR模型即将内生滞后值,也将同期的外生滞后项视为回归量,可在单个模型中同时预测多个时间序列相关变量。

XGBoost 模型

是一种常见的决策树算模型,他通过不对的已有的树修正再创建新书,直到最优结果。当用于时间序列预测时,需要把时间序列数据转化为监督数据:把需要预测目标数据为因变量,把时间点拆分为年份和月,作为哑变量。

 

其他可能性因素相关性验证:

除去房屋市场自身产业指标对房价的影响,再挖掘其他可能性影响因素后,需要验证这些指标是否相关。

相关系数矩阵

直观的表现出不同指标关联性的强弱。

特征提取模型

通过建模型,降低数据维度,挑选出重要指标。既可以为日后预测建模提供统计学的数据参考,也可以侧面说明该指标对房价有很大的影响

1. PCA 主成分分析

通常用于减少维数。它用于将具有许多列的数据集减少到较少的列数,而不会丢失数据的本质。作为附带结果,它还提供了变量之间的相关性。PCA将24个指标缩减为能解释90%的主要成分数,并将特征在降维方面起了作用的重要程度排名筛选出最重要的五个特征。

2. LASSO

Lasso算法是一种监督算法,尝试找出所有独立变量与目标变量之间的相关性。Lasso变量的系数逼近零,实现收缩。通过交叉验证找到最佳约束参数。

EDA 结果:

下图仅为报告的可交互式dashboard部分截图,涵盖了部分EDA结果。

通过EDA的分析,我发现房价展现出较为稳定的周期性和增长趋势,并和部分其他指标有着关联性,因此挑选了三种不同的模型可能适用的模型(VAR,SARIMA,XGBOOST),在下一部分进行预测分析

同时EDA也展示房屋市场各类指标表现出较强的地域差异,由此展开深入挖掘,通过二次数据搜索和调查,进行相关性分析


点击标题查阅往期内容


PYTHON链家租房数据分析:岭回归、LASSO、随机森林、XGBOOST、KERAS神经网络、KMEANS聚类、地理可视化


01

02

03

04


预测模型结果:

三个模型中最精确的是SARIMA模型。但是从图像来看该模型没有很好的计算出季节性,经过再次尝试在去掉季节性因素后SARIMA模型的准确率又有了进一步提升。

而从Var 模型的系数p值结果来看,相关外生因素并没有显著性差异。XGBoost模型在面对有明显趋势的时间序列数据并不占优。

 

以三个预测模型作为参考,但是基本上都预示了房价在未来会稳定上涨的趋势。

 

其他可能性因素相关性分析结果:

下图从左至右分别是相关系数矩阵、PCA和LASSO算法结果的可视化

额外的24个因素中,虽然不同的方法结果有所不同,总的来说教育产业相关的指标均表现出较高的相关性,可以得出结论,房屋市场和教育产业高度相关。同时这些高度相关的指标也可以作为一个特征选择的参考,以便日后做进一步研究。

 

总结


以上展现所有的结果,包括:数据可视化,算法应用等都是研究房屋市场现状的一个手段不是目的。

想要用数据分析全方面的了解一个行业,不能仅限于行业里的数字研究,还需要发散性思考,结合市场调查或者行业领域专家的意见,对分析角度进行增补。这样才能更好的将数据分析运用到实际中去。


关于分析师


在此对Xueyan Liu对本文所作的贡献表示诚挚感谢,她在乔治城大学完成了数据科学专业的硕士学位。擅长数据整理,可视化数据和模型,统计学习,机器学习, 时间序列。


相关文章
|
5月前
|
数据采集 机器学习/深度学习 数据可视化
R语言从数据到决策:R语言在商业分析中的实践
【9月更文挑战第1天】R语言在商业分析中的应用广泛而深入,从数据收集、预处理、分析到预测模型构建和决策支持,R语言都提供了强大的工具和功能。通过学习和掌握R语言在商业分析中的实践应用,我们可以更好地利用数据驱动企业决策,提升企业的竞争力和盈利能力。未来,随着大数据和人工智能技术的不断发展,R语言在商业分析领域的应用将更加广泛和深入,为企业带来更多的机遇和挑战。
|
4月前
|
数据挖掘 C语言 C++
R语言是一种强大的统计分析工具,提供了丰富的函数和包用于时间序列分析。
【10月更文挑战第21天】时间序列分析是一种重要的数据分析方法,广泛应用于经济学、金融学、气象学、生态学等领域。R语言是一种强大的统计分析工具,提供了丰富的函数和包用于时间序列分析。本文将介绍使用R语言进行时间序列分析的基本概念、方法和实例,帮助读者掌握R语言在时间序列分析中的应用。
79 3
|
5月前
|
数据采集 数据可视化 数据挖掘
R语言在金融数据分析中的深度应用:探索数据背后的市场智慧
【9月更文挑战第1天】R语言在金融数据分析中展现出了强大的功能和广泛的应用前景。通过丰富的数据处理函数、强大的统计分析功能和优秀的可视化效果,R语言能够帮助金融机构深入挖掘数据价值,洞察市场动态。未来,随着金融数据的不断积累和技术的不断进步,R语言在金融数据分析中的应用将更加广泛和深入。
|
6月前
|
机器学习/深度学习 数据采集 数据可视化
R语言在数据科学中的应用实例:探索与预测分析
【8月更文挑战第31天】通过上述实例,我们展示了R语言在数据科学中的强大应用。从数据准备、探索、预处理到建模与预测,R语言提供了完整的解决方案和丰富的工具集。当然,数据科学远不止于此,随着技术的不断发展和业务需求的不断变化,我们需要不断学习和探索新的方法和工具,以更好地应对挑战,挖掘数据的潜在价值。 未来,随着大数据和人工智能技术的普及,R语言在数据科学领域的应用将更加广泛和深入。我们期待看到更多创新的应用实例,为各行各业的发展注入新的动力。
|
9月前
|
数据可视化 数据挖掘 API
【R语言实战】聚类分析及可视化
【R语言实战】聚类分析及可视化
|
9月前
|
机器学习/深度学习 数据可视化
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为2
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为
|
6月前
|
数据采集 存储 数据可视化
R语言时间序列分析:处理与建模时间序列数据的深度探索
【8月更文挑战第31天】R语言作为一款功能强大的数据分析工具,为处理时间序列数据提供了丰富的函数和包。从数据读取、预处理、建模到可视化,R语言都提供了灵活且强大的解决方案。然而,时间序列数据的处理和分析是一个复杂的过程,需要结合具体的应用场景和需求来选择合适的方法和模型。希望本文能为读者在R语言中进行时间序列分析提供一些有益的参考和启示。
|
6月前
|
资源调度 数据挖掘
R语言回归分析:线性回归模型的构建与评估
【8月更文挑战第31天】线性回归模型是统计分析中一种重要且实用的工具,能够帮助我们理解和预测自变量与因变量之间的线性关系。在R语言中,我们可以轻松地构建和评估线性回归模型,从而对数据背后的关系进行深入的探索和分析。
|
6月前
|
机器学习/深度学习 数据采集
R语言逻辑回归、GAM、LDA、KNN、PCA主成分分类分析预测房价及交叉验证
上述介绍仅为简要概述,每个模型在实施时都需要仔细调整与优化。为了实现高度精确的预测,模型选择与调参是至关重要的步骤,并且交叉验证是提升模型稳健性的有效途径。在真实世界的房价预测问题中,可能还需要结合地域经济、市场趋势等宏观因素进行综合分析。
110 3
|
9月前
|
数据采集 数据可视化
利用R语言进行因子分析实战(数据+代码+可视化+详细分析)
利用R语言进行因子分析实战(数据+代码+可视化+详细分析)