IMPACT framework, an interpretable multi-target framework for multi-class outputs
Project description
An interpretable model for multi-target predictions with multi-class outputs
Welcome to the official repository for IMPACT – a novel, interpretable model designed for Multi-Target Predictions (MTP) with multi-class outputs. IMPACT extends the Cognitive Diagnosis Bayesian Personalized Ranking framework to effectively handle multi-class prediction tasks. Built primarily in Python using PyTorch, this repository includes the four datasets featured in our publication, along with Jupyter notebooks that allow you to reproduce our experiments and conduct your own analyses.
Installing IMPACT
Directly from pip
pip install impact-liris
Or from source for developers
git clone https://github.com/arthur-batel/IMPACT.git
cd IMPACT
make install
conda activate impact-env
# open one of the notebooks in the experiments/notebook_examples folder
Requirements
- Linux OS
- conda package manager
- CUDA version >= 12.4
- pytorch for CUDA (to install with pip in accordance with your CUDA version : https://pytorch.org/get-started/locally)
IMPACT in few lines of code
from IMPACT import utils, model, dataset
# Set all the required parameters ---------------
config = utils.generate_eval_config(dataset_name="postcovid", learning_rate=0.02026, lambda_=1.2e-5, batch_size=2048, num_epochs=200,
valid_metric='rmse', pred_metrics=['rmse', 'mae'], profile_metrics=['doa', 'pc-er'])
# Read the dataset and the metadata -------------
concept_map, train_data, valid_data, test_data = utils.prepare_dataset(config, i_fold=0)
# Train the model --------------------------------
algo = model.IMPACT(**config)
algo.init_model(train_data, valid_data)
algo.train(train_data, valid_data)
# Test the model --------------------------------
eval_preds = algo.evaluate_predictions(test_data)
eval_profiles = algo.evaluate_profiles(test_data)
print("Evaluation of the predictions :",eval_preds)
print("Evaluation of the profiles :",eval_profiles)
Repository map
experiments/: Contains the jupyter notebooks and datasets to run the experiments of the scientific paper.experiments/ckpt/: Folder for models parameter savingexperiments/datasets/: Contains the raw and pre-processed datasets, as well as there pre-processing jupyter notebookexperiments/embs/: Folder for user embeddings savingexperiments/hyperparam_search/: Contains the csv files of the optimal hyperparameter for each method (obtained with Tree-structured Parzen Estimator (TPE) sampler)experiments/logs/: Folder for running logs savingexperiments/notebook_example/: Contains the jupyter notebooks to run the experiments of the scientific paper, including competitors.experiments/preds/: Folder for predictions savingexperiments/tensorboard/: Folder for tensorboard data saving
figs/: Contains the figures of the paperIMPACT/: Contains the source code of the IMPACT modelIMPACT/dataset/: Contains the code of the dataset classIMPACT/models/: Contains the code of the IMPACT model and its abstract class, handling the learning processIMPACT/utils/: Contains utility functions for logging, complex metric computations, configuration handling, etc.
Authors
Arthur Batel, arthur.batel@insa-lyon.fr, INSA Lyon, LIRIS UMR 5205 FR
Marc Plantevit, marc.plantevit@epita.fr, EPITA Lyon, EPITA Research Laboratory (LRE) FR
Idir Benouaret, idir.benouaret@epita.fr, EPITA Lyon, EPITA Research Laboratory (LRE) FR
Céline Robardet, celine.robardet@insa-lyon.fr, INSA Lyon, LIRIS UMR 5205 FR
Contributor
Lucas Michaëli
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lirisimpact-2.0.2.tar.gz.
File metadata
- Download URL: lirisimpact-2.0.2.tar.gz
- Upload date:
- Size: 47.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fed30232b1cb0249d7ed9a5076747169c33a08b87eeeb8aeaee320e86f0c0d08
|
|
| MD5 |
f08acad5d4d0c7415be182f4a9b5ecb2
|
|
| BLAKE2b-256 |
897eec719fe6c71c63194f2ef239afb63238818b696393aba25b2cec625ee445
|
File details
Details for the file lirisimpact-2.0.2-py3-none-any.whl.
File metadata
- Download URL: lirisimpact-2.0.2-py3-none-any.whl
- Upload date:
- Size: 53.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f052f9745ef333e6c52b40c757557be86bf3226ed3471faaa3ffe183b4069a12
|
|
| MD5 |
9eaf78f195dddd406411c706564555af
|
|
| BLAKE2b-256 |
1638a6a52c2308947b6d173f54d07dbff60595c2a8af6368303239f204de5d4c
|