Skip to main content

Composite Feature Selection using Deep Ensembles

Project description

Composite-Feature-Selection

Tests Tutorials Paper License: MIT Python 3.7+

Official code for the NeurIPS 2022 paper Composite Feature Selection using Deep Ensembles ( Fergus Imrie, Alexander Norcliffe, Pietro Liò, Mihaela van der Schaar )

Current feature selection methods only return a list of predictive features. However, features often don't act alone, but with each other. Take XOR as a simple example, feature 1 literally provides no information without also knowing the value of feature 2 and vice versa. This work aims to solve the problem of Composite Feature Selection, where we find the groups of features that act together.

Deep Graph Mapper Our model CompFS. We use an ensemble of group selection models to discover composite features and an aggregate predictor to combine these features when issuing predictions.

Abstract

In many real world problems, features do not act alone but in combination with each other. For example, in genomics, diseases might not be caused by any single mutation but require the presence of multiple mutations. Prior work on feature selection either seeks to identify individual features or can only determine relevant groups from a predefined set. We investigate the problem of discovering groups of predictive features without predefined grouping. To do so, we define predictive groups in terms of linear and non-linear interactions between features. We introduce a novel deep learning architecture that uses an ensemble of feature selection models to find predictive groups, without requiring candidate groups to be provided. The selected groups are sparse and exhibit minimum overlap. Furthermore, we propose a new metric to measure similarity between discovered groups and the ground truth. We demonstrate the utility of our model on multiple synthetic tasks and semi-synthetic chemistry datasets, where the ground truth structure is known, as well as an image dataset and a real-world cancer dataset.

Deep Graph Mapper The novel regularisation component of the loss function. The first term makes groups small, the second term makes groups different.

Deep Graph Mapper Our new metric for determining similarity between sets of discovered group features. Our metric is based on a normalized Jaccard similarity between the ground truth and the discovered groups.

Installation and Usage

We used python 3.7 for this project. To setup the virtual environment and necessary packages, please run the following commands:

$ conda create --name compfs python=3.7
$ conda activate compfs

The library can be installed from PyPI using

pip install compfs

or from source, using

pip install .

For running the tests and experiments, the dependencies can be installed using

pip install .[testing]

Datasets

The datasets have not been included here to save space. Download each dataset and place in the following folders:

  • Chemisty Data: Link, store data in <library_path>/datasets/chem_data/ (copy and paste from the 'all_16_logics_train_and_test' folder)
  • Metabric Data: Link, store data in <library_path>/datasets/metabric_data/ (copy and paste from the 'archive' folder)

Running the Experiments

Experiments can be run from the command line (from the home directory), with the arguments: experiment_no, experiment, model, for example:

$ python -m experiments.run_experiment --experiment_no 1 --experiment syn1 --model compfs1
$ python -m experiments.run_experiment --experiment_no 6 --experiment chem3 --model ensemble_stg
$ python -m experiments.run_experiment --experiment_no 2 --experiment metabric --model compfs
$ python -m experiments.run_experiment --experiment_no 1 --experiment mnist --model stg

Following that, the standard evaluation to produce the tables from the paper may be carried out from the command line (from the home directory), with the arguments: experiment, model, for example:

$ python -m experiments.run_evaluation --experiment syn4 --model lasso
$ python -m experiments.run_evaluation --experiment chem1 --model random_forests
$ python -m experiments.run_evaluation --experiment chem2 --model oracle

For Group Lasso, STG and Concrete Autoencoder we have included Python Notebooks in the experiments/notebooks/ folder to be run. Included are also notebooks for the MNIST evaluation. STG may also be run from the command line using the same commands as above, with command line argument --model stg, however this is an adapted Ensemble STG with one STG so the hyperparameters have been adjusted accordingly to obtain the same positive results.

Running CompFS on your Data

We have included a notebook, 'tutorials/example.ipynb', which demonstrates CompFS on Syn1. Here the data can be easily be replaced with NumPy arrays of custom data, and the hyperparameters of CompFS can be set. The notebook 'standalone_example.ipynb' is the same notebook but with code copied directly rather than imported so that it can be used without requiring imports from the repo.

Citation

If our paper or code helped you in your own research, please cite our work as:

@article{imrie2022compfs,
  title={{C}omposite {F}eature {S}election using {D}eep {E}nsembles},
  author={Imrie, Fergus and Norcliffe, Alexander and Li{\`o}, Pietro and van der Schaar, Mihaela},
  journal={Advances in Neural Information Processing Systems},
  volume={35},
  year={2022}
}

Acknowledgements

We thank the anonymous reviewers for their comments and suggestions for this paper. At the time of this work, Fergus Imrie and Mihaela van der Schaar are supported by the National Science Foundation (NSF, grant number 1722516). Mihaela van der Schaar is additionally supported by the Office of Naval Research (ONR). Alexander Norcliffe is supported by a GlaxoSmithKline grant. We would also like to thank Bogdan Cebere and Evgeny Saveliev for reviewing this code.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

compfs-0.0.2-py3-none-macosx_10_14_x86_64.whl (24.0 kB view hashes)

Uploaded Python 3 macOS 10.14+ x86-64

compfs-0.0.2-py3-none-any.whl (24.2 kB view hashes)

Uploaded Python 3

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