- Title: Robust Novelty Detection through Style-Conscious Feature Ranking
- Authors: Stefan Smeu*, Elena Burceanu*, Emanuela Haller*, Andrei Liviu Nicolicioiu
- ArXiv Preprint
- Accepted at WACV 2025
We work in a multi-environment setup, where each training environment changes the style of the samples, while all the environments contain a set of seen content classes. The goal of training environments is to define what is content and what is style. Consequently, we are not restricted to a certain style definition but rather expect the training environments to define what might be correlated with our task, but is not actually relevant. Then, we define an evaluation environment, containing both seen and novel classes with an associated new style. The goal of robust novelty detection is to separate between seen and novel content classes, without being affected by the new style.
We focus on discovering which features from a given, pretrained representation, are more environment-biased, thus prone to contain spurious correlations, and should be better ignored. Finding the robust part of a representation is closely linked to invariance between environments, thus we want to have a measure of variance for each dimension in our representation. We first quantify the degree of change in each feature distribution, and then we drop the ones that vary more.
Our algorithm works over the representations extracted from a frozen model. We assume that for each sample of our training set, we start with a vector of
-
Step 1. Feature ranking in training environments First, we compute a score that says how much a feature changes across environments. For each feature
$i$ , we consider$f_i(env)$ to be the distribution of this feature in environment$env$ . We employ the Wasserstein distance to compute the distance between the distributions of each feature$i$ , across pairs of environments$(a, b)$ .$dist_i(env_a, env_b) = W(f_i(env_a), f_i(env_b)), \quad \forall i \in [1..N]$ The per-feature score is obtained next as the expected value of the Wasserstein distance across all pairs of environments
$(env_a, env_b)$ , where$a \neq b$ .$score_i = \mathbb{E}_{a,b}[dist_i(env_a, env_b)] , \quad \forall i \in [1..N]$ -
Step 2. Features selection for Robust Novelty Detection Next, since our purpose is to be robust and to be able to ignore environment changes, we remove features with top scores. The intuition here is that environment-biased features facilitate spuriousness, providing a training setup prone to such correlations.
-
Create a new conda environment starting from the provided requirements file:
conda create --name stylist --file requirements.txt
-
Activate the new environment:
conda activate stylist
-
Install additional packages:
pip install faiss-gpu
pip install skfeature-chappers
- Download data from: https://console.cloud.google.com/storage/browser/bitdefender_ml_artifacts/stylist
- It contains the following folders:
- splits - dataset splits for DomainNet, fMoW, COCOShift_balanced, COCOShift75 and COCOShift95
- embeddings - precomputed embeddings (CLIP and ResNet-18) for all sets
- make sure to unzip the archive in the same folder as the code (or change data_path from configs.py)
- It contains the following folders:
- Original datasets:
- DomainNet https://ai.bu.edu/M3SDA/#dataset
- fMoW https://github.com/fMoW/dataset
- COCOShift images will be released soon
- check
demo.ipynb
Please cite this project as:
@article{smeu2023stylist,
title={Robust Novelty Detection through Style-Conscious Feature Ranking},
author={Smeu, Stefan and Burceanu, Elena and Haller, Emanuela and Nicolicioiu, Andrei Liviu},
journal={WACV},
year={2025}
}