{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T22:17:22.186520Z",
     "start_time": "2024-09-19T22:17:14.904947Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "from torchvision import transforms\n",
    "\n",
    "from torchvision.datasets import CelebA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T22:24:02.388909Z",
     "start_time": "2024-09-19T22:23:50.875432Z"
    }
   },
   "outputs": [],
   "source": [
    "compose = transforms.Compose(\n",
    "    [\n",
    "        transforms.CenterCrop((178, 178)),\n",
    "        transforms.Resize((64, 64)),\n",
    "        transforms.ToTensor(),\n",
    "    ]\n",
    ")\n",
    "dataset = CelebA(root=\"data\", split=\"train\", download=True, transform=compose)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T22:24:06.248933Z",
     "start_time": "2024-09-19T22:24:05.990597Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x15545fc45520>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(dataset[0][0].permute(1, 2, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T21:44:27.761927Z",
     "start_time": "2024-09-19T21:44:23.133415Z"
    }
   },
   "outputs": [],
   "source": [
    "from pdisvae import inference"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T21:45:23.366803Z",
     "start_time": "2024-09-19T21:45:23.360657Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.7252)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "inference.evaluate_partial_correlation(torch.randn(100, 6), torch.randn(100, 6), n_groups=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T22:19:37.588862Z",
     "start_time": "2024-09-19T22:19:37.552045Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "162770"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-19T22:20:02.333609Z",
     "start_time": "2024-09-19T22:20:02.330403Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "41"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset.attr_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:.conda-cli726]",
   "language": "python",
   "name": "conda-env-.conda-cli726-py"
  },
  "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
