Skip to content

Latest commit

 

History

History
27 lines (14 loc) · 3.81 KB

File metadata and controls

27 lines (14 loc) · 3.81 KB

Semi-supervised Hedge Fund Clustering

A semi-supervised clustering method utilizing tree distance for enhanced hierarchical classification of funds in fund of funds analysis.

It incorporates a limited number of known hierarchical classifications, such as those obtained through due diligence, making it semi-supervised. Additionally, it employs hierarchical tree distance to effectively utilize fund classification features provided by data vendors, accommodating varying taxonomy systems.

The implementation is based on my two other repos, AKB-distance for measuring tree distance, and semi-supervised-chameleon-clustering for the clustering framework, offering a comprehensive solution tailored for fund of fund anallysis.

Motivation

In fund of funds analysis, we often need to classify unknown funds. On the one hand this allows us to compare the fund more meaningfully with its counterparts in the same strategy. On the other hand we can use this to obtain the recent performance of different strategies in the market, e.g. to calculate a strategy index. The categorisation is often hierarchical, e.g. "CTA - Quantitative CTA - Medium to Long Term Momentum CTA", or "Equity - Discretionary Long - Sector Rotation". However, the way these strategies are grouped varies a lot and isn't standard, making it tough to apply typical supervised learning methods.

The challenge lies in implementing general supervised learning algorithms due to the scarce availability of accurate strategy classification labels, which are typically obtained through due diligence or from third-party data vendors. The number of true labels obtained by due diligence is small, which is not sufficient to use supervised learning models. The labels from third parties are often unverified and may not align with one's internal classification system. Additionally, the need for more granular classifications beyond the broad categories provided can be a problem. This repository addresses these issues through a semi-supervised clustering algorithm and hierarchical tree distance.

AKB Distance

The clustering algorithm calculates the distance between instances using features. When dealing with a tree-structured fund classification from data vendors, traditional metrics struggle to accurately measure distances. Thus, the AKB distance is used, a novel measure designed to quantify the similarity between classes within a hierarchical label tree. The AKB tree distance is particularly adept at emphasizing the importance of higher hierarchy errors, utilizing the taxonomy's inherent structure instead of simply flattening the hierarchy in traditional methods.

After calculating pairwise distances between instances for certain features, the final distance is obtained by summing the normalized distance for each feature, following the heterogeneous Euclidean-overlap metric (HEOM) approach.

Semi-supervised Chameleon Clustering

Semi-supervised clustering is a technique that introduces knowledge-based constraints into the clustering process. In our context, these constraints are in the form of must-link (two instances must belong to the same cluster at a certain hierarchy level) and cannot-link (two instances must not belong to the same cluster). Chameleon clustering, a hierarchical algorithm, is used here; it initially segments the data into many small groups and then reassembles these groups, respecting the natural data groupings. We inject must-link and cannot-link constraints during the partitioning and merging phase. This helps to fasten the process and improve accuracy.

Toy Example

Please refer to the provided jupyter notebook. It contains a toy example using synthetic data with hierarchiacl labels.