# Adaptive Uncertainty-Guided Counterfactual Intervention for VQA

This repository contains the implementation of our adaptive causal debiasing framework for Visual Question Answering as described in the paper "Harnessing Model Uncertainty for Adaptive Causal Debiasing in Visual Question Answering".

## Overview

The code implements our proposed Adaptive Uncertainty-Guided Intervention (AUGI) mechanism that dynamically modulates causal interventions based on model uncertainty. The framework builds upon counterfactual reasoning techniques while adding uncertainty estimation to achieve more effective debiasing.

### Key Components

- **base_model.py**: Contains model architectures including:
  - `BaseModel`: The underlying VQA model (UpDn backbone)
  - `CFVQAModel`: The standard counterfactual VQA model with static intervention
  - `AdaptiveCFVQAModel`: Our proposed model with uncertainty-guided adaptive intervention
  - `AdaptiveUncertaintyModule`: Module that estimates uncertainty and generates adaptive factors

- **main.py**: Handles dataset loading, model initialization, and experiment setup:
  - Computes question-type bias priors
  - Sets up curriculum learning if enabled
  - Configures model hyperparameters

- **train.py**: Implements training and evaluation routines:
  - Handles curriculum learning schedule during training
  - Computes performance metrics
  - Manages experiment lifecycle and results recording

## Usage

The model supports different modes of operation:
- Standard VQA (no debiasing)
- CF-VQA (static counterfactual intervention)
- Adaptive CF-VQA (our approach with uncertainty-guided intervention)

Three uncertainty estimation methods are supported:
- Entropy
- Prediction margin
- Ensemble disagreement

**Note**: These files contain the implementation of the main work in the paper. More code details(such as Uncertainty-Aware Curriculum Learning method) will be made public since the paper is accepted.

