Skip to main content

A package for variable clustering

Project description

VarClusHi

This is a Python module to perform variable clustering (varclus) with a hierarchical structure. Varclus is a nice dimension reduction algorithm. Here is a short description:

  1. A cluster is chosen for splitting.
  2. The chosen cluster is split into two clusters by finding the first two principal components, performing an orthoblique rotation, and assigning each variable to the rotated component with which it has the higher squared correlation.
  3. Variables are iteratively reassigned to clusters to maximize the variance accounted for by the cluster components.

Indented Audience:

  • Those who are familar with the usage of varclus algorithm in other analytical software like SAS, but always feel distressed when trying to find a RIGHT python module.
  • Pythoners who are new to varclus algorithm. The source code could help you gain a deep understanding of the math behind this algorithm.

INSIGHTS & HIGHLIGHTS:

  • (this is a pure theoretical part, ignore this bullet point does not affect the usage of this package) Existing literatures always mention we need principal components (refer step 2-3 above). Actually, implementing this algorithm DOES NOT require principle components to be calulated, correlation matrix and its eigenvectors are enough to get the squared correlation between component and variable (this can be proved by math). If our dataset has millions of observations and hundreds of variables, not using principal components will save time and memory.
  • Python package VarClusHi can produce very similar results, if we use SAS VARCLUS Procedure as a benchmark. This gurantees the correctness of the code.:)

Example

See demo.ipynb for more details.

import pandas as pd
from varclushi import VarClusHi

Create a VarClusHi object and pass the dataframe (df) to be analyzed as a parameter, you can also specify

  • a feature list (feat_list, default all columns of df)
  • max second eigenvalue (maxeigval2, default 1)
  • max clusters (maxclus, default None)

Then call method varclus(), which performs hierachical variable clustering algorithm

demo1_df = pd.read_csv('https://archive.ics.uci.edu/ml/machine-learning-databases/wine-quality/winequality-red.csv', sep=';')
demo1_df.drop('quality',axis=1,inplace=True)
demo1_vc = VarClusHi(demo1_df,maxeigval2=1,maxclus=None)
demo1_vc.varclus()
<varclushi.varclushi.VarClusHi at 0x15f96e35e10>

Call info, you can get the number of clusters, number of variables in each cluster (N_vars), variance explained by each cluster (Eigval1), etc.

demo1_vc.info
  Cluster N_Vars   Eigval1   Eigval2   VarProp
0       0      3  2.141357  0.658413  0.713786
1       1      3  1.766885  0.900991  0.588962
2       2      2  1.371260  0.628740  0.685630
3       3      2  1.552496  0.447504  0.776248
4       4      1  1.000000  0.000000  1.000000

Call rsquare, you can get the (1 - rsquare) ratio of each variable

demo1_vc.rsquare
   Cluster              Variable    RS_Own     RS_NC  RS_Ratio
0        0         fixed acidity  0.882210  0.277256  0.162976
1        0               density  0.622070  0.246194  0.501362
2        0                    pH  0.637076  0.194359  0.450478
3        1   free sulfur dioxide  0.777796  0.010358  0.224530
4        1  total sulfur dioxide  0.786660  0.042294  0.222761
5        1        residual sugar  0.202428  0.045424  0.835525
6        2             sulphates  0.685630  0.106022  0.351653
7        2             chlorides  0.685630  0.048903  0.330534
8        3           citric acid  0.776248  0.398208  0.371810
9        3      volatile acidity  0.776248  0.040920  0.233299
10       4               alcohol  1.000000  0.082055  0.000000

Installation

  • Requirements: Python 3.4+

  • Install by pip:

pip install varclushi

Other Comments:

  • The parameters controlling this algorithm only include second eigenvalues and max number of clusters. I do not develop other functions because it is enough for my use. If you have a need for more flexibility, you can reach out to me via xuanjing@hotmail.com.

  • Comments for source code will be added once I have time.

Thanks

Thank my former manager ***, I first heard of this method from him. Thank my current manager Mr. Mingsong Li, who gave me enough encouragement and support to complete this project.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

varclushi-0.1.0.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

varclushi-0.1.0-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file varclushi-0.1.0.tar.gz.

File metadata

  • Download URL: varclushi-0.1.0.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.18.4 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.5

File hashes

Hashes for varclushi-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b41cb4539f0bda09dad9164c53f4c784c69bd004862659d9cf0639499eb2c24a
MD5 81e993ed6c43e475d9111e45067a3842
BLAKE2b-256 967e3e7c36c542b6927d563bead838b2a8672210fadba58842c12273f7a22baa

See more details on using hashes here.

File details

Details for the file varclushi-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: varclushi-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 6.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.4.2 requests/2.18.4 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.5

File hashes

Hashes for varclushi-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 60d2c852760ed1cf300010e9530bba32bdbeb5896a5a2fa517d5e7c7d1c4067d
MD5 eb64b3c9cf886f7684be7e5de474f753
BLAKE2b-256 503666a2fd2a06906bd2ed4e82a59fd0cabe7824624c00b13da369eac547ad79

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page