使用树状图可视化聚类

news/2024/12/29 6:29:15/

一般情况下,我们都是使用散点图进行聚类可视化,但是某些的聚类算法可视化时散点图并不理想,所以在这篇文章中,我们介绍如何使用树状图(Dendrograms)对我们的聚类结果进行可视化。

树状图

树状图是显示对象、组或变量之间的层次关系的图表。树状图由在节点或簇处连接的分支组成,它们代表具有相似特征的观察组。分支的高度或节点之间的距离表示组之间的不同或相似程度。也就是说分支越长或节点之间的距离越大,组就越不相似。分支越短或节点之间的距离越小,组越相似。

树状图对于可视化复杂的数据结构和识别具有相似特征的数据子组或簇很有用。它们通常用于生物学、遗传学、生态学、社会科学和其他可以根据相似性或相关性对数据进行分组的领域。

背景知识:

“树状图”一词来自希腊语“dendron”(树)和“gramma”(绘图)。1901年,英国数学家和统计学家卡尔皮尔逊用树状图来显示不同植物种类之间的关系[1]。他称这个图为“聚类图”。这可以被认为是树状图的首次使用。

数据准备

我们将使用几家公司的真实股价来进行聚类。为了方便获取,所以使用 Alpha Vantage 提供的免费 API 来收集数据。Alpha Vantage同时提供免费 API 和高级 API,通过API访问需要密钥,请参考他的网站。

 importpandasaspdimportrequestscompanies={'Apple':'AAPL','Amazon':'AMZN','Facebook':'META','Tesla':'TSLA','Alphabet (Google)':'GOOGL','Shell':'SHEL','Suncor Energy':'SU','Exxon Mobil Corp':'XOM','Lululemon':'LULU','Walmart':'WMT','Carters':'CRI','Childrens Place':'PLCE','TJX Companies':'TJX','Victorias Secret':'VSCO','MACYs':'M','Wayfair':'W','Dollar Tree':'DLTR','CVS Caremark':'CVS','Walgreen':'WBA','Curaleaf':'CURLF'}

科技、零售、石油和天然气以及其他行业中挑选了 20 家公司。

 importtimeall_data={}forkey,valueincompanies.items():  # Replace YOUR_API_KEY with your Alpha Vantage API keyurl=f'https://www.alphavantage.co/query?function=TIME_SERIES_DAILY_ADJUSTED&symbol={value}&apikey=<YOUR_API_KEY>&outputsize=full'response=requests.get(url)data=response.json()time.sleep(15)if'Time Series (Daily)'indataanddata['Time Series (Daily)']:df=pd.DataFrame.from_dict(data['Time Series (Daily)'], orient='index')print(f'Received data for {key}')else:print("Time series data is empty or not available.")df.rename(columns= {'1. open':key}, inplace=True)all_data[key]=df[key]

在上面的代码在 API 调用之间设置了 15 秒的暂停,这样可以保证不会因为太频繁被封掉。

 # find common dates among all data framescommon_dates=Nonefordf_key, dfinall_data.items():ifcommon_datesisNone:common_dates=set(df.index)else:common_dates=common_dates.intersection(df.index)common_dates=sorted(list(common_dates))# create new data frame with common dates as indexdf_combined=pd.DataFrame(index=common_dates)# reindex each data frame with common dates and concatenate horizontallyfordf_key, dfinall_data.items():df_combined=pd.concat([df_combined, df.reindex(common_dates)], axis=1)

将上面的数据整合成我们需要的DF,下面就可以直接使用了

层次聚类

层次聚类(Hierarchical clustering)是一种用于机器学习和数据分析的聚类算法。它使用嵌套簇的层次结构,根据相似性将相似对象分组到簇中。该算法可以是聚集性的可以从单个对象开始并将它们合并成簇,也可以是分裂的,从一个大簇开始并递归地将其分成较小的簇。

需要注意的是并非所有聚类方法都是层次聚类方法,只能在少数聚类算法上使用树状图。

聚类算法我们将使用 scipy 模块中提供的层次聚类。

1、自上而下聚类

 importnumpyasnpimportscipy.cluster.hierarchyasschimportmatplotlib.pyplotasplt# Convert correlation matrix to distance matrixdist_mat=1-df_combined.corr()# Perform top-down clusteringclustering=sch.linkage(dist_mat, method='complete')cuts=sch.cut_tree(clustering, n_clusters=[3, 4])# Plot dendrogramplt.figure(figsize=(10, 5))sch.dendrogram(clustering, labels=list(df_combined.columns), leaf_rotation=90)plt.title('Dendrogram of Company Correlations (Top-Down Clustering)')plt.xlabel('Companies')plt.ylabel('Distance')plt.show()

如何根据树状图确定最佳簇数

找到最佳簇数的最简单方法是查看生成的树状图中使用的颜色数。最佳簇的数量比颜色的数量少一个就可以了。所以根据上面这个树状图,最佳聚类的数量是两个。

另一种找到最佳簇数的方法是识别簇间距离突然变化的点。这称为“拐点”或“肘点”,可用于确定最能捕捉数据变化的聚类数量。上面图中我们可以看到,不同数量的簇之间的最大距离变化发生在 1 和 2 个簇之间。因此,再一次说明最佳簇数是两个。

从树状图中获取任意数量的簇

使用树状图的一个优点是可以通过查看树状图将对象聚类到任意数量的簇中。例如,需要找到两个聚类,可以查看树状图上最顶部的垂直线并决定聚类。比如在这个例子中,如果需要两个簇,那么第一个簇中有四家公司,第二个集群中有 16 个公司。如果我们需要三个簇就可以将第二个簇进一步拆分为 11 个和 5 个公司。如果需要的更多可以依次类推。

2、自下而上聚类

 importnumpyasnpimportscipy.cluster.hierarchyasschimportmatplotlib.pyplotasplt# Convert correlation matrix to distance matrixdist_mat=1-df_combined.corr()# Perform bottom-up clusteringclustering=sch.linkage(dist_mat, method='ward')# Plot dendrogramplt.figure(figsize=(10, 5))sch.dendrogram(clustering, labels=list(df_combined.columns), leaf_rotation=90)plt.title('Dendrogram of Company Correlations (Bottom-Up Clustering)')plt.xlabel('Companies')plt.ylabel('Distance')plt.show()

我们为自下而上的聚类获得的树状图类似于自上而下的聚类。最佳簇数仍然是两个(基于颜色数和“拐点”方法)。但是如果我们需要更多的集群,就会观察到一些细微的差异。这也很正常,因为使用的方法不一样,导致结果会有一些细微的差异。

总结

树状图是可视化复杂数据结构和识别具有相似特征的数据子组或簇的有用工具。在本文中,我们使用层次聚类方法来演示如何创建树状图以及如何确定最佳聚类数。对于我们的数据树状图有助于理解不同公司之间的关系,但它们也可以用于其他各种领域,以理解数据的层次结构。

https://avoid.overfit.cn/post/1271784ad1ea4ff28eea9ef3c9f6f498

作者:Shashindra Silva


http://www.ppmy.cn/news/40899.html

相关文章

探索网络世界的核心:TCPIP协议四层模型解析.md

前言 欢迎来到今天的每日一题&#xff0c;每日一提。今天要聊的是面试中经常会问到tcp协议 。相信在以往的面试中&#xff0c;一定碰到过这个问题吧&#xff1a;什么是TCP/IP协议&#xff1f;它包括哪些层次&#xff1f;。虽然在面试中脱口而出&#xff0c;有四层&#xff1a;应…

有无SSL证书,网站安全大不同

随着互联网时代的发展&#xff0c;用户信息数据量越来越大&#xff0c;同时数据泄露的风险也越来越大。随意搜索一下&#xff0c;用户信息数据泄露等安全问题的事件常有发生。 一些数据泄露的报道事件令大众对于自身数据安全这一块非常敏感&#xff0c;保护自己信息安全的意识…

「抖in新风潮·春夏上新」,新品激活潮流“大”生意

不同的时代风靡各异的潮流&#xff0c;而在当下&#xff0c;更多年轻人正以年轻鲜活的视野&#xff0c;无限放大“自我”的力量&#xff0c;塑造着属于个体的潮流表达。这种基于真我本色的塑造&#xff0c;在抖音又得以被无限地看到&#xff0c;从而无限地聚集同好、引发交流、…

科研热点|2023基金委首批科研不端案件处理结果通报~

2023年查处的不端行为案件处理结果通报&#xff08;第一批次&#xff09; 近期&#xff0c;经国家自然科学基金委员会监督委员会调查审议、国家自然科学基金委员会委务会议审定&#xff0c;国家自然科学基金委员会对相关科研不端案件涉事主体进行了处理。现将给予通报批评的有…

实战大数据项目

存储日志数据集&#xff08;HDFS&#xff09; 数据仓库构建&#xff08;Hive&#xff09; 数据分区表构建 数据预处理 &#xff08;Spark计算引擎&#xff09;-使用Zeppelin进行写SQL 订单指标分析 Sqoop数据导出到传统数据库&#xff08;Mysql&#xff09; Superset数据…

Java设计模式之适配器模式

目录 1、什么是 Java 适配器模式 2、为什么要使用适配器模式 3、适配器模式的应用场景 4、Java代码中使用适配器的例子 1、什么是 Java 适配器模式 Java 适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;用于将一个类的接口转换为客户端…

闲人闲谈PS之四十——项目售前费用归集

惯例闲话&#xff1a;广东这段时间老是下雨&#xff0c;堪比江浙一带梅雨季节&#xff0c;人的心情也像这天气一样&#xff0c;阴雨绵绵。2023年伊始&#xff0c;确实感觉很多事情在发生剧变&#xff0c;这种变化也稍微影响了闲人那本来稳如老狗的心。面对未知和变化&#xff0…

软考第三章 广域通信网

广域通信网 1.公共交换电话网 公共交换电话网PSTN&#xff1a;是为了话音通信而建立的网络&#xff0c;在有些地方用户仍然通过电话线拨号上网 1.1 电话系统的结构 电话系统是一个高度冗余的分级网络。用户电话通过一对铜线连接到最近的端局。 公共电话网由本地网和长途网组…