python 聚类 特征权重_如何在python中执行权重/密度的集群?像重量的kmeans?

Or is there something else I should be using for this problem that would be better?

为了同时考虑中心之间的地理距离和产生的功率,您应该定义适当的度量.下面的函数计算地球表面上两个点之间的距离,从纬度和经度到haversine formula,并将生成的功率差的绝对值乘以加权因子.权重值决定了聚类过程中距离和功率差异的相对影响.

import numpy as np

def custom_metric(central_1, central_2, weight=1):

lat1, lng1, pow1 = central_1

lat2, lng2, pow2 = central_2

lat1, lat2, lng1, lng2 = np.deg2rad(np.asarray([lat1, lat2, lng1, lng2]))

dlat = lat2 - lat1

dlng = lng2 - lng1

h = (1 - np.cos(dlat))/2. + np.cos(lat1)*np.cos(lat2)*(1 - np.cos(dlng))/2.

km = 2*6371*np.arcsin(np.sqrt(h))

MW = np.abs(pow2 - pow1)

return km + weight*MW

Should I be doing this with kmeans (or some other method)?

不幸的是,SciPy的kmeans2和scikit-learn的KMeans的当前实现仅支持欧几里德距离.另一种方法是通过SciPy的聚类包执行hierarchical clustering,根据刚定义的度量对中心进行分组.

演示

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值