Python:根据散点局部密度进行等高线展示

from pylab import *
from sklearn import datasets
import matplotlib.pyplot as plt
import numpy as np
from scipy.spatial.distance import pdist,squareform

X, y = datasets.make_blobs(n_samples=1000, n_features=2, center_box=(-20, 20), centers=4, cluster_std=[4, 4, 4, 4], random_state=3)
for i, ele in enumerate(y):
    if ele == 3:
        y[i] = 0
    elif ele == 0:
        y[i] = 2
    elif ele == 2:
        y[i] = 3
def D(a, b):
    return np.sqrt(sum((a - b) ** 2))
N = X.shape[0]


dist_list = pdist(X=X,metric='euclidean')
cut_idx = int(len(dist_list) / 100) * 5
ordidx = np.argsort(dist_list)
cut_dist = dist_list[ordidx[cut_idx]]

num = 70
C, D = np.meshgrid(linspace(-35,35,num),linspace(-35,35,num))
rho_matric = np.zeros((num,num))
for i in range(num):
    for j in range(num):
        d = np.array([C[i,j],D[i,j]])
        for r in range(N):
            if np.sqrt(sum((d - X[r]) ** 2)) <= cut_dist:
                rho_matric[i,j] += 1

rho_list = []
for i in range(num):
    for j in range(num):
        rho_list.append(rho_matric[i,j])
maxrho = max(rho_list)

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DeniuHe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值