{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "# Path to your pickle file\n",
    "file_path = '/data/*****/supervised_concept_learning/aa2_baselines/2025-04-20_13_48_01/plots/attribution/mi_residual_deeplift_shapley_concept.pkl'\n",
    "\n",
    "# Load the pickle file\n",
    "with open(file_path, 'rb') as f:\n",
    "    data = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "32"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[0][\"deeplift_shapley\"][\"concept_attributions\"].shape\n",
    "data[0][\"config\"][\"residual_dim\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['concept_attributions', 'residual_attributions', 'concept_values'])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[0][\"deeplift_shapley\"].keys()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "All concept importance histograms saved in a single PDF with 4 concepts per row.\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "\n",
    "# Path to your pickle file\n",
    "#file_path = '/data/*****/supervised_concept_learning/aa2_baselines/2025-04-20_13_48_01/plots/attribution/mi_residual_deeplift_shapley_concept.pkl'\n",
    "file_path = '/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl'\n",
    "# Load the pickle file\n",
    "with open(file_path, 'rb') as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "# Group results by residual dimension\n",
    "results_by_residual_dim = defaultdict(list)\n",
    "for result in data:\n",
    "    residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "    concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "    concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "    \n",
    "    # Store tuple of (attributions, values) for each residual dimension\n",
    "    results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "\n",
    "# Process data for all residual dimensions\n",
    "all_data_by_residual_dim = {}\n",
    "for residual_dim, results_list in results_by_residual_dim.items():\n",
    "    # Concatenate all results for this residual dimension\n",
    "    all_attributions = []\n",
    "    all_values = []\n",
    "    \n",
    "    for attributions, values in results_list:\n",
    "        all_attributions.append(attributions)\n",
    "        all_values.append(values)\n",
    "    \n",
    "    if all_attributions:\n",
    "        all_attributions = np.vstack(all_attributions)\n",
    "        all_values = np.vstack(all_values)\n",
    "        \n",
    "        # Store the concatenated data\n",
    "        all_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "\n",
    "# Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "sorted_residual_dims = sorted(all_data_by_residual_dim.keys())\n",
    "\n",
    "# Get number of concepts (assuming all have the same number of concepts)\n",
    "if all_data_by_residual_dim:\n",
    "    first_dim = list(all_data_by_residual_dim.keys())[0]\n",
    "    num_concepts = all_data_by_residual_dim[first_dim][0].shape[1]\n",
    "    \n",
    "    # Generate colors for each residual dimension\n",
    "    colors = plt.cm.tab10(np.linspace(0, 1, len(sorted_residual_dims)))\n",
    "    \n",
    "    # Calculate layout parameters\n",
    "    max_cols = 4  # Maximum number of concepts per row\n",
    "    num_rows = math.ceil(num_concepts / max_cols)\n",
    "    num_cols = min(max_cols, num_concepts)\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages('concept_importance_histograms.pdf') as pdf:\n",
    "        # Create a figure with subplots\n",
    "        fig = plt.figure(figsize=(5*num_cols, 4*num_rows))\n",
    "        \n",
    "        # Create subplots for each concept\n",
    "        for concept_idx in range(num_concepts):\n",
    "            # Add subplot\n",
    "            ax = fig.add_subplot(num_rows, num_cols, concept_idx + 1)\n",
    "            \n",
    "            # For legend\n",
    "            legend_labels = []\n",
    "            \n",
    "            # Plot histogram for each residual dimension in sorted order\n",
    "            for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "                # Get the data for this residual dimension\n",
    "                attributions, values = all_data_by_residual_dim[residual_dim]\n",
    "                \n",
    "                # Get concept attributions and values for this concept\n",
    "                concept_attr = attributions[:, concept_idx]\n",
    "                concept_val = values[:, concept_idx]\n",
    "                \n",
    "                # Only consider samples where concept is active\n",
    "                active_mask = np.abs(concept_val) > 1e-6\n",
    "                \n",
    "                if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                    active_attributions = concept_attr[active_mask]\n",
    "                    \n",
    "                    # Create histogram normalized by total number of active samples\n",
    "                    weights = np.ones_like(active_attributions) / len(active_attributions)\n",
    "                    \n",
    "                    # Plot the histogram with the appropriate color\n",
    "                    ax.hist(active_attributions, bins=30, weights=weights, alpha=0.6, \n",
    "                             color=colors[i], label=f'Residual Dim: {residual_dim}')\n",
    "                    \n",
    "                    # Add to legend\n",
    "                    legend_labels.append(f'Dim: {residual_dim} (n={np.sum(active_mask)})')\n",
    "            \n",
    "            ax.set_title(f'Concept {concept_idx}')\n",
    "            ax.set_xlabel('Concept Importance')\n",
    "            ax.set_ylabel('Normalized Frequency')\n",
    "            ax.grid(alpha=0.3)\n",
    "            \n",
    "            # Only add legend if it's not empty\n",
    "            if legend_labels:\n",
    "                # Adjust legend font size based on number of dimensions\n",
    "                legend_fontsize = 'small' if len(legend_labels) > 5 else 'medium'\n",
    "                ax.legend(legend_labels, loc='best', fontsize=legend_fontsize)\n",
    "        \n",
    "        # Adjust layout\n",
    "        plt.tight_layout()\n",
    "        \n",
    "        # Save the figure to the PDF\n",
    "        pdf.savefig(fig)\n",
    "        plt.close(fig)\n",
    "\n",
    "print(\"All concept importance histograms saved in a single PDF with 4 concepts per row.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "from scipy.stats import gaussian_kde\n",
    "\n",
    "# Path to your pickle file\n",
    "# Load the pickle file\n",
    "with open(file_path, 'rb') as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "# Group results by residual dimension\n",
    "results_by_residual_dim = defaultdict(list)\n",
    "for result in data:\n",
    "    residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "    concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "    concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "    \n",
    "    # Store tuple of (attributions, values) for each residual dimension\n",
    "    results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "\n",
    "# Process data for all residual dimensions\n",
    "all_data_by_residual_dim = {}\n",
    "for residual_dim, results_list in results_by_residual_dim.items():\n",
    "    # Concatenate all results for this residual dimension\n",
    "    all_attributions = []\n",
    "    all_values = []\n",
    "    \n",
    "    for attributions, values in results_list:\n",
    "        all_attributions.append(attributions)\n",
    "        all_values.append(values)\n",
    "    \n",
    "    if all_attributions:\n",
    "        all_attributions = np.vstack(all_attributions)\n",
    "        all_values = np.vstack(all_values)\n",
    "        \n",
    "        # Store the concatenated data\n",
    "        all_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "\n",
    "# Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "sorted_residual_dims = sorted(all_data_by_residual_dim.keys())\n",
    "\n",
    "# Get number of concepts (assuming all have the same number of concepts)\n",
    "if all_data_by_residual_dim:\n",
    "    first_dim = list(all_data_by_residual_dim.keys())[0]\n",
    "    num_concepts = all_data_by_residual_dim[first_dim][0].shape[1]\n",
    "    \n",
    "    # Generate colors for each residual dimension\n",
    "    colors = plt.cm.tab10(np.linspace(0, 1, len(sorted_residual_dims)))\n",
    "    \n",
    "    # Calculate layout parameters\n",
    "    max_cols = 4  # Maximum number of concepts per row\n",
    "    num_rows = math.ceil(num_concepts / max_cols)\n",
    "    num_cols = min(max_cols, num_concepts)\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages('concept_importance_kde.pdf') as pdf:\n",
    "        # Create a figure with subplots\n",
    "        fig = plt.figure(figsize=(5*num_cols, 4*num_rows))\n",
    "        \n",
    "        # Create subplots for each concept\n",
    "        for concept_idx in range(num_concepts):\n",
    "            # Add subplot\n",
    "            ax = fig.add_subplot(num_rows, num_cols, concept_idx + 1)\n",
    "            \n",
    "            # For legend\n",
    "            legend_labels = []\n",
    "            \n",
    "            # Plot KDE for each residual dimension in sorted order\n",
    "            for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "                # Get the data for this residual dimension\n",
    "                attributions, values = all_data_by_residual_dim[residual_dim]\n",
    "                \n",
    "                # Get concept attributions and values for this concept\n",
    "                concept_attr = attributions[:, concept_idx]\n",
    "                concept_val = values[:, concept_idx]\n",
    "                \n",
    "                # Only consider samples where concept is active\n",
    "                #active_mask = np.abs(concept_val) > 1e-6\n",
    "                active_mask = np.ones_like(concept_val, dtype=bool)  # Use all samples\n",
    "                \n",
    "                if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                    active_attributions = concept_attr[active_mask]\n",
    "                    \n",
    "                    # Define the range to evaluate KDE\n",
    "                    x_min, x_max = min(active_attributions), max(active_attributions)\n",
    "                    x_range = x_max - x_min\n",
    "                    x_min -= x_range * 0.1  # Add some padding\n",
    "                    x_max += x_range * 0.1\n",
    "                    x = np.linspace(x_min, x_max, 1000)\n",
    "                    \n",
    "                    # Create and evaluate KDE\n",
    "                    kde = gaussian_kde(active_attributions, bw_method='scott')\n",
    "                    y = kde(x)\n",
    "                    \n",
    "                    # Plot the KDE\n",
    "                    ax.plot(x, y, color=colors[i], linewidth=2, \n",
    "                           label=f'Residual Dim: {residual_dim}')\n",
    "                    \n",
    "                    # Add to legend\n",
    "                    n_samples = np.sum(active_mask)\n",
    "                    legend_labels.append(f'Dim: {residual_dim} (n={n_samples})')\n",
    "                    \n",
    "                    # Fill the area under the curve with low alpha\n",
    "                    ax.fill_between(x, y, alpha=0.2, color=colors[i])\n",
    "            \n",
    "            ax.set_title(f'Concept {concept_idx}')\n",
    "            ax.set_xlabel('Concept Importance')\n",
    "            ax.set_ylabel('Density')\n",
    "            ax.grid(alpha=0.3)\n",
    "            \n",
    "            # Only add legend if it's not empty\n",
    "            if legend_labels:\n",
    "                # Adjust legend font size based on number of dimensions\n",
    "                legend_fontsize = 'small' if len(legend_labels) > 5 else 'medium'\n",
    "                ax.legend(legend_labels, loc='best', fontsize=legend_fontsize)\n",
    "        \n",
    "        # Adjust layout\n",
    "        plt.tight_layout()\n",
    "        \n",
    "        # Save the figure to the PDF\n",
    "        pdf.savefig(fig)\n",
    "        plt.close(fig)\n",
    "\n",
    "print(\"All concept importance density plots saved in a single PDF with 4 concepts per row.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "active attribution for res_dim= 1 mean: 1.7331156730651855\n",
      "active attribution for res_dim= 2 mean: 1.7560077905654907\n",
      "active attribution for res_dim= 4 mean: 1.5466628074645996\n",
      "active attribution for res_dim= 8 mean: 1.5489994287490845\n",
      "active attribution for res_dim= 16 mean: 1.5471115112304688\n",
      "active attribution for res_dim= 32 mean: 1.5456340312957764\n",
      "active attribution for res_dim= 64 mean: 1.5248891115188599\n",
      "active attribution for res_dim= 1 mean: 1.7721498012542725\n",
      "active attribution for res_dim= 2 mean: 1.7948882579803467\n",
      "active attribution for res_dim= 4 mean: 1.5897374153137207\n",
      "active attribution for res_dim= 8 mean: 1.588356614112854\n",
      "active attribution for res_dim= 16 mean: 1.5757886171340942\n",
      "active attribution for res_dim= 32 mean: 1.5599071979522705\n",
      "active attribution for res_dim= 64 mean: 1.547255516052246\n",
      "active attribution for res_dim= 1 mean: 1.6785129308700562\n",
      "active attribution for res_dim= 2 mean: 1.697414755821228\n",
      "active attribution for res_dim= 4 mean: 1.490605115890503\n",
      "active attribution for res_dim= 8 mean: 1.4941222667694092\n",
      "active attribution for res_dim= 16 mean: 1.4816735982894897\n",
      "active attribution for res_dim= 32 mean: 1.4737263917922974\n",
      "active attribution for res_dim= 64 mean: 1.4567439556121826\n",
      "active attribution for res_dim= 1 mean: 1.5146369934082031\n",
      "active attribution for res_dim= 2 mean: 1.5210808515548706\n",
      "active attribution for res_dim= 4 mean: 1.351515769958496\n",
      "active attribution for res_dim= 8 mean: 1.3533059358596802\n",
      "active attribution for res_dim= 16 mean: 1.3371785879135132\n",
      "active attribution for res_dim= 32 mean: 1.319352388381958\n",
      "active attribution for res_dim= 64 mean: 1.3043534755706787\n",
      "active attribution for res_dim= 1 mean: 1.5774604082107544\n",
      "active attribution for res_dim= 2 mean: 1.591529369354248\n",
      "active attribution for res_dim= 4 mean: 1.3946059942245483\n",
      "active attribution for res_dim= 8 mean: 1.403616189956665\n",
      "active attribution for res_dim= 16 mean: 1.3893002271652222\n",
      "active attribution for res_dim= 32 mean: 1.3891137838363647\n",
      "active attribution for res_dim= 64 mean: 1.3749943971633911\n",
      "active attribution for res_dim= 1 mean: 1.6871075630187988\n",
      "active attribution for res_dim= 2 mean: 1.707585096359253\n",
      "active attribution for res_dim= 4 mean: 1.5057168006896973\n",
      "active attribution for res_dim= 8 mean: 1.5137747526168823\n",
      "active attribution for res_dim= 16 mean: 1.49563467502594\n",
      "active attribution for res_dim= 32 mean: 1.4836527109146118\n",
      "active attribution for res_dim= 64 mean: 1.4721730947494507\n",
      "All concept importance density plots saved in a single PDF with 4 concepts per row.\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "from scipy.stats import gaussian_kde\n",
    "\n",
    "# Path to your pickle file\n",
    "#file_path = '/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl'\n",
    "file_path = '/data/*****/supervised_concept_learning/aa2_baselines/2025-04-20_13_48_01/plots/attribution/mi_residual_deeplift_shapley_concept.pkl'\n",
    "# Load the pickle file\n",
    "def make_plots(file_path, method_name):\n",
    "with open(file_path, 'rb') as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "# Group results by residual dimension\n",
    "results_by_residual_dim = defaultdict(list)\n",
    "for result in data:\n",
    "    residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "    concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "    concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "    \n",
    "    # Store tuple of (attributions, values) for each residual dimension\n",
    "    results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "\n",
    "# Process data for all residual dimensions\n",
    "all_data_by_residual_dim = {}\n",
    "for residual_dim, results_list in results_by_residual_dim.items():\n",
    "    # Concatenate all results for this residual dimension\n",
    "    all_attributions = []\n",
    "    all_values = []\n",
    "    \n",
    "    for attributions, values in results_list:\n",
    "        all_attributions.append(attributions)\n",
    "        all_values.append(values)\n",
    "    \n",
    "    if all_attributions:\n",
    "        all_attributions = np.vstack(all_attributions)\n",
    "        all_values = np.vstack(all_values)\n",
    "        \n",
    "        # Store the concatenated data\n",
    "        all_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "\n",
    "# Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "sorted_residual_dims = sorted(all_data_by_residual_dim.keys())\n",
    "\n",
    "# Get number of concepts (assuming all have the same number of concepts)\n",
    "if all_data_by_residual_dim:\n",
    "    first_dim = list(all_data_by_residual_dim.keys())[0]\n",
    "    num_concepts = all_data_by_residual_dim[first_dim][0].shape[1]\n",
    "    \n",
    "    # Generate colors for each residual dimension\n",
    "    color_map = plt.cm.tab10\n",
    "    colors = color_map(np.linspace(0, 1, len(sorted_residual_dims)))\n",
    "    \n",
    "    # Calculate layout parameters\n",
    "    max_cols = 4  # Maximum number of concepts per row\n",
    "    num_rows = math.ceil(num_concepts / max_cols)\n",
    "    num_cols = min(max_cols, num_concepts)\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages('concept_importance_kde.pdf') as pdf:\n",
    "        # Create a figure with subplots\n",
    "        fig = plt.figure(figsize=(5*num_cols, 4*num_rows))\n",
    "        \n",
    "        # Create subplots for each concept\n",
    "        for concept_idx in range(num_concepts):\n",
    "            # Add subplot\n",
    "            ax = fig.add_subplot(num_rows, num_cols, concept_idx + 1)\n",
    "            \n",
    "            # Track lines and labels for the legend\n",
    "            lines = []\n",
    "            labels = []\n",
    "            \n",
    "            # Plot KDE for each residual dimension in sorted order\n",
    "            for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "                # Get the data for this residual dimension\n",
    "                attributions, values = all_data_by_residual_dim[residual_dim]\n",
    "                \n",
    "                # Get concept attributions and values for this concept\n",
    "                concept_attr = attributions[:, concept_idx]\n",
    "                concept_val = values[:, concept_idx]\n",
    "                \n",
    "                # Only consider samples where concept is active\n",
    "                #active_mask = np.abs(concept_val) > 1e-6\n",
    "                active_mask = np.ones_like(concept_val, dtype=bool)  # Use all samples\n",
    "                \n",
    "                if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                    active_attributions = concept_attr[active_mask]\n",
    "                    print(f\"active attribution for res_dim= {residual_dim} mean: {np.mean(active_attributions)}\")\n",
    "                    \n",
    "                    # Define the range to evaluate KDE\n",
    "                    x_min, x_max = min(active_attributions), max(active_attributions)\n",
    "                    x_range = x_max - x_min\n",
    "                    x_min -= x_range * 0.1  # Add some padding\n",
    "                    x_max += x_range * 0.1\n",
    "                    x = np.linspace(x_min, x_max, 1000)\n",
    "                    \n",
    "                    # Create and evaluate KDE\n",
    "                    kde = gaussian_kde(active_attributions, bw_method='scott')\n",
    "                    y = kde(x)\n",
    "                    \n",
    "                    # Get color for this dimension\n",
    "                    color = colors[i]\n",
    "                    \n",
    "                    # Plot the KDE\n",
    "                    line, = ax.plot(x, y, color=color, linewidth=2)\n",
    "                    \n",
    "                    # Fill the area under the curve with low alpha\n",
    "                    ax.fill_between(x, y, alpha=0.2, color=color)\n",
    "                    \n",
    "                    # Add to legend lists\n",
    "                    n_samples = np.sum(active_mask)\n",
    "                    lines.append(line)\n",
    "                    labels.append(f'Dim: {residual_dim} (n={n_samples})')\n",
    "            \n",
    "            ax.set_title(f'Concept {concept_idx}')\n",
    "            ax.set_xlabel('Concept Importance')\n",
    "            ax.set_ylabel('Density')\n",
    "            ax.grid(alpha=0.3)\n",
    "            \n",
    "            # Only add legend if it's not empty\n",
    "            if lines:\n",
    "                # Create legend with collected lines and labels\n",
    "                legend_fontsize = 'small' if len(lines) > 5 else 'medium'\n",
    "                ax.legend(lines, labels, loc='best', fontsize=legend_fontsize)\n",
    "        \n",
    "        # Adjust layout\n",
    "        plt.tight_layout()\n",
    "        \n",
    "        # Save the figure to the PDF\n",
    "        pdf.savefig(fig)\n",
    "        plt.close(fig)\n",
    "\n",
    "print(\"All concept importance density plots saved in a single PDF with 4 concepts per row.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing mi_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9907608032226562\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.578683614730835\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.253778338432312\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1590712070465088\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3060222864151\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4027646780014038\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0035849809646606\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5285962820053101\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9821250438690186\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6491916179656982\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.294105052947998\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.2005360126495361\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3058886528015137\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4179668426513672\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0052275657653809\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5277441143989563\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8961714506149292\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4395537376403809\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2080879211425781\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1548893451690674\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3020586967468262\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4256328344345093\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0162841081619263\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4109736382961273\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9306015968322754\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5239732265472412\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.182824730873108\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1489224433898926\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3051905632019043\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.418357491493225\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0039054155349731\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.46621203422546387\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9472084045410156\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5743166208267212\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2436903715133667\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.172464370727539\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3072304725646973\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.418818473815918\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0093790292739868\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.45160940289497375\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9453223943710327\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.549450159072876\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2404271364212036\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1586922407150269\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3070849180221558\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4206033945083618\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.008987307548523\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4961436688899994\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.921124815940857\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4998044967651367\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2218960523605347\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1710566282272339\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2989082336425781\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4161895513534546\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.021798849105835\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.47947248816490173\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.972865343093872\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6381179094314575\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2784663438796997\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.197499394416809\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2996368408203125\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.40660560131073\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.000719666481018\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4991196095943451\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9792428016662598\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5901132822036743\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2328001260757446\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.184434413909912\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2831512689590454\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.3935790061950684\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9885722398757935\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5114477276802063\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.955647349357605\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5669025182724\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2213071584701538\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.169464349746704\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3330167531967163\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4301543235778809\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.017385721206665\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.46591079235076904\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.938519835472107\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4661459922790527\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2168422937393188\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1216000318527222\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.313785195350647\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4166991710662842\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.006103515625\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.44260385632514954\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 2.002725839614868\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.641567349433899\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2701269388198853\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.188875675201416\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3003016710281372\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4100390672683716\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9978808760643005\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5358113050460815\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 2.018855571746826\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5698493719100952\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.24722421169281\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1715248823165894\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2969636917114258\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4059685468673706\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.993030309677124\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.520044207572937\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9993860721588135\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.7244333028793335\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.3125542402267456\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.209413766860962\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.304384708404541\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.410249948501587\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9958075881004333\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5445348620414734\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8233095407485962\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4940851926803589\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.248007893562317\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1718605756759644\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2917630672454834\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.3966952562332153\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.010293960571289\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4944296181201935\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 2.001650094985962\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.7313271760940552\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.308516502380371\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.2078009843826294\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3032461404800415\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4089237451553345\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9985585808753967\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5669400095939636\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.993062973022461\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6006669998168945\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2606996297836304\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1703896522521973\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2948524951934814\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.411603569984436\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9972217082977295\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5567458271980286\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8556894063949585\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.3803261518478394\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.1760319471359253\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.163351058959961\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3236405849456787\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4249931573867798\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0203622579574585\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4225504994392395\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9427512884140015\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.499866247177124\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2277382612228394\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1760468482971191\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3065537214279175\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.416324257850647\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0107041597366333\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.483120322227478\n",
      "mi_residual_cifar - active attribution for res_dim= 1 mean: 1.975023865699768\n",
      "mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5927157402038574\n",
      "mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2480558156967163\n",
      "mi_residual_cifar - active attribution for res_dim= 8 mean: 1.184918999671936\n",
      "mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3231201171875\n",
      "mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4230271577835083\n",
      "mi_residual_cifar - active attribution for res_dim= 64 mean: 1.017172932624817\n",
      "mi_residual_cifar - active attribution for res_dim= 128 mean: 0.519589364528656\n",
      "Concept importance plots for mi_residual_cifar saved in 'concept_importance_smoothed_mi_residual_cifar.pdf'\n",
      "Processing latent_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.859893560409546\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3909916877746582\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9015409350395203\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5852282047271729\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46774205565452576\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4095911979675293\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.37786293029785156\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.36551371216773987\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8808915615081787\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.525931715965271\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9049006104469299\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5723445415496826\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4436017870903015\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.38735145330429077\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.360501766204834\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.34716925024986267\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.824547529220581\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.0523682832717896\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.5923725962638855\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.37422630190849304\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3034840226173401\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.26109760999679565\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.23486684262752533\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.22345148026943207\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.938423752784729\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.269308090209961\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7237184643745422\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.45818883180618286\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3568023145198822\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.31359511613845825\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.2918660044670105\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.27769285440444946\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8708620071411133\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3276824951171875\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7279810309410095\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.45254436135292053\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.35030847787857056\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.303221195936203\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.27777785062789917\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.26403942704200745\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9129670858383179\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2654149532318115\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7713161706924438\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5110986232757568\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3941502273082733\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3433323800563812\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31880417466163635\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.30461761355400085\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8134151697158813\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.1907455921173096\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7735736966133118\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.4640074670314789\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3664534091949463\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.31862738728523254\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.29515403509140015\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.28179314732551575\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9756059646606445\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.468709945678711\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8525881767272949\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5457680225372314\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.40997713804244995\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3586009740829468\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3305206894874573\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3165625333786011\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.934630274772644\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.4827734231948853\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8761229515075684\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5752955675125122\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4502300024032593\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.39935657382011414\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3705783188343048\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3544961214065552\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8103893995285034\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2209484577178955\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.6990819573402405\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.4527839124202728\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.360226571559906\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3199319839477539\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.2913048565387726\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.2809585630893707\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.7393841743469238\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2635756731033325\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.6566638350486755\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.41147398948669434\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.32851651310920715\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.29186534881591797\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.26264941692352295\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.25056588649749756\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 2.0074331760406494\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.4880986213684082\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9000258445739746\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5972887277603149\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46984702348709106\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.410831093788147\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.38366109132766724\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3685707151889801\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9601808786392212\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.5017926692962646\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8864768147468567\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5936452150344849\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46387389302253723\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4047219157218933\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.37869149446487427\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3612472116947174\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9940625429153442\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.5746973752975464\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9739550948143005\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6159653067588806\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4715172350406647\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4133966267108917\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3826351463794708\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3707312047481537\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.7461516857147217\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2378164529800415\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7690579891204834\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5010358691215515\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3887287378311157\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3399953246116638\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31394946575164795\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3024817407131195\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.98450767993927\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.6633925437927246\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 1.040778398513794\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6508172154426575\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.5100518465042114\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.44462043046951294\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.4166078567504883\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.40236902236938477\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9745510816574097\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.502227544784546\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9539585113525391\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6402988433837891\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.5022791028022766\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.43645986914634705\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.4103163182735443\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3934943377971649\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.5722333192825317\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.042224407196045\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.5464203953742981\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.33908316493034363\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.26820749044418335\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.23689936101436615\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.21244120597839355\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.2034035176038742\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.889854073524475\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2997734546661377\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7459878325462341\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5022370219230652\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3852386474609375\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3362422287464142\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31089749932289124\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.29911959171295166\n",
      "latent_residual_cifar - active attribution for res_dim= 1 mean: 1.951115608215332\n",
      "latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3712412118911743\n",
      "latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8044833540916443\n",
      "latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5409162640571594\n",
      "latent_residual_cifar - active attribution for res_dim= 16 mean: 0.41987207531929016\n",
      "latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3718327283859253\n",
      "latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3452274203300476\n",
      "latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3314245045185089\n",
      "Concept importance plots for latent_residual_cifar saved in 'concept_importance_smoothed_latent_residual_cifar.pdf'\n",
      "Processing decorrelated_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.976718783378601\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.5121854543685913\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9223090410232544\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6051944494247437\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4795418083667755\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4206852316856384\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.39143338799476624\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3762180507183075\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9947285652160645\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.5793310403823853\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9307538866996765\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5953804850578308\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.454486221075058\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.39740094542503357\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.37013453245162964\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.35566359758377075\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.75916588306427\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.1266742944717407\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6131651401519775\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4025186598300934\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.31921881437301636\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.27743667364120483\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.25414901971817017\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2447662055492401\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.922489881515503\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.310524344444275\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7245917916297913\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.47841188311576843\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.37087005376815796\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3245331645011902\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.30189743638038635\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2899148166179657\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8544365167617798\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.3649110794067383\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7307838201522827\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4815320670604706\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3650934398174286\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.31665757298469543\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.29301968216896057\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.278494656085968\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9092748165130615\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4135385751724243\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8016512989997864\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5264954566955566\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4047463536262512\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3496544063091278\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.33228057622909546\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31729036569595337\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9065210819244385\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.315798282623291\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7764511704444885\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4907686412334442\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3803101181983948\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.33118492364883423\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.30889892578125\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.29613733291625977\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.936795949935913\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4535317420959473\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8527522087097168\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5498721599578857\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.42296645045280457\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3687218427658081\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.34254711866378784\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3296605348587036\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9587401151657104\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4182147979736328\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.877560555934906\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.591023325920105\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.47509855031967163\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41224363446235657\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3825947642326355\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3651842474937439\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8936041593551636\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.372828722000122\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6856315732002258\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.48040828108787537\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3765046000480652\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.33342254161834717\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.31438571214675903\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.29787346720695496\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8084558248519897\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.2719697952270508\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6273241639137268\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.427360862493515\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3431031107902527\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3013402223587036\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.2749837636947632\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2692238390445709\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9921932220458984\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.454414963722229\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9020417332649231\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.61247718334198\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.47803637385368347\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4201339781284332\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.39488735795021057\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.377694696187973\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 2.0063061714172363\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4718873500823975\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8899406790733337\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6100896596908569\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4833798408508301\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41867417097091675\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3884989321231842\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3729307949542999\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9864798784255981\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.6030418872833252\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9870434999465942\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6280349493026733\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4767570197582245\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41799241304397583\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3931368887424469\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3758717477321625\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.7223143577575684\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.2316513061523438\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7780988812446594\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.518278956413269\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4027177691459656\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.35569706559181213\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3303956985473633\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31553858518600464\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 2.026745557785034\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.6532704830169678\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 1.0980415344238281\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6798232793807983\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.5158914923667908\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4496232569217682\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.42426735162734985\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.41043537855148315\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9619824886322021\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.541020154953003\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9731823205947876\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.661444365978241\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.5136975646018982\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.44694969058036804\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.4186006188392639\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.40399667620658875\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.709263801574707\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.1161781549453735\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.5131497383117676\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.3688802421092987\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.30023327469825745\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.25603774189949036\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.2339981496334076\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.22676332294940948\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.86502206325531\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.326198697090149\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7574369311332703\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.501915693283081\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3999693691730499\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3459365665912628\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3243209719657898\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31032371520996094\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9419167041778564\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.354884386062622\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7981630563735962\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5547291040420532\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4269840717315674\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.377488911151886\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.35269826650619507\n",
      "decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.34079164266586304\n",
      "Concept importance plots for decorrelated_residual_cifar saved in 'concept_importance_smoothed_decorrelated_residual_cifar.pdf'\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "# No longer need savgol_filter\n",
    "# from scipy.signal import savgol_filter\n",
    "\n",
    "def make_plots(file_path, method_name):\n",
    "    \"\"\"\n",
    "    Generate concept importance plots for a single pickle file with a specified method name.\n",
    "    Uses histogram with smoothing instead of KDE.\n",
    "    \n",
    "    Args:\n",
    "        file_path (str): Path to the pickle file\n",
    "        method_name (str): Name of the method to use in plot title\n",
    "    \"\"\"\n",
    "    print(f\"Processing {method_name} from {file_path}\")\n",
    "    \n",
    "    # Load the pickle file\n",
    "    with open(file_path, 'rb') as f:\n",
    "        data = pickle.load(f)\n",
    "    \n",
    "    # Group results by residual dimension\n",
    "    results_by_residual_dim = defaultdict(list)\n",
    "    for result in data:\n",
    "        residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "        concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "        concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "        \n",
    "        # Store tuple of (attributions, values) for each residual dimension\n",
    "        results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "    \n",
    "    # Process data for all residual dimensions\n",
    "    all_data_by_residual_dim = {}\n",
    "    for residual_dim, results_list in results_by_residual_dim.items():\n",
    "        # Concatenate all results for this residual dimension\n",
    "        all_attributions = []\n",
    "        all_values = []\n",
    "        \n",
    "        for attributions, values in results_list:\n",
    "            all_attributions.append(attributions)\n",
    "            all_values.append(values)\n",
    "        \n",
    "        if all_attributions:\n",
    "            all_attributions = np.vstack(all_attributions)\n",
    "            all_values = np.vstack(all_values)\n",
    "            \n",
    "            # Store the concatenated data\n",
    "            all_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "    \n",
    "    # Create output filename based on method name\n",
    "    output_pdf_name = f'concept_importance_smoothed_{method_name}.pdf'\n",
    "    \n",
    "    # Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "    sorted_residual_dims = sorted(all_data_by_residual_dim.keys())\n",
    "    \n",
    "    # Get number of concepts\n",
    "    if not all_data_by_residual_dim:\n",
    "        print(f\"No data for method: {method_name}\")\n",
    "        return\n",
    "        \n",
    "    first_dim = list(all_data_by_residual_dim.keys())[0]\n",
    "    num_concepts = all_data_by_residual_dim[first_dim][0].shape[1]\n",
    "    \n",
    "    # Generate colors for each residual dimension\n",
    "    color_map = plt.cm.tab10\n",
    "    colors = color_map(np.linspace(0, 1, len(sorted_residual_dims)))\n",
    "    \n",
    "    # Calculate layout parameters\n",
    "    max_cols = 4  # Maximum number of concepts per row\n",
    "    num_rows = math.ceil(num_concepts / max_cols)\n",
    "    num_cols = min(max_cols, num_concepts)\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages(output_pdf_name) as pdf:\n",
    "        # Create a figure with subplots\n",
    "        fig = plt.figure(figsize=(5*num_cols, 4*num_rows))\n",
    "        fig.suptitle(f'Method: {method_name}', fontsize=16)\n",
    "        \n",
    "        # Create subplots for each concept\n",
    "        for concept_idx in range(num_concepts):\n",
    "            # Add subplot\n",
    "            ax = fig.add_subplot(num_rows, num_cols, concept_idx + 1)\n",
    "            \n",
    "            # Track lines and labels for the legend\n",
    "            lines = []\n",
    "            labels = []\n",
    "            \n",
    "            # Plot smoothed histogram for each residual dimension in sorted order\n",
    "            for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "                # Get the data for this residual dimension\n",
    "                attributions, values = all_data_by_residual_dim[residual_dim]\n",
    "                \n",
    "                # Get concept attributions and values for this concept\n",
    "                concept_attr = attributions[:, concept_idx]\n",
    "                concept_val = values[:, concept_idx]\n",
    "                \n",
    "                # Use all samples\n",
    "                active_mask = np.ones_like(concept_val, dtype=bool)\n",
    "                \n",
    "                if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                    active_attributions = concept_attr[active_mask]\n",
    "                    print(f\"{method_name} - active attribution for res_dim= {residual_dim} \"\n",
    "                          f\"mean: {np.mean(active_attributions)}\")\n",
    "                    \n",
    "                    # Use more bins for higher resolution\n",
    "                    bins = min(50, max(20, int(np.sqrt(len(active_attributions)))))\n",
    "                    counts, bin_edges = np.histogram(active_attributions, bins=bins, density=True)\n",
    "                    bin_centers = (bin_edges[:-1] + bin_edges[1:]) / 2\n",
    "                    \n",
    "                    # Apply a simple moving average for light smoothing (TensorBoard-like)\n",
    "                    def moving_average(x, w):\n",
    "                        \"\"\"Simple moving average with padding to maintain array length\"\"\"\n",
    "                        # Pad the array to maintain the same length after convolution\n",
    "                        padding = w // 2\n",
    "                        padded = np.pad(x, (padding, padding), mode='edge')\n",
    "                        # Create the window/kernel\n",
    "                        window = np.ones(w) / w\n",
    "                        # Apply convolution\n",
    "                        return np.convolve(padded, window, mode='valid')\n",
    "                    \n",
    "                    # Use a small window size for lighter smoothing\n",
    "                    window_size = min(5, max(3, len(counts) // 10))\n",
    "                    \n",
    "                    if len(counts) > window_size:  # Only smooth if we have enough data points\n",
    "                        smoothed_counts = moving_average(counts, window_size)\n",
    "                    else:\n",
    "                        smoothed_counts = counts  # Not enough data points for smoothing\n",
    "                    \n",
    "                    # Get color for this dimension\n",
    "                    color = colors[i]\n",
    "                    \n",
    "                    # Plot the smoothed histogram\n",
    "                    line, = ax.plot(bin_centers, smoothed_counts, color=color, linewidth=2)\n",
    "                    \n",
    "                    # Fill the area under the curve with low alpha\n",
    "                    ax.fill_between(bin_centers, smoothed_counts, alpha=0.2, color=color)\n",
    "                    \n",
    "                    # Add to legend lists\n",
    "                    n_samples = np.sum(active_mask)\n",
    "                    lines.append(line)\n",
    "                    labels.append(f'Dim: {residual_dim} (n={n_samples})')\n",
    "            \n",
    "            ax.set_title(f'Concept {concept_idx}')\n",
    "            ax.set_xlabel('Concept Importance')\n",
    "            ax.set_ylabel('Density')\n",
    "            ax.grid(alpha=0.3)\n",
    "            \n",
    "            # Only add legend if it's not empty\n",
    "            if lines:\n",
    "                # Create legend with collected lines and labels\n",
    "                legend_fontsize = 'small' if len(lines) > 5 else 'medium'\n",
    "                ax.legend(lines, labels, loc='best', fontsize=legend_fontsize)\n",
    "        \n",
    "        # Adjust layout\n",
    "        plt.tight_layout(rect=[0, 0, 1, 0.97])  # Make room for the suptitle\n",
    "        \n",
    "        # Save the figure to the PDF\n",
    "        pdf.savefig(fig)\n",
    "        plt.close(fig)\n",
    "    \n",
    "    print(f\"Concept importance plots for {method_name} saved in '{output_pdf_name}'\")\n",
    "\n",
    "\n",
    "# Define file paths and method names\n",
    "files_and_methods = {\"mi_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\",\n",
    "                     \"latent_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\",\n",
    "                     \"decorrelated_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\",}\n",
    "\n",
    "\n",
    "# Process each file\n",
    "for method_name, file_path in files_and_methods.items():\n",
    "    make_plots(file_path, method_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing 3 methods\n",
      "Loading data for mi_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\n",
      "Loading data for latent_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\n",
      "Loading data for decorrelated_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\n",
      "Processing concept 0\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9907608032226562\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.859893560409546\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.976718783378601\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.578683614730835\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3909916877746582\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.5121854543685913\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.253778338432312\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9015409350395203\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9223090410232544\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1590712070465088\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5852282047271729\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6051944494247437\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3060222864151\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46774205565452576\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4795418083667755\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4027646780014038\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4095911979675293\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4206852316856384\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0035849809646606\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.37786293029785156\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.39143338799476624\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5285962820053101\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.36551371216773987\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3762180507183075\n",
      "Processing concept 1\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9821250438690186\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8808915615081787\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9947285652160645\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6491916179656982\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.525931715965271\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.5793310403823853\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.294105052947998\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9049006104469299\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9307538866996765\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.2005360126495361\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5723445415496826\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5953804850578308\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3058886528015137\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4436017870903015\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.454486221075058\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4179668426513672\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.38735145330429077\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.39740094542503357\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0052275657653809\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.360501766204834\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.37013453245162964\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5277441143989563\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.34716925024986267\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.35566359758377075\n",
      "Processing concept 2\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8961714506149292\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.824547529220581\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.75916588306427\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4395537376403809\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.0523682832717896\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.1266742944717407\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2080879211425781\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.5923725962638855\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6131651401519775\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1548893451690674\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.37422630190849304\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4025186598300934\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3020586967468262\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3034840226173401\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.31921881437301636\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4256328344345093\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.26109760999679565\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.27743667364120483\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0162841081619263\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.23486684262752533\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.25414901971817017\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4109736382961273\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.22345148026943207\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2447662055492401\n",
      "Processing concept 3\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9306015968322754\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.938423752784729\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.922489881515503\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5239732265472412\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.269308090209961\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.310524344444275\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.182824730873108\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7237184643745422\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7245917916297913\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1489224433898926\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.45818883180618286\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.47841188311576843\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3051905632019043\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3568023145198822\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.37087005376815796\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.418357491493225\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.31359511613845825\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3245331645011902\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0039054155349731\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.2918660044670105\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.30189743638038635\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.46621203422546387\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.27769285440444946\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2899148166179657\n",
      "Processing concept 4\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9472084045410156\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8708620071411133\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8544365167617798\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5743166208267212\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3276824951171875\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.3649110794067383\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2436903715133667\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7279810309410095\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7307838201522827\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.172464370727539\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.45254436135292053\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4815320670604706\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3072304725646973\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.35030847787857056\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3650934398174286\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.418818473815918\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.303221195936203\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.31665757298469543\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0093790292739868\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.27777785062789917\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.29301968216896057\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.45160940289497375\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.26403942704200745\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.278494656085968\n",
      "Processing concept 5\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9453223943710327\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9129670858383179\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9092748165130615\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.549450159072876\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2654149532318115\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4135385751724243\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2404271364212036\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7713161706924438\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8016512989997864\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1586922407150269\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5110986232757568\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5264954566955566\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3070849180221558\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3941502273082733\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4047463536262512\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4206033945083618\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3433323800563812\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3496544063091278\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.008987307548523\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31880417466163635\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.33228057622909546\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4961436688899994\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.30461761355400085\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31729036569595337\n",
      "Processing concept 6\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.921124815940857\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8134151697158813\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9065210819244385\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4998044967651367\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.1907455921173096\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.315798282623291\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2218960523605347\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7735736966133118\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7764511704444885\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1710566282272339\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.4640074670314789\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.4907686412334442\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2989082336425781\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3664534091949463\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3803101181983948\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4161895513534546\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.31862738728523254\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.33118492364883423\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.021798849105835\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.29515403509140015\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.30889892578125\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.47947248816490173\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.28179314732551575\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.29613733291625977\n",
      "Processing concept 7\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.972865343093872\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9756059646606445\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.936795949935913\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6381179094314575\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.468709945678711\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4535317420959473\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2784663438796997\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8525881767272949\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8527522087097168\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.197499394416809\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5457680225372314\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5498721599578857\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2996368408203125\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.40997713804244995\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.42296645045280457\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.40660560131073\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3586009740829468\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3687218427658081\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.000719666481018\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3305206894874573\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.34254711866378784\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4991196095943451\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3165625333786011\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3296605348587036\n",
      "Processing concept 8\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9792428016662598\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.934630274772644\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9587401151657104\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5901132822036743\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.4827734231948853\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4182147979736328\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2328001260757446\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8761229515075684\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.877560555934906\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.184434413909912\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5752955675125122\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.591023325920105\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2831512689590454\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4502300024032593\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.47509855031967163\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.3935790061950684\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.39935657382011414\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41224363446235657\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9885722398757935\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3705783188343048\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3825947642326355\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5114477276802063\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3544961214065552\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3651842474937439\n",
      "Processing concept 9\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.955647349357605\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.8103893995285034\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8936041593551636\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5669025182724\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2209484577178955\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.372828722000122\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2213071584701538\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.6990819573402405\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6856315732002258\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.169464349746704\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.4527839124202728\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.48040828108787537\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3330167531967163\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.360226571559906\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3765046000480652\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4301543235778809\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3199319839477539\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.33342254161834717\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.017385721206665\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.2913048565387726\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.31438571214675903\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.46591079235076904\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.2809585630893707\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.29787346720695496\n",
      "Processing concept 10\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.938519835472107\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.7393841743469238\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.8084558248519897\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4661459922790527\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2635756731033325\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.2719697952270508\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2168422937393188\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.6566638350486755\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.6273241639137268\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1216000318527222\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.41147398948669434\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.427360862493515\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.313785195350647\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.32851651310920715\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3431031107902527\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4166991710662842\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.29186534881591797\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3013402223587036\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.006103515625\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.26264941692352295\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.2749837636947632\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.44260385632514954\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.25056588649749756\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.2692238390445709\n",
      "Processing concept 11\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 2.002725839614868\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 2.0074331760406494\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9921932220458984\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.641567349433899\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.4880986213684082\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.454414963722229\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2701269388198853\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9000258445739746\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9020417332649231\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.188875675201416\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5972887277603149\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.61247718334198\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3003016710281372\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46984702348709106\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.47803637385368347\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4100390672683716\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.410831093788147\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4201339781284332\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9978808760643005\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.38366109132766724\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.39488735795021057\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5358113050460815\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3685707151889801\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.377694696187973\n",
      "Processing concept 12\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 2.018855571746826\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9601808786392212\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 2.0063061714172363\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5698493719100952\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.5017926692962646\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.4718873500823975\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.24722421169281\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8864768147468567\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.8899406790733337\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1715248823165894\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5936452150344849\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6100896596908569\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2969636917114258\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46387389302253723\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4833798408508301\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4059685468673706\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4047219157218933\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41867417097091675\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.993030309677124\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.37869149446487427\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3884989321231842\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.520044207572937\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3612472116947174\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3729307949542999\n",
      "Processing concept 13\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9993860721588135\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9940625429153442\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9864798784255981\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.7244333028793335\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.5746973752975464\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.6030418872833252\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.3125542402267456\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9739550948143005\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9870434999465942\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.209413766860962\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6159653067588806\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6280349493026733\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.304384708404541\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.4715172350406647\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4767570197582245\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.410249948501587\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4133966267108917\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.41799241304397583\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9958075881004333\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3826351463794708\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3931368887424469\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5445348620414734\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3707312047481537\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3758717477321625\n",
      "Processing concept 14\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8233095407485962\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.7461516857147217\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.7223143577575684\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.4940851926803589\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2378164529800415\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.2316513061523438\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.248007893562317\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7690579891204834\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7780988812446594\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1718605756759644\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5010358691215515\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.518278956413269\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2917630672454834\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3887287378311157\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4027177691459656\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.3966952562332153\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3399953246116638\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.35569706559181213\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.010293960571289\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31394946575164795\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3303956985473633\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4944296181201935\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3024817407131195\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31553858518600464\n",
      "Processing concept 15\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 2.001650094985962\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.98450767993927\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 2.026745557785034\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.7313271760940552\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.6633925437927246\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.6532704830169678\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.308516502380371\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 1.040778398513794\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 1.0980415344238281\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.2078009843826294\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6508172154426575\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6798232793807983\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3032461404800415\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.5100518465042114\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.5158914923667908\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4089237451553345\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.44462043046951294\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4496232569217682\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9985585808753967\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.4166078567504883\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.42426735162734985\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5669400095939636\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.40236902236938477\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.41043537855148315\n",
      "Processing concept 16\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.993062973022461\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.9745510816574097\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9619824886322021\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.6006669998168945\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.502227544784546\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.541020154953003\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2606996297836304\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9539585113525391\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9731823205947876\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1703896522521973\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.6402988433837891\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.661444365978241\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.2948524951934814\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.5022791028022766\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.5136975646018982\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.411603569984436\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.43645986914634705\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.44694969058036804\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 0.9972217082977295\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.4103163182735443\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.4186006188392639\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5567458271980286\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3934943377971649\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.40399667620658875\n",
      "Processing concept 17\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.8556894063949585\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.5722333192825317\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.709263801574707\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.3803261518478394\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.042224407196045\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.1161781549453735\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.1760319471359253\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.5464203953742981\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.5131497383117676\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.163351058959961\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.33908316493034363\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.3688802421092987\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3236405849456787\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.26820749044418335\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.30023327469825745\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4249931573867798\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.23689936101436615\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.25603774189949036\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0203622579574585\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.21244120597839355\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.2339981496334076\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.4225504994392395\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.2034035176038742\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.22676332294940948\n",
      "Processing concept 18\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9427512884140015\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.889854073524475\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.86502206325531\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.499866247177124\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.2997734546661377\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.326198697090149\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2277382612228394\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.7459878325462341\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7574369311332703\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1760468482971191\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5022370219230652\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.501915693283081\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3065537214279175\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.3852386474609375\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.3999693691730499\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.416324257850647\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3362422287464142\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.3459365665912628\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0107041597366333\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.31089749932289124\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.3243209719657898\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.483120322227478\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.29911959171295166\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.31032371520996094\n",
      "Processing concept 19\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.975023865699768\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.951115608215332\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.9419167041778564\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.5927157402038574\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3712412118911743\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.354884386062622\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.2480558156967163\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.8044833540916443\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.7981630563735962\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.184918999671936\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5409162640571594\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.5547291040420532\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3231201171875\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.41987207531929016\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4269840717315674\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4230271577835083\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.3718327283859253\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.377488911151886\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.017172932624817\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.3452274203300476\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.35269826650619507\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.519589364528656\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.3314245045185089\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.34079164266586304\n",
      "Concept importance plots by residual dimension saved in 'concept_importance_by_residual_dim.pdf'\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "\n",
    "def make_plots_by_residual_dim(files_and_methods):\n",
    "    \"\"\"\n",
    "    Generate plots by residual dimension, showing different methods in each plot.\n",
    "    \n",
    "    Args:\n",
    "        files_and_methods (dict): Dictionary mapping method names to file paths\n",
    "    \"\"\"\n",
    "    print(f\"Processing {len(files_and_methods)} methods\")\n",
    "    \n",
    "    # Dictionary to hold all data, organized by method and residual dimension\n",
    "    all_data = {}\n",
    "    \n",
    "    # Load and organize data for all methods\n",
    "    for method_name, file_path in files_and_methods.items():\n",
    "        print(f\"Loading data for {method_name} from {file_path}\")\n",
    "        \n",
    "        # Load the pickle file\n",
    "        with open(file_path, 'rb') as f:\n",
    "            data = pickle.load(f)\n",
    "        \n",
    "        # Group results by residual dimension\n",
    "        results_by_residual_dim = defaultdict(list)\n",
    "        for result in data:\n",
    "            residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "            concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "            concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "            \n",
    "            # Store tuple of (attributions, values) for each residual dimension\n",
    "            results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "        \n",
    "        # Process data for all residual dimensions\n",
    "        method_data_by_residual_dim = {}\n",
    "        for residual_dim, results_list in results_by_residual_dim.items():\n",
    "            # Concatenate all results for this residual dimension\n",
    "            all_attributions = []\n",
    "            all_values = []\n",
    "            \n",
    "            for attributions, values in results_list:\n",
    "                all_attributions.append(attributions)\n",
    "                all_values.append(values)\n",
    "            \n",
    "            if all_attributions:\n",
    "                all_attributions = np.vstack(all_attributions)\n",
    "                all_values = np.vstack(all_values)\n",
    "                \n",
    "                # Store the concatenated data\n",
    "                method_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "        \n",
    "        # Store in the main dictionary\n",
    "        all_data[method_name] = method_data_by_residual_dim\n",
    "    \n",
    "    # Check if we have any data\n",
    "    if not all_data:\n",
    "        print(\"No data found for any method\")\n",
    "        return\n",
    "    \n",
    "    # Get all unique residual dimensions across all methods\n",
    "    all_residual_dims = set()\n",
    "    for method_data in all_data.values():\n",
    "        all_residual_dims.update(method_data.keys())\n",
    "    \n",
    "    # Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "    sorted_residual_dims = sorted(all_residual_dims)\n",
    "    \n",
    "    # Get number of concepts from first available method and dimension\n",
    "    first_method = list(all_data.keys())[0]\n",
    "    first_dim = list(all_data[first_method].keys())[0]\n",
    "    num_concepts = all_data[first_method][first_dim][0].shape[1]\n",
    "    \n",
    "    # Generate colors for each method\n",
    "    color_map = plt.cm.tab10\n",
    "    colors = color_map(np.linspace(0, 1, len(files_and_methods)))\n",
    "    \n",
    "    # Create output filename\n",
    "    output_pdf_name = 'concept_importance_by_residual_dim.pdf'\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages(output_pdf_name) as pdf:\n",
    "        # Process each concept\n",
    "        for concept_idx in range(num_concepts):\n",
    "            print(f\"Processing concept {concept_idx}\")\n",
    "            \n",
    "            # Calculate layout parameters for residual dimensions\n",
    "            max_cols = 3  # Maximum number of residual dimensions per row\n",
    "            num_rows = math.ceil(len(sorted_residual_dims) / max_cols)\n",
    "            num_cols = min(max_cols, len(sorted_residual_dims))\n",
    "            \n",
    "            # Create a figure with subplots\n",
    "            fig = plt.figure(figsize=(6*num_cols, 5*num_rows))\n",
    "            fig.suptitle(f'Concept {concept_idx}', fontsize=16)\n",
    "            \n",
    "            # Create subplots for each residual dimension\n",
    "            for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "                # Add subplot\n",
    "                ax = fig.add_subplot(num_rows, num_cols, i + 1)\n",
    "                \n",
    "                # Track lines and labels for the legend\n",
    "                lines = []\n",
    "                labels = []\n",
    "                \n",
    "                # Plot smoothed histogram for each method\n",
    "                for j, (method_name, method_data) in enumerate(all_data.items()):\n",
    "                    # Check if this method has data for this residual dimension\n",
    "                    if residual_dim not in method_data:\n",
    "                        print(f\"Method {method_name} does not have data for residual dim {residual_dim}\")\n",
    "                        continue\n",
    "                    \n",
    "                    # Get the data for this method and residual dimension\n",
    "                    attributions, values = method_data[residual_dim]\n",
    "                    \n",
    "                    # Get concept attributions and values for this concept\n",
    "                    concept_attr = attributions[:, concept_idx]\n",
    "                    concept_val = values[:, concept_idx]\n",
    "                    \n",
    "                    # Use all samples\n",
    "                    active_mask = np.ones_like(concept_val, dtype=bool)\n",
    "                    \n",
    "                    if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                        active_attributions = concept_attr[active_mask]\n",
    "                        print(f\"Method {method_name} - active attribution for res_dim= {residual_dim} \"\n",
    "                              f\"mean: {np.mean(active_attributions)}\")\n",
    "                        \n",
    "                        # Use more bins for higher resolution\n",
    "                        bins = min(50, max(20, int(np.sqrt(len(active_attributions)))))\n",
    "                        counts, bin_edges = np.histogram(active_attributions, bins=bins, density=True)\n",
    "                        bin_centers = (bin_edges[:-1] + bin_edges[1:]) / 2\n",
    "                        \n",
    "                        # Apply a simple moving average for light smoothing (TensorBoard-like)\n",
    "                        def moving_average(x, w):\n",
    "                            \"\"\"Simple moving average with padding to maintain array length\"\"\"\n",
    "                            # Pad the array to maintain the same length after convolution\n",
    "                            padding = w // 2\n",
    "                            padded = np.pad(x, (padding, padding), mode='edge')\n",
    "                            # Create the window/kernel\n",
    "                            window = np.ones(w) / w\n",
    "                            # Apply convolution\n",
    "                            return np.convolve(padded, window, mode='valid')\n",
    "                        \n",
    "                        # Use a small window size for lighter smoothing\n",
    "                        window_size = min(5, max(3, len(counts) // 10))\n",
    "                        \n",
    "                        if len(counts) > window_size:  # Only smooth if we have enough data points\n",
    "                            smoothed_counts = moving_average(counts, window_size)\n",
    "                        else:\n",
    "                            smoothed_counts = counts  # Not enough data points for smoothing\n",
    "                        \n",
    "                        # Get color for this method\n",
    "                        color = colors[j]\n",
    "                        \n",
    "                        # Plot the smoothed histogram\n",
    "                        line, = ax.plot(bin_centers, smoothed_counts, color=color, linewidth=2)\n",
    "                        \n",
    "                        # Fill the area under the curve with low alpha\n",
    "                        ax.fill_between(bin_centers, smoothed_counts, alpha=0.2, color=color)\n",
    "                        \n",
    "                        # Add to legend lists\n",
    "                        lines.append(line)\n",
    "                        labels.append(f'{method_name})')\n",
    "                \n",
    "                ax.set_title(f'Residual Dimension {residual_dim}')\n",
    "                ax.set_xlabel('Concept Importance')\n",
    "                ax.set_ylabel('Density')\n",
    "                ax.grid(alpha=0.3)\n",
    "                \n",
    "                # Only add legend if it's not empty\n",
    "                if lines:\n",
    "                    # Create legend with collected lines and labels\n",
    "                    legend_fontsize = 'small' if len(lines) > 3 else 'medium'\n",
    "                    ax.legend(lines, labels, loc='best', fontsize=legend_fontsize)\n",
    "            \n",
    "            # Adjust layout\n",
    "            plt.tight_layout(rect=[0, 0, 1, 0.97])  # Make room for the suptitle\n",
    "            \n",
    "            # Save the figure to the PDF\n",
    "            pdf.savefig(fig)\n",
    "            plt.close(fig)\n",
    "    \n",
    "    print(f\"Concept importance plots by residual dimension saved in '{output_pdf_name}'\")\n",
    "\n",
    "\n",
    "# Define file paths and method names (same as in the original code)\n",
    "files_and_methods = {\n",
    "    \"mi_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\",\n",
    "    \"latent_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\",\n",
    "    \"decorrelated_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\",\n",
    "}\n",
    "\n",
    "# Run the inverted plotting function\n",
    "make_plots_by_residual_dim(files_and_methods)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing 3 methods for concept 0\n",
      "Loading data for mi_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\n",
      "Loading data for latent_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\n",
      "Loading data for decorrelated_residual_cifar from /data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\n",
      "Method mi_residual_cifar - active attribution for res_dim= 1 mean: 1.9907608032226562\n",
      "Method latent_residual_cifar - active attribution for res_dim= 1 mean: 1.859893560409546\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 1 mean: 1.976718783378601\n",
      "Method mi_residual_cifar - active attribution for res_dim= 2 mean: 1.578683614730835\n",
      "Method latent_residual_cifar - active attribution for res_dim= 2 mean: 1.3909916877746582\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 2 mean: 1.5121854543685913\n",
      "Method mi_residual_cifar - active attribution for res_dim= 4 mean: 1.253778338432312\n",
      "Method latent_residual_cifar - active attribution for res_dim= 4 mean: 0.9015409350395203\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 4 mean: 0.9223090410232544\n",
      "Method mi_residual_cifar - active attribution for res_dim= 8 mean: 1.1590712070465088\n",
      "Method latent_residual_cifar - active attribution for res_dim= 8 mean: 0.5852282047271729\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 8 mean: 0.6051944494247437\n",
      "Method mi_residual_cifar - active attribution for res_dim= 16 mean: 1.3060222864151\n",
      "Method latent_residual_cifar - active attribution for res_dim= 16 mean: 0.46774205565452576\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 16 mean: 0.4795418083667755\n",
      "Method mi_residual_cifar - active attribution for res_dim= 32 mean: 1.4027646780014038\n",
      "Method latent_residual_cifar - active attribution for res_dim= 32 mean: 0.4095911979675293\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 32 mean: 0.4206852316856384\n",
      "Method mi_residual_cifar - active attribution for res_dim= 64 mean: 1.0035849809646606\n",
      "Method latent_residual_cifar - active attribution for res_dim= 64 mean: 0.37786293029785156\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 64 mean: 0.39143338799476624\n",
      "Method mi_residual_cifar - active attribution for res_dim= 128 mean: 0.5285962820053101\n",
      "Method latent_residual_cifar - active attribution for res_dim= 128 mean: 0.36551371216773987\n",
      "Method decorrelated_residual_cifar - active attribution for res_dim= 128 mean: 0.3762180507183075\n",
      "Concept importance plots for 'Small Mammals' saved in 'small_mammals_importance_by_residual_dim.pdf'\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "import os\n",
    "import math\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "\n",
    "def make_plots_by_residual_dim(files_and_methods, concept_number=0, concept_name=None):\n",
    "    \"\"\"\n",
    "    Generate plots by residual dimension for a specific concept, showing different methods in each plot.\n",
    "    \n",
    "    Args:\n",
    "        files_and_methods (dict): Dictionary mapping method names to file paths\n",
    "        concept_number (int): Index of the concept to plot\n",
    "        concept_name (str, optional): Custom name for the concept. If None, will use \"Concept {concept_number}\"\n",
    "    \"\"\"\n",
    "    print(f\"Processing {len(files_and_methods)} methods for concept {concept_number}\")\n",
    "    \n",
    "    # Set the concept name\n",
    "    if concept_name is None:\n",
    "        concept_name = f\"Concept {concept_number}\"\n",
    "    \n",
    "    # Dictionary to hold all data, organized by method and residual dimension\n",
    "    all_data = {}\n",
    "    \n",
    "    # Load and organize data for all methods\n",
    "    for method_name, file_path in files_and_methods.items():\n",
    "        print(f\"Loading data for {method_name} from {file_path}\")\n",
    "        \n",
    "        # Load the pickle file\n",
    "        with open(file_path, 'rb') as f:\n",
    "            data = pickle.load(f)\n",
    "        \n",
    "        # Group results by residual dimension\n",
    "        results_by_residual_dim = defaultdict(list)\n",
    "        for result in data:\n",
    "            residual_dim = result[\"config\"][\"residual_dim\"]\n",
    "            concept_attributions = result[\"deeplift_shapley\"][\"concept_attributions\"]\n",
    "            concept_values = result[\"deeplift_shapley\"][\"concept_values\"]\n",
    "            \n",
    "            # Store tuple of (attributions, values) for each residual dimension\n",
    "            results_by_residual_dim[residual_dim].append((concept_attributions, concept_values))\n",
    "        \n",
    "        # Process data for all residual dimensions\n",
    "        method_data_by_residual_dim = {}\n",
    "        for residual_dim, results_list in results_by_residual_dim.items():\n",
    "            # Concatenate all results for this residual dimension\n",
    "            all_attributions = []\n",
    "            all_values = []\n",
    "            \n",
    "            for attributions, values in results_list:\n",
    "                all_attributions.append(attributions)\n",
    "                all_values.append(values)\n",
    "            \n",
    "            if all_attributions:\n",
    "                all_attributions = np.vstack(all_attributions)\n",
    "                all_values = np.vstack(all_values)\n",
    "                \n",
    "                # Store the concatenated data\n",
    "                method_data_by_residual_dim[residual_dim] = (all_attributions, all_values)\n",
    "        \n",
    "        # Store in the main dictionary\n",
    "        all_data[method_name] = method_data_by_residual_dim\n",
    "    \n",
    "    # Check if we have any data\n",
    "    if not all_data:\n",
    "        print(\"No data found for any method\")\n",
    "        return\n",
    "    \n",
    "    # Get all unique residual dimensions across all methods\n",
    "    all_residual_dims = set()\n",
    "    for method_data in all_data.values():\n",
    "        all_residual_dims.update(method_data.keys())\n",
    "    \n",
    "    # Sort residual dimensions naturally (0, 1, 2, 4, etc.)\n",
    "    sorted_residual_dims = sorted(all_residual_dims)\n",
    "    \n",
    "    # Use the specific colors based on model ordering\n",
    "    # Colors for different model types\n",
    "    colors = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728', '#9467bd']\n",
    "    \n",
    "    # Model ordering\n",
    "    model_order = {\n",
    "        'latent_residual': 0, \n",
    "        'decorrelated_residual': 1, \n",
    "        'iter_norm': 2, \n",
    "        'eye': 3, \n",
    "        'mi_residual': 4\n",
    "    }\n",
    "    \n",
    "    # Create output filename\n",
    "    output_pdf_name = f'{concept_name.replace(\" \", \"_\").lower()}_importance_by_residual_dim.pdf'\n",
    "    \n",
    "    # Create PDF to save all plots\n",
    "    with PdfPages(output_pdf_name) as pdf:\n",
    "        # Calculate layout parameters for residual dimensions\n",
    "        max_cols = 3  # Maximum number of residual dimensions per row\n",
    "        num_rows = math.ceil(len(sorted_residual_dims) / max_cols)\n",
    "        num_cols = min(max_cols, len(sorted_residual_dims))\n",
    "        \n",
    "        # Create a figure with subplots\n",
    "        fig = plt.figure(figsize=(6*num_cols, 5*num_rows))\n",
    "        fig.suptitle(concept_name, fontsize=16)\n",
    "        \n",
    "        # Create subplots for each residual dimension\n",
    "        for i, residual_dim in enumerate(sorted_residual_dims):\n",
    "            # Add subplot\n",
    "            ax = fig.add_subplot(num_rows, num_cols, i + 1)\n",
    "            \n",
    "            # Track lines and labels for the legend\n",
    "            lines = []\n",
    "            labels = []\n",
    "            \n",
    "            # Plot smoothed histogram for each method\n",
    "            for j, (method_name, method_data) in enumerate(all_data.items()):\n",
    "                # Check if this method has data for this residual dimension\n",
    "                if residual_dim not in method_data:\n",
    "                    print(f\"Method {method_name} does not have data for residual dim {residual_dim}\")\n",
    "                    continue\n",
    "                \n",
    "                # Get the data for this method and residual dimension\n",
    "                attributions, values = method_data[residual_dim]\n",
    "                \n",
    "                # Get concept attributions and values for this concept\n",
    "                concept_attr = attributions[:, concept_number]\n",
    "                concept_val = values[:, concept_number]\n",
    "                \n",
    "                # Use all samples\n",
    "                active_mask = np.ones_like(concept_val, dtype=bool)\n",
    "                \n",
    "                if np.sum(active_mask) > 0:  # Only plot if there are active samples\n",
    "                    active_attributions = concept_attr[active_mask]\n",
    "                    print(f\"Method {method_name} - active attribution for res_dim= {residual_dim} \"\n",
    "                          f\"mean: {np.mean(active_attributions)}\")\n",
    "                    \n",
    "                    # Use more bins for higher resolution\n",
    "                    bins = min(50, max(20, int(np.sqrt(len(active_attributions)))))\n",
    "                    counts, bin_edges = np.histogram(active_attributions, bins=bins, density=True)\n",
    "                    bin_centers = (bin_edges[:-1] + bin_edges[1:]) / 2\n",
    "                    \n",
    "                    # Apply a simple moving average for light smoothing (TensorBoard-like)\n",
    "                    def moving_average(x, w):\n",
    "                        \"\"\"Simple moving average with padding to maintain array length\"\"\"\n",
    "                        # Pad the array to maintain the same length after convolution\n",
    "                        padding = w // 2\n",
    "                        padded = np.pad(x, (padding, padding), mode='edge')\n",
    "                        # Create the window/kernel\n",
    "                        window = np.ones(w) / w\n",
    "                        # Apply convolution\n",
    "                        return np.convolve(padded, window, mode='valid')\n",
    "                    \n",
    "                    # Use a small window size for lighter smoothing\n",
    "                    window_size = min(5, max(3, len(counts) // 10))\n",
    "                    \n",
    "                    if len(counts) > window_size:  # Only smooth if we have enough data points\n",
    "                        smoothed_counts = moving_average(counts, window_size)\n",
    "                    else:\n",
    "                        smoothed_counts = counts  # Not enough data points for smoothing\n",
    "                    \n",
    "                    # Get color based on model ordering\n",
    "                    # Extract the base model name (without _cifar suffix)\n",
    "                    base_model_name = method_name.split('_cifar')[0]\n",
    "                    # Use the model order to determine the color index, default to 0 if not found\n",
    "                    color_index = model_order.get(base_model_name, 0)\n",
    "                    color = colors[color_index]\n",
    "                    \n",
    "                    # Plot the smoothed histogram\n",
    "                    line, = ax.plot(bin_centers, smoothed_counts, color=color, linewidth=2)\n",
    "                    \n",
    "                    # Fill the area under the curve with low alpha\n",
    "                    ax.fill_between(bin_centers, smoothed_counts, alpha=0.8, color=color)\n",
    "                    \n",
    "                    # Add to legend lists\n",
    "                    lines.append(line)\n",
    "                    labels.append(f'{method_name}')\n",
    "            \n",
    "            ax.set_title(f'Residual Dimension {residual_dim}')\n",
    "            ax.set_xlabel('Concept Importance')\n",
    "            ax.set_ylabel('Density')\n",
    "            ax.grid(alpha=0.3)\n",
    "            \n",
    "            # Only add legend if it's not empty\n",
    "            if lines:\n",
    "                # Create legend with collected lines and labels\n",
    "                legend_fontsize = 'small' if len(lines) > 3 else 'medium'\n",
    "                ax.legend(lines, labels, loc='best', fontsize=legend_fontsize)\n",
    "        \n",
    "        # Adjust layout\n",
    "        plt.tight_layout(rect=[0, 0, 1, 0.97])  # Make room for the suptitle\n",
    "        \n",
    "        # Save the figure to the PDF\n",
    "        pdf.savefig(fig)\n",
    "        plt.close(fig)\n",
    "    \n",
    "    print(f\"Concept importance plots for '{concept_name}' saved in '{output_pdf_name}'\")\n",
    "\n",
    "\n",
    "\n",
    "files_and_methods = {\n",
    "    \"mi_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/mi_residual_deeplift_shapley_concept.pkl\",\n",
    "    \"latent_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/latent_residual_deeplift_shapley_concept.pkl\",\n",
    "    \"decorrelated_residual_cifar\": \"/data/*****/supervised_concept_learning/cifar_baselines/2025-03-28_11_40_06/plots/attribution/decorrelated_residual_deeplift_shapley_concept.pkl\",\n",
    "}\n",
    "\n",
    "# Plot specific concept (for example, concept 3 with custom name \"Texture\")\n",
    "make_plots_by_residual_dim(files_and_methods, concept_number=0, concept_name=\"Small Mammals\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py310",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
