{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Classification"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Testing on ImageNet-1K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%run src/classification.py --model vit --attack --dds"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Segmentation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Testing on ImageNet-Segmentation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "ViT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%run src/segmentation.py --method rollout --attack True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%run src/segmentation.py --method transformer_attribution --attack True --dds True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Deit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%run src/segmentation.py --method rollout --model deit --attack True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Perturbation Tests"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate Visualizations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.generate_visualizations import generate_visualizations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "visualization_config = {\n",
    "'batch_size': 16,\n",
    "'method': 'dds',  # choices: ['rollout', 'lrp', 'transformer_attribution', 'full_lrp', 'lrp_last_layer', 'attn_last_layer', 'attn_gradcam']\n",
    "'lmd': 10.0,\n",
    "'vis_class': 'top',  # choices: ['top', 'target', 'index']\n",
    "'class_id': 0,\n",
    "'is_ablation': False,\n",
    "'imagenet_validation_path': 'data_dir/',  # required\n",
    "'to_attack':True,\n",
    "'noise_level':4,\n",
    "'base_vit' :'vit'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "generate_visualizations(visualization_config, visualization_config['base_vit'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Perturbations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.perturbations import setup_perturbations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "perturbation_config = {\n",
    "    'batch_size': 32,\n",
    "    'neg': True,\n",
    "    'value': False,\n",
    "    'scale': 'per',  # ['per', '100']\n",
    "    'method': 'dds',   # ['rollout', 'lrp', 'transformer_attribution', 'full_lrp', 'v_gradcam', 'lrp_last_layer',\n",
    "                                #  'lrp_second_layer', 'gradcam',\n",
    "                                #  'attn_last_layer', 'attn_gradcam', 'input_grads'],\n",
    "    'vis_class': 'top',   # ['top', 'target', 'index'],\n",
    "    'wrong': False,\n",
    "    'class_id': 0,\n",
    "    'is_ablation': False,\n",
    "    'to_save_results':False,\n",
    "    'attacked':True,\n",
    "    'noise_level':4,\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Negative Perturbation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "auc = setup_perturbations(perturbation_config)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Positive Perturbation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "perturbation_config['neg'] = False\n",
    "auc = setup_perturbations(perturbation_config)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fvit",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
