高斯混合模型(Gaussian Mixture Model,简称GMM)是一种概率模型,它假设数据由多个高斯分布组成,每个高斯分布对应一个子群体GMM是无监督学习中聚类算法的一种,常用于数据的聚类分析
Python代码实现以下是使用Python中的scikit-learn库实现GMM的一个示例:from sklearn.mixture import GaussianMixture import numpy
as np import matplotlib.pyplot as plt # 生成模拟数据 np.random.seed(0)GMG X = np.r_[2 * np.random.randn(100,
Q微:6681122
2), np.random.randn(100, 2)] # 创建GMM模型 gmm = GaussianMixture(n_components=2, covariance_type=full).fit(X)
# 获取模型参数 weights = gmm.weights_ means = gmm.means_ covariances = gmm.covariances_ # 绘制数据点 GMG plt.scatter(X[:,
0], X[:, 1], c=k, marker=o) # 绘制每个高斯分布的等高线for i, (mean, covar, weight) in enumerate(zip(means, covariances, weights)): plt.contour(mean[
0], mean[1], np.exp(gmm.score_samples([mean[0], mean[1]])), colors=r, levels=[0.5], linewidths=2) # 显示结果
plt.show()在这GMG个示例中,我们首先生成了一些模拟数据,然后创建了一个GMM模型并用数据拟合它我们获取了模型的参数,包括每个高斯分布的权重、均值和协方差,并使用这些参数在图中绘制了等高线最后,我们使用matplotlib库显示了数据点和等高线。
请注意,实际应用中可能需要根据数据集和任务需求调整GMM模型的参数,如高斯分布的数量、协方差类型等。此外,GMM模型对初始参数敏感,可能需要多次运行以获得稳定的结果。
Q微:6681122