{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e8e085b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import os\n",
    "import glob\n",
    "import pydicom\n",
    "import matplotlib.pylab as plt\n",
    "from PIL import Image, ImageDraw\n",
    "from torchvision import transforms\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fa31be6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "%run maskrcnn_benchmark/data/datasets/cxr.py\n",
    "%run maskrcnn_benchmark/data/collate_batch.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a7c02741",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data_path = '/share/fsmresfiles/MIMIC_CXR/2.0.0/'\n",
    "data_path = '/data/Mao/DATASET/MIMIC-CXR/2.0.0/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "3445d0ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchvision import transforms\n",
    "transform = transforms.Compose([ transforms.ToTensor(), transforms.Normalize(mean=[0.406, 0.456, 0.485],std=[0.225, 0.224, 0.229]) ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "0e4ebc59",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = MimicCXR_V2(data_path,  transforms = transform)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "c1cd74cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import Dataset, DataLoader\n",
    "train_set, validation_set, test_set = dataset.split()\n",
    "train_loader = DataLoader(train_set, batch_size=4, collate_fn= BatchCollator_cxr(), shuffle=True,  pin_memory=True, num_workers=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "de426e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[W pthreadpool-cpp.cc:90] Warning: Leaking Caffe2 thread-pool after fork. (function pthreadpool)\n",
      "[W pthreadpool-cpp.cc:90] Warning: Leaking Caffe2 thread-pool after fork. (function pthreadpool)\n",
      "[W pthreadpool-cpp.cc:90] Warning: Leaking Caffe2 thread-pool after fork. (function pthreadpool)\n",
      "[W pthreadpool-cpp.cc:90] Warning: Leaking Caffe2 thread-pool after fork. (function pthreadpool)\n"
     ]
    }
   ],
   "source": [
    "data = iter(train_loader).next()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "d3e8231d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['disease Atelectasis found',\n",
       " 'disease Pneumothorax found',\n",
       " 'Support Devices found',\n",
       " 'no disease found',\n",
       " 'disease Edema found',\n",
       " 'disease Pleural Effusion found',\n",
       " 'disease Cardiomegaly found',\n",
       " 'disease Consolidation found']"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "tensor([[1., 1., 1., 0., 0., 0., 0., 0.],\n",
       "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
       "        [0., 0., 0., 0., 1., 1., 0., 0.],\n",
       "        [0., 0., 0., 0., 0., 1., 1., 1.]])"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data['prompt_target'].columns.tolist()\n",
    "torch.Tensor(data['prompt_target'].values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "59c6f179",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['disease text found',\n",
       " 'disease Atelectasis found',\n",
       " 'disease Cardiomegaly found',\n",
       " 'disease Consolidation found',\n",
       " 'disease Edema found',\n",
       " 'disease Enlarged Cardiomediastinum found',\n",
       " 'disease Fracture found',\n",
       " 'disease Lung Lesion found',\n",
       " 'disease Lung Opacity found',\n",
       " 'no disease found',\n",
       " 'disease Pleural Effusion found',\n",
       " 'disease Pleural Other found',\n",
       " 'disease Pneumonia found',\n",
       " 'disease Pneumothorax found',\n",
       " 'Support Devices found']"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_loader.dataset.label_prompt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "63f19ef2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>no disease found</th>\n",
       "      <th>disease Atelectasis found</th>\n",
       "      <th>disease Lung Opacity found</th>\n",
       "      <th>disease Pleural Effusion found</th>\n",
       "      <th>disease Edema found</th>\n",
       "      <th>not sure if disease Pleural Effusion found</th>\n",
       "      <th>disease Cardiomegaly found</th>\n",
       "      <th>Support Devices found</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   no disease found  disease Atelectasis found  disease Lung Opacity found  \\\n",
       "0               1.0                        0.0                         0.0   \n",
       "1               0.0                        1.0                         1.0   \n",
       "2               0.0                        0.0                         1.0   \n",
       "3               0.0                        0.0                         0.0   \n",
       "\n",
       "   disease Pleural Effusion found  disease Edema found  \\\n",
       "0                             0.0                  0.0   \n",
       "1                             1.0                  0.0   \n",
       "2                             0.0                  1.0   \n",
       "3                             0.0                  0.0   \n",
       "\n",
       "   not sure if disease Pleural Effusion found  disease Cardiomegaly found  \\\n",
       "0                                         0.0                         0.0   \n",
       "1                                         0.0                         0.0   \n",
       "2                                         1.0                         0.0   \n",
       "3                                         0.0                         1.0   \n",
       "\n",
       "   Support Devices found  \n",
       "0                    0.0  \n",
       "1                    0.0  \n",
       "2                    0.0  \n",
       "3                    1.0  "
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame([{s:1 for s in x} for x in data['label_prompt']]).fillna(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e35de4f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "meta_data = pd.read_csv(os.path.join(data_path, 'cxr-study-list.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7fa0420f",
   "metadata": {},
   "outputs": [],
   "source": [
    "label_data = pd.read_csv(os.path.join(data_path, 'mimic-cxr-2.0.0-chexpert.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f83f982e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>subject_id</th>\n",
       "      <th>study_id</th>\n",
       "      <th>path</th>\n",
       "      <th>text</th>\n",
       "      <th>Atelectasis</th>\n",
       "      <th>Cardiomegaly</th>\n",
       "      <th>Consolidation</th>\n",
       "      <th>Edema</th>\n",
       "      <th>Enlarged Cardiomediastinum</th>\n",
       "      <th>Fracture</th>\n",
       "      <th>Lung Lesion</th>\n",
       "      <th>Lung Opacity</th>\n",
       "      <th>No Finding</th>\n",
       "      <th>Pleural Effusion</th>\n",
       "      <th>Pleural Other</th>\n",
       "      <th>Pneumonia</th>\n",
       "      <th>Pneumothorax</th>\n",
       "      <th>Support Devices</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>10000032</td>\n",
       "      <td>50414267</td>\n",
       "      <td>files/p10/p10000032/s50414267.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53189527</td>\n",
       "      <td>files/p10/p10000032/s53189527.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53911762</td>\n",
       "      <td>files/p10/p10000032/s53911762.txt</td>\n",
       "      <td>final report\\n examination:  chest (portable a...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10000032</td>\n",
       "      <td>56699142</td>\n",
       "      <td>files/p10/p10000032/s56699142.txt</td>\n",
       "      <td>final report\\n indication:  ___ year old woman...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10000764</td>\n",
       "      <td>57375967</td>\n",
       "      <td>files/p10/p10000764/s57375967.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227830</th>\n",
       "      <td>19999442</td>\n",
       "      <td>58708861</td>\n",
       "      <td>files/p19/p19999442/s58708861.txt</td>\n",
       "      <td>final report\\n portable ap chest x-ray\\n \\n in...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227831</th>\n",
       "      <td>19999733</td>\n",
       "      <td>57132437</td>\n",
       "      <td>files/p19/p19999733/s57132437.txt</td>\n",
       "      <td>final report\\n indication:  ___-year-old with ...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227832</th>\n",
       "      <td>19999987</td>\n",
       "      <td>55368167</td>\n",
       "      <td>files/p19/p19999987/s55368167.txt</td>\n",
       "      <td>final report\\n portable chest of ___\\n \\n comp...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227833</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58621812</td>\n",
       "      <td>files/p19/p19999987/s58621812.txt</td>\n",
       "      <td>final report\\n chest radiograph performed on _...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227834</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58971208</td>\n",
       "      <td>files/p19/p19999987/s58971208.txt</td>\n",
       "      <td>final report\\n indication:  ___-year-old femal...</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>227835 rows × 18 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        subject_id  study_id                               path  \\\n",
       "0         10000032  50414267  files/p10/p10000032/s50414267.txt   \n",
       "1         10000032  53189527  files/p10/p10000032/s53189527.txt   \n",
       "2         10000032  53911762  files/p10/p10000032/s53911762.txt   \n",
       "3         10000032  56699142  files/p10/p10000032/s56699142.txt   \n",
       "4         10000764  57375967  files/p10/p10000764/s57375967.txt   \n",
       "...            ...       ...                                ...   \n",
       "227830    19999442  58708861  files/p19/p19999442/s58708861.txt   \n",
       "227831    19999733  57132437  files/p19/p19999733/s57132437.txt   \n",
       "227832    19999987  55368167  files/p19/p19999987/s55368167.txt   \n",
       "227833    19999987  58621812  files/p19/p19999987/s58621812.txt   \n",
       "227834    19999987  58971208  files/p19/p19999987/s58971208.txt   \n",
       "\n",
       "                                                     text  Atelectasis  \\\n",
       "0       final report\\n examination:  chest (pa and lat...          NaN   \n",
       "1       final report\\n examination:  chest (pa and lat...          NaN   \n",
       "2       final report\\n examination:  chest (portable a...          NaN   \n",
       "3       final report\\n indication:  ___ year old woman...          NaN   \n",
       "4       final report\\n examination:  chest (pa and lat...          NaN   \n",
       "...                                                   ...          ...   \n",
       "227830  final report\\n portable ap chest x-ray\\n \\n in...          NaN   \n",
       "227831  final report\\n indication:  ___-year-old with ...          NaN   \n",
       "227832  final report\\n portable chest of ___\\n \\n comp...          1.0   \n",
       "227833  final report\\n chest radiograph performed on _...          1.0   \n",
       "227834  final report\\n indication:  ___-year-old femal...          1.0   \n",
       "\n",
       "        Cardiomegaly  Consolidation  Edema  Enlarged Cardiomediastinum  \\\n",
       "0                NaN            NaN    NaN                         NaN   \n",
       "1                NaN            NaN    NaN                         NaN   \n",
       "2                NaN            NaN    NaN                         NaN   \n",
       "3                NaN            NaN    NaN                         NaN   \n",
       "4                NaN            1.0    NaN                         NaN   \n",
       "...              ...            ...    ...                         ...   \n",
       "227830           NaN            NaN    NaN                         NaN   \n",
       "227831           NaN            NaN    NaN                         NaN   \n",
       "227832          -1.0            NaN    NaN                         NaN   \n",
       "227833           NaN            NaN    NaN                         NaN   \n",
       "227834           NaN            NaN    NaN                         NaN   \n",
       "\n",
       "        Fracture  Lung Lesion  Lung Opacity  No Finding  Pleural Effusion  \\\n",
       "0            NaN          NaN           NaN         1.0               NaN   \n",
       "1            NaN          NaN           NaN         1.0               NaN   \n",
       "2            NaN          NaN           NaN         1.0               NaN   \n",
       "3            NaN          NaN           NaN         1.0               NaN   \n",
       "4            NaN          NaN           NaN         NaN               NaN   \n",
       "...          ...          ...           ...         ...               ...   \n",
       "227830       NaN          NaN           NaN         1.0               NaN   \n",
       "227831       NaN          NaN           NaN         1.0               NaN   \n",
       "227832       NaN          0.0           NaN         NaN               0.0   \n",
       "227833       NaN          NaN           NaN         NaN               NaN   \n",
       "227834       NaN          NaN           NaN         NaN               NaN   \n",
       "\n",
       "        Pleural Other  Pneumonia  Pneumothorax  Support Devices  \n",
       "0                 NaN        NaN           NaN              NaN  \n",
       "1                 NaN        NaN           NaN              NaN  \n",
       "2                 NaN        NaN           NaN              NaN  \n",
       "3                 NaN        NaN           NaN              NaN  \n",
       "4                 NaN       -1.0           NaN              NaN  \n",
       "...               ...        ...           ...              ...  \n",
       "227830            NaN        NaN           NaN              1.0  \n",
       "227831            NaN        NaN           NaN              NaN  \n",
       "227832            NaN        NaN           0.0              NaN  \n",
       "227833            NaN        NaN           NaN              1.0  \n",
       "227834            NaN        NaN           NaN              NaN  \n",
       "\n",
       "[227835 rows x 18 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "meta_data.merge(label_data,on=['subject_id','study_id'], how='left')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4c9eb1d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "image_files = glob.glob(os.path.join(data_path, 'files/p10/p10000032/s50414267')+'/*.jpg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "49a7460d",
   "metadata": {},
   "outputs": [],
   "source": [
    "images = [Image.open(fn).convert(\"RGB\") for fn in image_files]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "8b4b8fd9",
   "metadata": {},
   "outputs": [],
   "source": [
    "image = transforms.ToTensor()(images[0])*255"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "820b4ce0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        ...,\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.]])"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "image[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "db125372",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.6400)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from torchvision.transforms import functional as F\n",
    "F.normalize(image, mean=[ 103.530, 116.280, 123.675 ], std=[ 57.375, 57.120, 58.395 ]).max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "bc642c60",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044],\n",
       "         [-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044],\n",
       "         [-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044],\n",
       "         ...,\n",
       "         [-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044],\n",
       "         [-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044],\n",
       "         [-1.8044, -1.8044, -1.8044,  ..., -1.8044, -1.8044, -1.8044]],\n",
       "\n",
       "        [[-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357],\n",
       "         [-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357],\n",
       "         [-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357],\n",
       "         ...,\n",
       "         [-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357],\n",
       "         [-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357],\n",
       "         [-2.0357, -2.0357, -2.0357,  ..., -2.0357, -2.0357, -2.0357]],\n",
       "\n",
       "        [[-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179],\n",
       "         [-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179],\n",
       "         [-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179],\n",
       "         ...,\n",
       "         [-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179],\n",
       "         [-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179],\n",
       "         [-2.1179, -2.1179, -2.1179,  ..., -2.1179, -2.1179, -2.1179]]])"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "transform(images[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "189c61a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.17815876007080078\n"
     ]
    }
   ],
   "source": [
    "s=time.time()\n",
    "ds = pydicom.dcmread('/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p10/p10935586/s57922700/63522ab8-faa45d49-7ac7aeab-1168d5f9-24859a09.dcm')\n",
    "print(time.time()-s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "85332642",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3056, 2544)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.pixel_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "dbe1ede0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.004040241241455078\n"
     ]
    }
   ],
   "source": [
    "import time\n",
    "s=time.time()\n",
    "im = Image.open('/share/fsmresfiles/MIMIC_CXR/MIMIC_CXR_JPG_2/physionet.org/files/mimic-cxr-jpg/2.0.0/files/p10/p10935586/s57922700/63522ab8-faa45d49-7ac7aeab-1168d5f9-24859a09.jpg')\n",
    "print(time.time()-s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "0fb4e4e9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function time.time>"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "09232381",
   "metadata": {},
   "outputs": [],
   "source": [
    "st_jpg =glob.glob('/share/fsmresfiles/MIMIC_CXR/MIMIC_CXR_JPG_2/physionet.org/files/mimic-cxr-jpg/2.0.0/files/*/*/s*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "2c3a82ea",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'st_jpg' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_3928/487619608.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mst_jpg\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m: name 'st_jpg' is not defined"
     ]
    }
   ],
   "source": [
    "st_jpg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "a5916349",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p19',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p13',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p12',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p18',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p14',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p17',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p16',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p11',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p10',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p15']"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "glob.glob('/share/fsmresfiles/MIMIC_CXR/2.0.0/files/*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "3f9fe37d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p19/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p13/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p12/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p18/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p14/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p17/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p16/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p11/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p10/index.html',\n",
       " '/share/fsmresfiles/MIMIC_CXR/2.0.0/files/p15/index.html']"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[x for x in persons if x.endswith('.html')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6776571e",
   "metadata": {},
   "outputs": [],
   "source": [
    "meta_data = pd.read_csv(os.path.join(data_path, 'cxr-study-list.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "98a58531",
   "metadata": {},
   "outputs": [],
   "source": [
    "label_data = pd.read_csv(os.path.join(data_path, 'mimic-cxr-2.0.0-chexpert.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "a9248bcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "split = pd.read_csv(os.path.join(data_path, 'mimic-cxr-2.0.0-split.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "de0d9e80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "222758"
      ]
     },
     "execution_count": 130,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "3269"
      ]
     },
     "execution_count": 130,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "1808"
      ]
     },
     "execution_count": 130,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "split.query('split==\"train\"')['study_id'].nunique()\n",
    "split.query('split==\"test\"')['study_id'].nunique()\n",
    "split.query('split==\"validate\"')['study_id'].nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4e83bf75",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([50414267, 53189527, 53911762, ..., 55368167, 58621812, 58971208])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "split.query('split==\"train\"')['study_id'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "08f13a02",
   "metadata": {},
   "outputs": [],
   "source": [
    "label = label_data.iloc[:,2:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "edfb8815",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Atelectasis</th>\n",
       "      <th>Cardiomegaly</th>\n",
       "      <th>Consolidation</th>\n",
       "      <th>Edema</th>\n",
       "      <th>Enlarged Cardiomediastinum</th>\n",
       "      <th>Fracture</th>\n",
       "      <th>Lung Lesion</th>\n",
       "      <th>Lung Opacity</th>\n",
       "      <th>No Finding</th>\n",
       "      <th>Pleural Effusion</th>\n",
       "      <th>Pleural Other</th>\n",
       "      <th>Pneumonia</th>\n",
       "      <th>Pneumothorax</th>\n",
       "      <th>Support Devices</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1293</th>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2963</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5944</th>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6159</th>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6410</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>224378</th>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>226565</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>226606</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227506</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227668</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>237 rows × 14 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        Atelectasis  Cardiomegaly  Consolidation  Edema  \\\n",
       "1293            NaN           1.0            NaN    0.0   \n",
       "2963            NaN           NaN            NaN    1.0   \n",
       "5944            1.0           NaN            NaN    NaN   \n",
       "6159            NaN           1.0            NaN    NaN   \n",
       "6410            NaN           NaN            NaN    NaN   \n",
       "...             ...           ...            ...    ...   \n",
       "224378         -1.0           NaN           -1.0   -1.0   \n",
       "226565          NaN           NaN            NaN    NaN   \n",
       "226606          NaN           NaN            NaN    NaN   \n",
       "227506          NaN           NaN            1.0    NaN   \n",
       "227668          NaN           NaN            NaN    NaN   \n",
       "\n",
       "        Enlarged Cardiomediastinum  Fracture  Lung Lesion  Lung Opacity  \\\n",
       "1293                           NaN       NaN          NaN           NaN   \n",
       "2963                           NaN       NaN          NaN           NaN   \n",
       "5944                           NaN       NaN          NaN           1.0   \n",
       "6159                           NaN       1.0          NaN           NaN   \n",
       "6410                           NaN       NaN          NaN           NaN   \n",
       "...                            ...       ...          ...           ...   \n",
       "224378                         NaN       NaN          NaN           NaN   \n",
       "226565                         NaN       NaN          NaN           1.0   \n",
       "226606                         NaN       NaN          NaN           NaN   \n",
       "227506                         1.0       NaN         -1.0           1.0   \n",
       "227668                         NaN       NaN          1.0           NaN   \n",
       "\n",
       "        No Finding  Pleural Effusion  Pleural Other  Pneumonia  Pneumothorax  \\\n",
       "1293           NaN               0.0            NaN        NaN           0.0   \n",
       "2963           NaN               NaN            NaN        NaN           NaN   \n",
       "5944           NaN               NaN            NaN        NaN           1.0   \n",
       "6159           NaN               NaN            NaN        NaN           0.0   \n",
       "6410           NaN               NaN            NaN        NaN           1.0   \n",
       "...            ...               ...            ...        ...           ...   \n",
       "224378         NaN               NaN            NaN        NaN           NaN   \n",
       "226565         NaN               1.0            NaN        NaN           1.0   \n",
       "226606         NaN               0.0            NaN        NaN          -1.0   \n",
       "227506         NaN               1.0            NaN        NaN           NaN   \n",
       "227668         NaN               NaN            NaN        NaN           NaN   \n",
       "\n",
       "        Support Devices  \n",
       "1293               -1.0  \n",
       "2963               -1.0  \n",
       "5944               -1.0  \n",
       "6159               -1.0  \n",
       "6410               -1.0  \n",
       "...                 ...  \n",
       "224378             -1.0  \n",
       "226565             -1.0  \n",
       "226606             -1.0  \n",
       "227506             -1.0  \n",
       "227668             -1.0  \n",
       "\n",
       "[237 rows x 14 columns]"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label.query('`Support Devices`==-1')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "0a27d5dc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Atelectasis</th>\n",
       "      <th>Cardiomegaly</th>\n",
       "      <th>Consolidation</th>\n",
       "      <th>Edema</th>\n",
       "      <th>Enlarged Cardiomediastinum</th>\n",
       "      <th>Fracture</th>\n",
       "      <th>Lung Lesion</th>\n",
       "      <th>Lung Opacity</th>\n",
       "      <th>No Finding</th>\n",
       "      <th>Pleural Effusion</th>\n",
       "      <th>Pleural Other</th>\n",
       "      <th>Pneumonia</th>\n",
       "      <th>Pneumothorax</th>\n",
       "      <th>Support Devices</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>72</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227566</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227574</th>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227633</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227774</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227785</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10884 rows × 14 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        Atelectasis  Cardiomegaly  Consolidation  Edema  \\\n",
       "12              NaN           NaN            NaN   -1.0   \n",
       "13              NaN           NaN            NaN    0.0   \n",
       "23              NaN           NaN            NaN    NaN   \n",
       "45              NaN           NaN            0.0    0.0   \n",
       "72              NaN           NaN            NaN    NaN   \n",
       "...             ...           ...            ...    ...   \n",
       "227566          0.0           0.0            NaN    0.0   \n",
       "227574         -1.0           NaN            NaN    NaN   \n",
       "227633          NaN           NaN            NaN    NaN   \n",
       "227774          NaN           NaN            NaN    NaN   \n",
       "227785          NaN           NaN            NaN   -1.0   \n",
       "\n",
       "        Enlarged Cardiomediastinum  Fracture  Lung Lesion  Lung Opacity  \\\n",
       "12                             NaN       NaN          NaN           NaN   \n",
       "13                             NaN       NaN          NaN           NaN   \n",
       "23                             NaN       NaN          NaN           NaN   \n",
       "45                             NaN       NaN          NaN           NaN   \n",
       "72                             NaN      -1.0          NaN           NaN   \n",
       "...                            ...       ...          ...           ...   \n",
       "227566                         NaN       NaN          NaN           NaN   \n",
       "227574                         NaN       NaN          NaN          -1.0   \n",
       "227633                         NaN       NaN          NaN           NaN   \n",
       "227774                         NaN       NaN          NaN           NaN   \n",
       "227785                         NaN       NaN          NaN           NaN   \n",
       "\n",
       "        No Finding  Pleural Effusion  Pleural Other  Pneumonia  Pneumothorax  \\\n",
       "12             NaN               NaN            NaN        NaN           NaN   \n",
       "13             NaN               0.0            NaN        0.0           NaN   \n",
       "23             NaN               0.0            NaN        0.0           NaN   \n",
       "45             NaN               0.0            NaN        NaN           0.0   \n",
       "72             NaN               NaN            NaN        NaN           NaN   \n",
       "...            ...               ...            ...        ...           ...   \n",
       "227566         NaN               0.0            NaN        0.0           NaN   \n",
       "227574         NaN               NaN            NaN        0.0           NaN   \n",
       "227633         NaN               NaN            NaN        0.0           NaN   \n",
       "227774         NaN               NaN            NaN        NaN           NaN   \n",
       "227785         NaN               NaN            NaN        NaN           NaN   \n",
       "\n",
       "        Support Devices  \n",
       "12                  NaN  \n",
       "13                  NaN  \n",
       "23                  NaN  \n",
       "45                  NaN  \n",
       "72                  NaN  \n",
       "...                 ...  \n",
       "227566              0.0  \n",
       "227574              NaN  \n",
       "227633              NaN  \n",
       "227774              NaN  \n",
       "227785              NaN  \n",
       "\n",
       "[10884 rows x 14 columns]"
      ]
     },
     "execution_count": 156,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label[(label==1).sum(axis=1)==0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "52db464e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "391845b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "text_file = os.path.join(data_path,data['path'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "4778bd75",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcm_folder = data['path'][:-4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "ad7dd797",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcm_files = glob.glob(os.path.join(data_path, dcm_folder)+'/*.dcm')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "eccc546a",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(text_file) as f:\n",
    "    text = f.read()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "526c4719",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>subject_id</th>\n",
       "      <th>study_id</th>\n",
       "      <th>path</th>\n",
       "      <th>Atelectasis</th>\n",
       "      <th>Cardiomegaly</th>\n",
       "      <th>Consolidation</th>\n",
       "      <th>Edema</th>\n",
       "      <th>Enlarged Cardiomediastinum</th>\n",
       "      <th>Fracture</th>\n",
       "      <th>Lung Lesion</th>\n",
       "      <th>Lung Opacity</th>\n",
       "      <th>No Finding</th>\n",
       "      <th>Pleural Effusion</th>\n",
       "      <th>Pleural Other</th>\n",
       "      <th>Pneumonia</th>\n",
       "      <th>Pneumothorax</th>\n",
       "      <th>Support Devices</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>10000032</td>\n",
       "      <td>50414267</td>\n",
       "      <td>files/p10/p10000032/s50414267.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53189527</td>\n",
       "      <td>files/p10/p10000032/s53189527.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53911762</td>\n",
       "      <td>files/p10/p10000032/s53911762.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10000032</td>\n",
       "      <td>56699142</td>\n",
       "      <td>files/p10/p10000032/s56699142.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10000764</td>\n",
       "      <td>57375967</td>\n",
       "      <td>files/p10/p10000764/s57375967.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227830</th>\n",
       "      <td>19999442</td>\n",
       "      <td>58708861</td>\n",
       "      <td>files/p19/p19999442/s58708861.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227831</th>\n",
       "      <td>19999733</td>\n",
       "      <td>57132437</td>\n",
       "      <td>files/p19/p19999733/s57132437.txt</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227832</th>\n",
       "      <td>19999987</td>\n",
       "      <td>55368167</td>\n",
       "      <td>files/p19/p19999987/s55368167.txt</td>\n",
       "      <td>1.0</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227833</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58621812</td>\n",
       "      <td>files/p19/p19999987/s58621812.txt</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227834</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58971208</td>\n",
       "      <td>files/p19/p19999987/s58971208.txt</td>\n",
       "      <td>1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>227835 rows × 17 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        subject_id  study_id                               path  Atelectasis  \\\n",
       "0         10000032  50414267  files/p10/p10000032/s50414267.txt          NaN   \n",
       "1         10000032  53189527  files/p10/p10000032/s53189527.txt          NaN   \n",
       "2         10000032  53911762  files/p10/p10000032/s53911762.txt          NaN   \n",
       "3         10000032  56699142  files/p10/p10000032/s56699142.txt          NaN   \n",
       "4         10000764  57375967  files/p10/p10000764/s57375967.txt          NaN   \n",
       "...            ...       ...                                ...          ...   \n",
       "227830    19999442  58708861  files/p19/p19999442/s58708861.txt          NaN   \n",
       "227831    19999733  57132437  files/p19/p19999733/s57132437.txt          NaN   \n",
       "227832    19999987  55368167  files/p19/p19999987/s55368167.txt          1.0   \n",
       "227833    19999987  58621812  files/p19/p19999987/s58621812.txt          1.0   \n",
       "227834    19999987  58971208  files/p19/p19999987/s58971208.txt          1.0   \n",
       "\n",
       "        Cardiomegaly  Consolidation  Edema  Enlarged Cardiomediastinum  \\\n",
       "0                NaN            NaN    NaN                         NaN   \n",
       "1                NaN            NaN    NaN                         NaN   \n",
       "2                NaN            NaN    NaN                         NaN   \n",
       "3                NaN            NaN    NaN                         NaN   \n",
       "4                NaN            1.0    NaN                         NaN   \n",
       "...              ...            ...    ...                         ...   \n",
       "227830           NaN            NaN    NaN                         NaN   \n",
       "227831           NaN            NaN    NaN                         NaN   \n",
       "227832          -1.0            NaN    NaN                         NaN   \n",
       "227833           NaN            NaN    NaN                         NaN   \n",
       "227834           NaN            NaN    NaN                         NaN   \n",
       "\n",
       "        Fracture  Lung Lesion  Lung Opacity  No Finding  Pleural Effusion  \\\n",
       "0            NaN          NaN           NaN         1.0               NaN   \n",
       "1            NaN          NaN           NaN         1.0               NaN   \n",
       "2            NaN          NaN           NaN         1.0               NaN   \n",
       "3            NaN          NaN           NaN         1.0               NaN   \n",
       "4            NaN          NaN           NaN         NaN               NaN   \n",
       "...          ...          ...           ...         ...               ...   \n",
       "227830       NaN          NaN           NaN         1.0               NaN   \n",
       "227831       NaN          NaN           NaN         1.0               NaN   \n",
       "227832       NaN          0.0           NaN         NaN               0.0   \n",
       "227833       NaN          NaN           NaN         NaN               NaN   \n",
       "227834       NaN          NaN           NaN         NaN               NaN   \n",
       "\n",
       "        Pleural Other  Pneumonia  Pneumothorax  Support Devices  \n",
       "0                 NaN        NaN           NaN              NaN  \n",
       "1                 NaN        NaN           NaN              NaN  \n",
       "2                 NaN        NaN           NaN              NaN  \n",
       "3                 NaN        NaN           NaN              NaN  \n",
       "4                 NaN       -1.0           NaN              NaN  \n",
       "...               ...        ...           ...              ...  \n",
       "227830            NaN        NaN           NaN              1.0  \n",
       "227831            NaN        NaN           NaN              NaN  \n",
       "227832            NaN        NaN           0.0              NaN  \n",
       "227833            NaN        NaN           NaN              1.0  \n",
       "227834            NaN        NaN           NaN              NaN  \n",
       "\n",
       "[227835 rows x 17 columns]"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "meta_data.merge(label_data,on=['subject_id','study_id'], how='left')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "fb646d00",
   "metadata": {},
   "outputs": [],
   "source": [
    "from maskrcnn_benchmark.structures.image_list import to_image_list\n",
    "from torchvision import transforms\n",
    "transform = transforms.Compose([ transforms.ToTensor(), transforms.Normalize(mean=[0.485, 0.456, 0.406],std=[0.229, 0.224, 0.225]) ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "5314b0ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "dcm_infos = [pydicom.dcmread(fn) for fn in dcm_files]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "d036611e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "images = [ds.pixel_array.astype(float) for ds in dcm_infos]\n",
    "images = [transform(img[...,None].repeat(3,axis=2)) for img in images]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "4133eb27",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3056, 2544)"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "(3056, 2544)"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "images[0].shape\n",
    "images[1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "0b173a86",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "The size of tensor a (2544) must match the size of tensor b (3) at non-singleton dimension 0",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_149250/930696024.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mtransform\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimages\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m...\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrepeat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m3\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/.conda/envs/cellpose/lib/python3.9/site-packages/torchvision/transforms/transforms.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, img)\u001b[0m\n\u001b[1;32m     58\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     59\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mt\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtransforms\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 60\u001b[0;31m             \u001b[0mimg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     61\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     62\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.conda/envs/cellpose/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1049\u001b[0m         if not (self._backward_hooks or self._forward_hooks or self._forward_pre_hooks or _global_backward_hooks\n\u001b[1;32m   1050\u001b[0m                 or _global_forward_hooks or _global_forward_pre_hooks):\n\u001b[0;32m-> 1051\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mforward_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1052\u001b[0m         \u001b[0;31m# Do not call functions when jit is used\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1053\u001b[0m         \u001b[0mfull_backward_hooks\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnon_full_backward_hooks\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.conda/envs/cellpose/lib/python3.9/site-packages/torchvision/transforms/transforms.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, tensor)\u001b[0m\n\u001b[1;32m    219\u001b[0m             \u001b[0mTensor\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mNormalized\u001b[0m \u001b[0mTensor\u001b[0m \u001b[0mimage\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    220\u001b[0m         \"\"\"\n\u001b[0;32m--> 221\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mF\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnormalize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtensor\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstd\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minplace\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    222\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    223\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__repr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.conda/envs/cellpose/lib/python3.9/site-packages/torchvision/transforms/functional.py\u001b[0m in \u001b[0;36mnormalize\u001b[0;34m(tensor, mean, std, inplace)\u001b[0m\n\u001b[1;32m    333\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mstd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    334\u001b[0m         \u001b[0mstd\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mstd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 335\u001b[0;31m     \u001b[0mtensor\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msub_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiv_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstd\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    336\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mtensor\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    337\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: The size of tensor a (2544) must match the size of tensor b (3) at non-singleton dimension 0"
     ]
    }
   ],
   "source": [
    "transform(images[0][None,...].repeat(3,axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "2ce7c4a2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3056, 2544, 3)"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "images[0][...,None].repeat(3,axis=2).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "7480767d",
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'numpy.ndarray' object has no attribute 'new'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_149250/1621526422.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mto_image_list\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimages\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/GLIP/maskrcnn_benchmark/structures/image_list.py\u001b[0m in \u001b[0;36mto_image_list\u001b[0;34m(tensors, size_divisible)\u001b[0m\n\u001b[1;32m     60\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     61\u001b[0m         \u001b[0mbatch_shape\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtensors\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mmax_size\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 62\u001b[0;31m         \u001b[0mbatched_imgs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtensors\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnew\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mbatch_shape\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzero_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     63\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpad_img\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtensors\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbatched_imgs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     64\u001b[0m             \u001b[0mpad_img\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m:\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcopy_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'numpy.ndarray' object has no attribute 'new'"
     ]
    }
   ],
   "source": [
    "to_image_list(images)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4db060be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fa2e65a6640>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "image_path = '/share/fsmresfiles/MIMIC_CXR/2.0.0/s58219844/88498b37-c21dc7ba-bc202800-b517a62d-f7ac5bcf.dcm'\n",
    "ds = pydicom.dcmread(image_path)\n",
    "\n",
    "plt.imshow(ds.pixel_array,cmap=plt.cm.bone)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f49413e2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Dataset.file_meta -------------------------------\n",
       "(0002, 0000) File Meta Information Group Length  UL: 206\n",
       "(0002, 0001) File Meta Information Version       OB: b'\\x00\\x01'\n",
       "(0002, 0002) Media Storage SOP Class UID         UI: Digital X-Ray Image Storage - For Presentation\n",
       "(0002, 0003) Media Storage SOP Instance UID      UI: 2.25.181156868769981012043172036552678680109\n",
       "(0002, 0010) Transfer Syntax UID                 UI: Explicit VR Little Endian\n",
       "(0002, 0012) Implementation Class UID            UI: 2.25.55362949469033348352269585565668676650\n",
       "(0002, 0013) Implementation Version Name         SH: 'MIMIC-CXR v2.0.0'\n",
       "-------------------------------------------------\n",
       "(0008, 0005) Specific Character Set              CS: 'ISO_IR 100'\n",
       "(0008, 0008) Image Type                          CS: ['DERIVED', 'PRIMARY']\n",
       "(0008, 0016) SOP Class UID                       UI: Digital X-Ray Image Storage - For Presentation\n",
       "(0008, 0018) SOP Instance UID                    UI: 2.25.181156868769981012043172036552678680109\n",
       "(0008, 0020) Study Date                          DA: '21871010'\n",
       "(0008, 0021) Series Date                         DA: '21871010'\n",
       "(0008, 0022) Acquisition Date                    DA: '21871010'\n",
       "(0008, 0023) Content Date                        DA: '21871010'\n",
       "(0008, 0030) Study Time                          TM: '125551.703'\n",
       "(0008, 0031) Series Time                         TM: '125610.796'\n",
       "(0008, 0032) Acquisition Time                    TM: '125610.796'\n",
       "(0008, 0033) Content Time                        TM: '125610.796'\n",
       "(0008, 0050) Accession Number                    SH: '58219844'\n",
       "(0008, 0060) Modality                            CS: 'DX'\n",
       "(0008, 0068) Presentation Intent Type            CS: 'FOR PRESENTATION'\n",
       "(0008, 0070) Manufacturer                        LO: ''\n",
       "(0008, 0090) Referring Physician's Name          PN: ''\n",
       "(0008, 1032)  Procedure Code Sequence  1 item(s) ---- \n",
       "   (0008, 0100) Code Value                          SH: 'C12'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'CLP'\n",
       "   (0008, 0104) Code Meaning                        LO: 'CHEST (PORTABLE AP)'\n",
       "   ---------\n",
       "(0008, 2218)  Anatomic Region Sequence  1 item(s) ---- \n",
       "   (0008, 0100) Code Value                          SH: 'T-D3000'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'SNM3'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Chest'\n",
       "   (0008, 0105) Mapping Resource                    CS: 'DCMR'\n",
       "   (0008, 0106) Context Group Version               DT: '20020904'\n",
       "   (0008, 010f) Context Identifier                  CS: '4031'\n",
       "   ---------\n",
       "(0010, 0010) Patient's Name                      PN: ''\n",
       "(0010, 0020) Patient ID                          LO: '10000935'\n",
       "(0010, 0030) Patient's Birth Date                DA: ''\n",
       "(0010, 0040) Patient's Sex                       CS: ''\n",
       "(0012, 0062) Patient Identity Removed            CS: 'YES'\n",
       "(0012, 0063) De-identification Method            LO: 'Basic Prof. PS3.15 Table E.1-1 2017e, with options.'\n",
       "(0012, 0064)  De-identification Method Code Sequence  5 item(s) ---- \n",
       "   (0008, 0100) Code Value                          SH: '113100'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'DCM'\n",
       "   (0008, 0103) Coding Scheme Version               SH: '20170914'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Basic Application Confidentiality Profile'\n",
       "   ---------\n",
       "   (0008, 0100) Code Value                          SH: '113105'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'DCM'\n",
       "   (0008, 0103) Coding Scheme Version               SH: '20170914'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Clean Descriptors Option'\n",
       "   ---------\n",
       "   (0008, 0100) Code Value                          SH: '113107'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'DCM'\n",
       "   (0008, 0103) Coding Scheme Version               SH: '20170914'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Retain Longitudinal Temporal Information Modified Dates Option'\n",
       "   ---------\n",
       "   (0008, 0100) Code Value                          SH: '113101'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'DCM'\n",
       "   (0008, 0103) Coding Scheme Version               SH: '20170914'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Clean Pixel Data Option'\n",
       "   ---------\n",
       "   (0008, 0100) Code Value                          SH: '113103'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'DCM'\n",
       "   (0008, 0103) Coding Scheme Version               SH: '20170914'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Clean Graphics Option'\n",
       "   ---------\n",
       "(0018, 0015) Body Part Examined                  CS: 'PORT CHEST'\n",
       "(0018, 1147) Field of View Shape                 CS: 'RECTANGLE'\n",
       "(0018, 1149) Field of View Dimension(s)          IS: [425, 354]\n",
       "(0018, 1164) Imager Pixel Spacing                DS: [0.139, 0.139]\n",
       "(0018, 1405) Relative X-Ray Exposure             IS: '1602'\n",
       "(0018, 1411) Exposure Index                      DS: '338.19'\n",
       "(0018, 1412) Target Exposure Index               DS: '316.18'\n",
       "(0018, 1413) Deviation Index                     DS: '0.29'\n",
       "(0018, 1508) Positioner Type                     CS: 'NONE'\n",
       "(0018, 1600) Shutter Shape                       CS: 'POLYGONAL'\n",
       "(0018, 1620) Vertices of the Polygonal Shutter   IS: [2513, 1, 3053, 5, 3053, 2541, 2937, 2544, 466, 2544, 489, 1]\n",
       "(0018, 1622) Shutter Presentation Value          US: 0\n",
       "(0018, 1700) Collimator Shape                    CS: 'RECTANGULAR'\n",
       "(0018, 1702) Collimator Left Vertical Edge       IS: '0'\n",
       "(0018, 1704) Collimator Right Vertical Edge      IS: '2544'\n",
       "(0018, 1706) Collimator Upper Horizontal Edge    IS: '464'\n",
       "(0018, 1708) Collimator Lower Horizontal Edge    IS: '3052'\n",
       "(0018, 5101) View Position                       CS: 'AP'\n",
       "(0018, 6000) Sensitivity                         DS: '987.0'\n",
       "(0018, 7001) Detector Temperature                DS: '30.0'\n",
       "(0018, 7004) Detector Type                       CS: 'DIRECT'\n",
       "(0018, 7005) Detector Configuration              CS: 'AREA'\n",
       "(0018, 701a) Detector Binning                    DS: [1, 1]\n",
       "(0018, 7020) Detector Element Physical Size      DS: [0.139, 0.139]\n",
       "(0018, 7022) Detector Element Spacing            DS: [0.139, 0.139]\n",
       "(0020, 000d) Study Instance UID                  UI: 2.25.250671978784336858319729432289619267236\n",
       "(0020, 000e) Series Instance UID                 UI: 2.25.128804925614456547687486636871622263354\n",
       "(0020, 0010) Study ID                            SH: '58219844'\n",
       "(0020, 0011) Series Number                       IS: '1'\n",
       "(0020, 0012) Acquisition Number                  IS: '1'\n",
       "(0020, 0013) Instance Number                     IS: '1'\n",
       "(0020, 0020) Patient Orientation                 CS: ['L', 'F']\n",
       "(0020, 0062) Image Laterality                    CS: 'U'\n",
       "(0020, 1002) Images in Acquisition               IS: '1'\n",
       "(0028, 0002) Samples per Pixel                   US: 1\n",
       "(0028, 0004) Photometric Interpretation          CS: 'MONOCHROME2'\n",
       "(0028, 0010) Rows                                US: 3056\n",
       "(0028, 0011) Columns                             US: 2544\n",
       "(0028, 0030) Pixel Spacing                       DS: [0.139, 0.139]\n",
       "(0028, 0100) Bits Allocated                      US: 16\n",
       "(0028, 0101) Bits Stored                         US: 12\n",
       "(0028, 0102) High Bit                            US: 11\n",
       "(0028, 0103) Pixel Representation                US: 0\n",
       "(0028, 0106) Smallest Image Pixel Value          US: 0\n",
       "(0028, 0107) Largest Image Pixel Value           US: 4095\n",
       "(0028, 0301) Burned In Annotation                CS: 'YES'\n",
       "(0028, 1040) Pixel Intensity Relationship        CS: 'LOG'\n",
       "(0028, 1041) Pixel Intensity Relationship Sign   SS: -1\n",
       "(0028, 1050) Window Center                       DS: '2048.0'\n",
       "(0028, 1051) Window Width                        DS: '4096.0'\n",
       "(0028, 1052) Rescale Intercept                   DS: '0.0'\n",
       "(0028, 1053) Rescale Slope                       DS: '1.0'\n",
       "(0028, 1054) Rescale Type                        LO: 'US'\n",
       "(0028, 2110) Lossy Image Compression             CS: '00'\n",
       "(0032, 1033) Requesting Service                  LO: 'EU'\n",
       "(0040, 0244) Performed Procedure Step Start Date DA: '21871010'\n",
       "(0040, 0245) Performed Procedure Step Start Time TM: '125551.703'\n",
       "(0040, 0254) Performed Procedure Step Descriptio LO: 'CHEST (PORTABLE AP)'\n",
       "(0040, 0302) Entrance Dose                       US: 0\n",
       "(0040, 0303) Exposed Area                        US: [36, 35]\n",
       "(0054, 0220)  View Code Sequence  1 item(s) ---- \n",
       "   (0008, 0100) Code Value                          SH: 'R-10206'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'SNM3'\n",
       "   (0008, 0104) Code Meaning                        LO: 'antero-posterior'\n",
       "   (0008, 0105) Mapping Resource                    CS: 'DCMR'\n",
       "   (0008, 0106) Context Group Version               DT: '20040302'\n",
       "   (0008, 010f) Context Identifier                  CS: '4010'\n",
       "   ---------\n",
       "(0054, 0410)  Patient Orientation Code Sequence  1 item(s) ---- \n",
       "   (0008, 0100) Code Value                          SH: 'F-10440'\n",
       "   (0008, 0102) Coding Scheme Designator            SH: 'SNM3'\n",
       "   (0008, 0104) Code Meaning                        LO: 'Erect'\n",
       "   (0008, 0105) Mapping Resource                    CS: 'DCMR'\n",
       "   (0008, 0106) Context Group Version               DT: '20020904'\n",
       "   (0008, 010f) Context Identifier                  CS: '19'\n",
       "   ---------\n",
       "(0070, 0001)  Graphic Annotation Sequence  1 item(s) ---- \n",
       "   (0008, 1140)  Referenced Image Sequence  1 item(s) ---- \n",
       "      (0008, 1150) Referenced SOP Class UID            UI: Digital X-Ray Image Storage - For Presentation\n",
       "      (0008, 1155) Referenced SOP Instance UID         UI: 2.25.181156868769981012043172036552678680109\n",
       "      ---------\n",
       "   (0070, 0009)  Graphic Object Sequence  0 item(s) ---- \n",
       "   ---------\n",
       "(2050, 0020) Presentation LUT Shape              CS: 'IDENTITY'\n",
       "(7fe0, 0010) Pixel Data                          OW: Array of 15548928 elements"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "307917c3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0008, 0100) Code Value                          SH: 'C12'\n",
       "(0008, 0102) Coding Scheme Designator            SH: 'CLP'\n",
       "(0008, 0104) Code Meaning                        LO: 'CHEST (PORTABLE AP)'"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.ProcedureCodeSequence[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "0aa02d19",
   "metadata": {},
   "outputs": [],
   "source": [
    "study = pd.read_csv(os.path.join(data_path,'cxr-study-list.csv'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "af8dc0c5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                                                                                                        | 0/227835 [00:00<?, ?it/s]/tmp/ipykernel_3928/3196062173.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  study['text'].iloc[i] = f.read().strip().lower()\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 227835/227835 [1:34:46<00:00, 40.06it/s]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "for i in tqdm(range(len(study))):\n",
    "    with open(os.path.join(data_path,study['path'].iloc[i])) as f:\n",
    "        study['text'].iloc[i] = f.read().strip().lower()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "f5129db3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>subject_id</th>\n",
       "      <th>study_id</th>\n",
       "      <th>path</th>\n",
       "      <th>text</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>10000032</td>\n",
       "      <td>50414267</td>\n",
       "      <td>files/p10/p10000032/s50414267.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53189527</td>\n",
       "      <td>files/p10/p10000032/s53189527.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>10000032</td>\n",
       "      <td>53911762</td>\n",
       "      <td>files/p10/p10000032/s53911762.txt</td>\n",
       "      <td>final report\\n examination:  chest (portable a...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10000032</td>\n",
       "      <td>56699142</td>\n",
       "      <td>files/p10/p10000032/s56699142.txt</td>\n",
       "      <td>final report\\n indication:  ___ year old woman...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10000764</td>\n",
       "      <td>57375967</td>\n",
       "      <td>files/p10/p10000764/s57375967.txt</td>\n",
       "      <td>final report\\n examination:  chest (pa and lat...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227830</th>\n",
       "      <td>19999442</td>\n",
       "      <td>58708861</td>\n",
       "      <td>files/p19/p19999442/s58708861.txt</td>\n",
       "      <td>final report\\n portable ap chest x-ray\\n \\n in...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227831</th>\n",
       "      <td>19999733</td>\n",
       "      <td>57132437</td>\n",
       "      <td>files/p19/p19999733/s57132437.txt</td>\n",
       "      <td>final report\\n indication:  ___-year-old with ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227832</th>\n",
       "      <td>19999987</td>\n",
       "      <td>55368167</td>\n",
       "      <td>files/p19/p19999987/s55368167.txt</td>\n",
       "      <td>final report\\n portable chest of ___\\n \\n comp...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227833</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58621812</td>\n",
       "      <td>files/p19/p19999987/s58621812.txt</td>\n",
       "      <td>final report\\n chest radiograph performed on _...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227834</th>\n",
       "      <td>19999987</td>\n",
       "      <td>58971208</td>\n",
       "      <td>files/p19/p19999987/s58971208.txt</td>\n",
       "      <td>final report\\n indication:  ___-year-old femal...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>227835 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        subject_id  study_id                               path  \\\n",
       "0         10000032  50414267  files/p10/p10000032/s50414267.txt   \n",
       "1         10000032  53189527  files/p10/p10000032/s53189527.txt   \n",
       "2         10000032  53911762  files/p10/p10000032/s53911762.txt   \n",
       "3         10000032  56699142  files/p10/p10000032/s56699142.txt   \n",
       "4         10000764  57375967  files/p10/p10000764/s57375967.txt   \n",
       "...            ...       ...                                ...   \n",
       "227830    19999442  58708861  files/p19/p19999442/s58708861.txt   \n",
       "227831    19999733  57132437  files/p19/p19999733/s57132437.txt   \n",
       "227832    19999987  55368167  files/p19/p19999987/s55368167.txt   \n",
       "227833    19999987  58621812  files/p19/p19999987/s58621812.txt   \n",
       "227834    19999987  58971208  files/p19/p19999987/s58971208.txt   \n",
       "\n",
       "                                                     text  \n",
       "0       final report\\n examination:  chest (pa and lat...  \n",
       "1       final report\\n examination:  chest (pa and lat...  \n",
       "2       final report\\n examination:  chest (portable a...  \n",
       "3       final report\\n indication:  ___ year old woman...  \n",
       "4       final report\\n examination:  chest (pa and lat...  \n",
       "...                                                   ...  \n",
       "227830  final report\\n portable ap chest x-ray\\n \\n in...  \n",
       "227831  final report\\n indication:  ___-year-old with ...  \n",
       "227832  final report\\n portable chest of ___\\n \\n comp...  \n",
       "227833  final report\\n chest radiograph performed on _...  \n",
       "227834  final report\\n indication:  ___-year-old femal...  \n",
       "\n",
       "[227835 rows x 4 columns]"
      ]
     },
     "execution_count": 125,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "edcc53ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "study.to_csv('/data/Mao/DATASET/MIMIC-CXR/2.0.0/cxr-study-list.csv',index=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cellpose",
   "language": "python",
   "name": "cellpose"
  },
  "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
