k-modes/k-prototypes聚类算法Python实现:kmodes

n6bg 9年前

k-modes/k-prototypes聚类算法Python实现。

Python implementations of the k-modes and k-prototypes clustering algorithms. Relies on numpy for a lot of the heavy lifting.

k-modes is used for clustering categorical variables. It defines clusters based on the number of matching categories between data points. (This is in contrast to the more well-known k-means algorithm, which clusters numerical data based on Euclidean distance.) The k-prototypes algorithm combines k-modes and k-means and is able to cluster mixed numerical / categorical data.

Implemented are:

The code is modeled after the k-means module in scikit-learn and has the same familiar interface.

Usage examples of both k-modes ('soybean.py') and k-prototypes ('stocks.py') are included.

I would love to have more people play around with this and give me feedback on my implementation.

Enjoy!

import numpy as np  from kmodes import kmodes    # random categorical data  data = np.random.choice(20, (100, 10))    km = kmodes.KModes(n_clusters=4, init='Huang', n_init=5, verbose=1)  clusters = km.fit_predict(data)

项目主页:http://www.open-open.com/lib/view/home/1430379142052