Skip to content

bit-ml/Stylist

Repository files navigation

Stylist

  • 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

Table of Contents

  1. Robust Novelty Detection Task
  2. Stylist
  3. Prepare Environment
  4. Data
  5. Usage
  6. Cite

Robust Novelty Detection Task

Robust Novelty Detection - Example 1 Robust Novelty Detection - Example 2

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.

Stylist

Stylist - Step 1 Stylist - Step 2

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 $N$ features. We proceed in two steps:

  • 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.

Prepare environment

  • 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

Data

Usage

  • check demo.ipynb

Cite

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}
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published