{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 1s 1s/step\n",
      "1/1 [==============================] - 1s 696ms/step\n",
      "1/1 [==============================] - 1s 695ms/step\n",
      "1/1 [==============================] - 0s 306ms/step\n",
      "1/1 [==============================] - 0s 256ms/step\n",
      "1/1 [==============================] - 0s 415ms/step\n",
      "1/1 [==============================] - 1s 878ms/step\n",
      "1/1 [==============================] - 1s 532ms/step\n",
      "1/1 [==============================] - 1s 507ms/step\n",
      "1/1 [==============================] - 0s 223ms/step\n",
      "1/1 [==============================] - 0s 235ms/step\n",
      "1/1 [==============================] - 0s 240ms/step\n",
      "1/1 [==============================] - 1s 832ms/step\n",
      "1/1 [==============================] - 1s 787ms/step\n",
      "1/1 [==============================] - 0s 236ms/step\n",
      "1/1 [==============================] - 0s 237ms/step\n",
      "1/1 [==============================] - 0s 283ms/step\n",
      "1/1 [==============================] - 1s 688ms/step\n",
      "1/1 [==============================] - 1s 893ms/step\n",
      "1/1 [==============================] - 0s 419ms/step\n",
      "1/1 [==============================] - 0s 381ms/step\n",
      "1/1 [==============================] - 0s 343ms/step\n",
      "两个GIF之间的FID值为: 156.63969820918683\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from PIL import Image\n",
    "from tensorflow.keras.applications.inception_v3 import InceptionV3, preprocess_input\n",
    "from tensorflow.keras.preprocessing import image\n",
    "from scipy.linalg import sqrtm\n",
    "import os\n",
    "def extract_frames_from_gif(gif_path):\n",
    "    frames = []\n",
    "    with Image.open(gif_path) as im:\n",
    "        try:\n",
    "            while True:\n",
    "                frame = im.copy()\n",
    "                frames.append(frame.convert('RGB'))  # 转换为RGB格式\n",
    "                im.seek(im.tell() + 1)\n",
    "        except EOFError:\n",
    "            pass\n",
    "    return frames\n",
    "\n",
    "def get_activations(images, model):\n",
    "    activations = []\n",
    "    for img in images:\n",
    "        img = img.resize((299, 299))  # InceptionV3的输入尺寸\n",
    "        x = image.img_to_array(img)\n",
    "        x = np.expand_dims(x, axis=0)\n",
    "        x = preprocess_input(x)\n",
    "        act = model.predict(x)\n",
    "        activations.append(act[0])\n",
    "    activations = np.array(activations)\n",
    "    return activations\n",
    "\n",
    "def calculate_frechet_distance(mu1, sigma1, mu2, sigma2):\n",
    "    diff = mu1 - mu2\n",
    "    # 计算协方差矩阵的平方根\n",
    "    covmean, _ = sqrtm(sigma1.dot(sigma2), disp=False)\n",
    "    # 处理数值误差导致的复数结果\n",
    "    if np.iscomplexobj(covmean):\n",
    "        covmean = covmean.real\n",
    "    # 计算FID\n",
    "    fid = diff.dot(diff) + np.trace(sigma1 + sigma2 - 2 * covmean)\n",
    "    return fid\n",
    "\n",
    "# 主程序\n",
    "path1 = ''\n",
    "path2 = ''\n",
    "files1 = os.listdir(path1)\n",
    "files2 = os.listdir(path2)\n",
    "re = []\n",
    "for i in range(len(files1)):\n",
    "    gif_path1 = path1 + files1[i]   # 第一个GIF文件路径\n",
    "    gif_path2 = path2 + files2[i]   # 第二个GIF文件路径\n",
    "\n",
    "    # 提取两个GIF的帧\n",
    "    frames1 = extract_frames_from_gif(gif_path1)\n",
    "    frames2 = extract_frames_from_gif(gif_path2)\n",
    "\n",
    "    # 加载预训练的InceptionV3模型\n",
    "    model = InceptionV3(include_top=False, pooling='avg', input_shape=(299, 299, 3))\n",
    "\n",
    "    # 获取激活值\n",
    "    act1 = get_activations(frames1, model)\n",
    "    act2 = get_activations(frames2, model)\n",
    "\n",
    "    # 计算均值和协方差\n",
    "    mu1, sigma1 = np.mean(act1, axis=0), np.cov(act1, rowvar=False)\n",
    "    mu2, sigma2 = np.mean(act2, axis=0), np.cov(act2, rowvar=False)\n",
    "\n",
    "    # 计算FID\n",
    "    fid_value = calculate_frechet_distance(mu1, sigma1, mu2, sigma2)\n",
    "    print(f'两个GIF之间的FID值为: {fid_value}')\n",
    "    re.append(fid_value)\n",
    "print(np.mean(re))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.5"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "np.mean([1,2])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[31mERROR: Invalid requirement: 'pdf2image,'\u001b[0m\u001b[31m\n",
      "\u001b[0m"
     ]
    }
   ],
   "source": [
    "!pip install pdf2image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pdf2image import convert_from_path\n",
    "\n",
    "# Convert the PDF pages to images\n",
    "pdf_path = '/Health - ECG 2024-09-14 at 00.53.pdf'\n",
    "pages = convert_from_path(pdf_path, 300)\n",
    "\n",
    "# Save the images of pages containing the ECG\n",
    "for i, page in enumerate(pages):\n",
    "    page.save(f'ecg_page_{i+1}.png', 'PNG')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import cv2\n",
    "import numpy as np\n",
    "\n",
    "# Load the ECG image\n",
    "ecg_image_path = 'ecg_page_2.png'  # Adjust the page index based on the correct page number\n",
    "img = cv2.imread(ecg_image_path, cv2.IMREAD_GRAYSCALE)\n",
    "\n",
    "# Apply edge detection to highlight the ECG line\n",
    "edges = cv2.Canny(img, 50, 150)\n",
    "\n",
    "# Find contours in the image\n",
    "contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)\n",
    "\n",
    "# Initialize an empty array to store the ECG signal\n",
    "ecg_signal = []\n",
    "\n",
    "# Extract the points from the largest contour (assuming it’s the ECG signal)\n",
    "if contours:\n",
    "    largest_contour = max(contours, key=cv2.contourArea)\n",
    "    for point in largest_contour:\n",
    "        ecg_signal.append(point[0][1])  # Append the Y-coordinate of each point\n",
    "\n",
    "# Normalize the signal (optional, depending on your use case)\n",
    "ecg_signal = np.array(ecg_signal)\n",
    "# ecg_signal = (ecg_signal - np.min(ecg_signal)) / (np.max(ecg_signal) - np.min(ecg_signal))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.        , 0.        , 0.        , ..., 0.        , 0.        ,\n",
       "        0.        ],\n",
       "       [0.        , 0.04761905, 0.11111111, ..., 0.29494355, 0.26775216,\n",
       "        0.29100529],\n",
       "       [0.        , 0.        , 0.        , ..., 0.        , 0.        ,\n",
       "        0.        ],\n",
       "       ...,\n",
       "       [0.        , 0.        , 0.        , ..., 0.        , 0.        ,\n",
       "        0.        ],\n",
       "       [0.        , 0.        , 0.        , ..., 0.        , 0.        ,\n",
       "        0.        ],\n",
       "       [0.        , 0.        , 0.        , ..., 0.        , 0.        ,\n",
       "        0.        ]])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "process_ekg(ecg_signal)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from scipy import interpolate\n",
    "def process_ekg(ekg_data, target_length=2250, repetitions=16):\n",
    "    processed_ekg = np.zeros((12, target_length))\n",
    "    \n",
    "    # 원본 데이터를 16번 반복\n",
    "    repeated_data = np.tile(ekg_data, repetitions)\n",
    "    \n",
    "    # 반복된 데이터의 길이\n",
    "    original_length = len(repeated_data)\n",
    "    \n",
    "    if original_length < target_length:\n",
    "        # Interpolation\n",
    "        x = np.linspace(0, 1, original_length)\n",
    "        f = interpolate.interp1d(x, repeated_data, kind='linear')\n",
    "        x_new = np.linspace(0, 1, target_length)\n",
    "        processed_ekg[1] = f(x_new)\n",
    "    elif original_length > target_length:\n",
    "        # Resampling\n",
    "        x = np.linspace(0, 1, original_length)\n",
    "        x_new = np.linspace(0, 1, target_length)\n",
    "        processed_ekg[1] = np.interp(x_new, x, repeated_data)\n",
    "    else:\n",
    "        processed_ekg[1] = repeated_data[:target_length]\n",
    "    if not isinstance(processed_ekg, np.ndarray):\n",
    "        processed_ekg = np.array(processed_ekg)\n",
    "    \n",
    "    # Z-score 정규화\n",
    "    processed_ekg = (processed_ekg - np.mean(processed_ekg)) / np.std(processed_ekg)\n",
    "    \n",
    "    # 이미 적절한 샘플링 레이트라고 가정. 필요하다면 여기서 리샘플링\n",
    "    \n",
    "    return torch.from_numpy(processed_ekg).float().unsqueeze(0)  # (1, length)\n",
    "   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.plot(signal)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0. ... 0. 0. 0.]\n"
     ]
    }
   ],
   "source": [
    "import cv2\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Load the image\n",
    "image_path = 'ecg_page_2.png'\n",
    "image = cv2.imread(image_path)\n",
    "\n",
    "# Convert the image to RGB (OpenCV loads images in BGR by default)\n",
    "image_rgb = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)\n",
    "\n",
    "# Crop the image to focus on the first row of the ECG signal\n",
    "# Adjust these values based on the actual position of the first row in the image\n",
    "cropped_image = image_rgb[:, :]  # Modify these values if necessary\n",
    "\n",
    "# Isolate the red color channel (assumes red is the dominant color of the ECG)\n",
    "lower_red = np.array([100, 0, 0])\n",
    "upper_red = np.array([255, 100, 100])\n",
    "\n",
    "# Create a mask that captures the red lines in the cropped image\n",
    "mask = cv2.inRange(cropped_image, lower_red, upper_red)\n",
    "\n",
    "# Apply the mask to extract only the red parts of the cropped image\n",
    "red_extracted = cv2.bitwise_and(cropped_image, cropped_image, mask=mask)\n",
    "\n",
    "# Convert the red extraction to grayscale to detect the ECG signal\n",
    "gray_ecg = cv2.cvtColor(red_extracted, cv2.COLOR_RGB2GRAY)\n",
    "\n",
    "# Find the coordinates of the non-zero values, which correspond to the ECG signal\n",
    "y_coords, x_coords = np.where(gray_ecg > 0)\n",
    "\n",
    "# Create an empty array to hold the ECG signal from the first row\n",
    "ecg_signal_first_row = np.zeros(gray_ecg.shape[1])\n",
    "\n",
    "# Populate the ECG signal by averaging the y-values at each x-coordinate\n",
    "for x in range(gray_ecg.shape[1]):\n",
    "    y_vals = y_coords[x_coords == x]\n",
    "    if len(y_vals) > 0:\n",
    "        ecg_signal_first_row[x] = np.mean(y_vals)\n",
    "\n",
    "# Normalize the ECG signal (optional)\n",
    "ecg_signal_first_row = (ecg_signal_first_row - np.min(ecg_signal_first_row)) / (np.max(ecg_signal_first_row) - np.min(ecg_signal_first_row))\n",
    "\n",
    "# Plot the extracted ECG signal from the first row\n",
    "plt.plot(ecg_signal_first_row)\n",
    "plt.title(\"Extracted ECG Signal from First Row\")\n",
    "plt.xlabel(\"Time (samples)\")\n",
    "plt.ylabel(\"Amplitude (normalized)\")\n",
    "plt.show()\n",
    "\n",
    "# Output the ECG signal as an array\n",
    "print(ecg_signal_first_row)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2550, 3301, 3)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "image.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(366, 2972)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from PIL import Image\n",
    "import numpy as np\n",
    "\n",
    "# Load the image\n",
    "image_path = 'ecg_page_2.png'\n",
    "image = Image.open(image_path)\n",
    "\n",
    "# Convert image to numpy array\n",
    "image_array = np.array(image)\n",
    "\n",
    "# Extract the red channel\n",
    "red_channel = image_array[:, :, 0]\n",
    "\n",
    "# Since the background is white (255, 255, 255), we will extract only the red values\n",
    "# which are significantly lower than 255 to identify the ECG line\n",
    "threshold = 200\n",
    "ecg_signal = np.where(red_channel < threshold, red_channel, 0)\n",
    "\n",
    "# Display the shape to see what we've got\n",
    "ecg_signal.shape\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "提取的一维信号： [0. 0. 0. ... 0. 0. 0.]\n"
     ]
    }
   ],
   "source": [
    "import cv2\n",
    "import numpy as np\n",
    "\n",
    "# 读取图像\n",
    "image = cv2.imread('/ecg_page_2.png')  # 替换为你的图像文件路径\n",
    "\n",
    "# 将图像转换为HSV颜色空间\n",
    "hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)\n",
    "\n",
    "# 定义红色的HSV范围\n",
    "# 红色在HSV颜色空间中有两个范围，需要分别处理\n",
    "lower_red1 = np.array([0, 70, 50])\n",
    "upper_red1 = np.array([10, 255, 255])\n",
    "\n",
    "lower_red2 = np.array([170, 70, 50])\n",
    "upper_red2 = np.array([180, 255, 255])\n",
    "\n",
    "# 创建红色掩码\n",
    "mask1 = cv2.inRange(hsv, lower_red1, upper_red1)\n",
    "mask2 = cv2.inRange(hsv, lower_red2, upper_red2)\n",
    "mask = cv2.bitwise_or(mask1, mask2)\n",
    "\n",
    "# 对掩码进行形态学处理，去除噪点\n",
    "kernel = np.ones((3, 3), np.uint8)\n",
    "mask = cv2.morphologyEx(mask, cv2.MORPH_OPEN, kernel)\n",
    "mask = cv2.morphologyEx(mask, cv2.MORPH_DILATE, kernel)\n",
    "\n",
    "# 找到红色像素的位置\n",
    "red_positions = np.column_stack(np.where(mask > 0))\n",
    "\n",
    "# 将二维的位置转换为一维信号，例如对行求和\n",
    "signal = np.sum(mask, axis=0)\n",
    "\n",
    "# 归一化信号（可选）\n",
    "signal = signal / np.max(signal)\n",
    "\n",
    "# 保存或输出一维信号\n",
    "# np.savetxt('signal.txt', signal)\n",
    "\n",
    "print(\"提取的一维信号：\", signal)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cloning into 'pytorch-i3d'...\n",
      "remote: Enumerating objects: 21, done.\u001b[K\n",
      "remote: Total 21 (delta 0), reused 0 (delta 0), pack-reused 21 (from 1)\u001b[K\n",
      "Receiving objects: 100% (21/21), 178.18 MiB | 31.45 MiB/s, done.\n",
      "Resolving deltas: 100% (5/5), done.\n",
      "Updating files: 100% (12/12), done.\n"
     ]
    }
   ],
   "source": [
    "!git clone https://github.com/piergiaj/pytorch-i3d.git"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "python: can't open file 'setup.py': [Errno 2] No such file or directory\n"
     ]
    }
   ],
   "source": [
    "!cd pytorch-i3d\n",
    "!python setup.py install\n",
    "!cd .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-09-17 22:27:59.334340: W tensorflow/core/common_runtime/gpu/gpu_device.cc:1960] Cannot dlopen some GPU libraries. Please make sure the missing libraries mentioned above are installed properly if you would like to use GPU. Follow the guide at https://www.tensorflow.org/install/gpu for how to download and setup the required libraries for your platform.\n",
      "Skipping registering GPU devices...\n"
     ]
    },
    {
     "ename": "TypeError",
     "evalue": "'AutoTrackable' object is not callable",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[3], line 126\u001b[0m\n\u001b[1;32m    123\u001b[0m video2 \u001b[38;5;241m=\u001b[39m load_gif(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m/raid/home/CAMCA/yl463/Video/TestDataApical_embedding_mixing/pred/A2C.USm.1.2.840.114089.1.0.1.2887499449.1641693197.4144.17402_1_21.mp4_pred.gif\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m    125\u001b[0m \u001b[38;5;66;03m# Compute FVD score\u001b[39;00m\n\u001b[0;32m--> 126\u001b[0m fvd_score \u001b[38;5;241m=\u001b[39m \u001b[43mcompute_fvd\u001b[49m\u001b[43m(\u001b[49m\u001b[43mvideo1\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mvideo2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mi3d_model\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    127\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mFVD Score: \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfvd_score\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n",
      "Cell \u001b[0;32mIn[3], line 110\u001b[0m, in \u001b[0;36mcompute_fvd\u001b[0;34m(video1, video2, model)\u001b[0m\n\u001b[1;32m    107\u001b[0m video1_preprocessed \u001b[38;5;241m=\u001b[39m preprocess_video(video1)\n\u001b[1;32m    108\u001b[0m video2_preprocessed \u001b[38;5;241m=\u001b[39m preprocess_video(video2)\n\u001b[0;32m--> 110\u001b[0m features1 \u001b[38;5;241m=\u001b[39m \u001b[43mextract_features\u001b[49m\u001b[43m(\u001b[49m\u001b[43mvideo1_preprocessed\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    111\u001b[0m features2 \u001b[38;5;241m=\u001b[39m extract_features(video2_preprocessed, model)\n\u001b[1;32m    113\u001b[0m \u001b[38;5;66;03m# Compute mean and covariance\u001b[39;00m\n",
      "Cell \u001b[0;32mIn[3], line 73\u001b[0m, in \u001b[0;36mextract_features\u001b[0;34m(video, model)\u001b[0m\n\u001b[1;32m     62\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mextract_features\u001b[39m(video, model):\n\u001b[1;32m     63\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m     64\u001b[0m \u001b[38;5;124;03m    Extract I3D features for a given video.\u001b[39;00m\n\u001b[1;32m     65\u001b[0m \u001b[38;5;124;03m    \u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     71\u001b[0m \u001b[38;5;124;03m        Video features of shape (1, num_features).\u001b[39;00m\n\u001b[1;32m     72\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m---> 73\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mmodel\u001b[49m\u001b[43m(\u001b[49m\u001b[43mvideo\u001b[49m\u001b[43m)\u001b[49m[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdefault\u001b[39m\u001b[38;5;124m'\u001b[39m]\n",
      "\u001b[0;31mTypeError\u001b[0m: 'AutoTrackable' object is not callable"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf\n",
    "import numpy as np\n",
    "from scipy import linalg\n",
    "from tensorflow_hub import load as hub_load\n",
    "from PIL import Image\n",
    "\n",
    "# Load pre-trained I3D model from TensorFlow Hub\n",
    "i3d_model = hub_load(\"https://tfhub.dev/deepmind/i3d-kinetics-400/1\")\n",
    "\n",
    "def load_gif(filename):\n",
    "    \"\"\"\n",
    "    Load a GIF file and convert it into a numpy array of shape (frames, height, width, channels).\n",
    "    \n",
    "    Args:\n",
    "        filename: Path to the GIF file.\n",
    "    \n",
    "    Returns:\n",
    "        Numpy array with shape (frames, height, width, 3).\n",
    "    \"\"\"\n",
    "    gif = Image.open(filename)\n",
    "    frames = []\n",
    "    \n",
    "    try:\n",
    "        while True:\n",
    "            # Convert each frame to RGB and resize to (128, 128)\n",
    "            frame = gif.convert(\"RGB\").resize((128, 128))\n",
    "            frames.append(np.array(frame))\n",
    "            gif.seek(gif.tell() + 1)\n",
    "    except EOFError:\n",
    "        pass  # End of sequence\n",
    "    \n",
    "    # Stack the frames into a numpy array (frames, height, width, channels)\n",
    "    return np.stack(frames)\n",
    "\n",
    "def preprocess_video(video, target_frames=11, target_size=(128, 128)):\n",
    "    \"\"\"\n",
    "    Preprocess video for I3D model: resize, center-crop, and normalize.\n",
    "    \n",
    "    Args:\n",
    "        video: Input video as a numpy array of shape (frames, height, width, channels).\n",
    "        target_frames: Number of frames to sample.\n",
    "        target_size: Target size for resizing (height, width).\n",
    "        \n",
    "    Returns:\n",
    "        Preprocessed video of shape (1, target_frames, target_size[0], target_size[1], 3).\n",
    "    \"\"\"\n",
    "    num_frames = video.shape[0]\n",
    "    \n",
    "    # Sample frames evenly\n",
    "    indices = np.linspace(0, num_frames - 1, target_frames).astype(int)\n",
    "    sampled_video = video[indices]\n",
    "\n",
    "    # Resize to target size\n",
    "    sampled_video = tf.image.resize(sampled_video, target_size)\n",
    "\n",
    "    # Normalize video\n",
    "    sampled_video = sampled_video / 255.0\n",
    "\n",
    "    # Add batch dimension\n",
    "    return tf.expand_dims(sampled_video, axis=0)\n",
    "\n",
    "def extract_features(video, model):\n",
    "    \"\"\"\n",
    "    Extract I3D features for a given video.\n",
    "    \n",
    "    Args:\n",
    "        video: Preprocessed video as a tensor of shape (1, frames, height, width, 3).\n",
    "        model: Pre-trained I3D model.\n",
    "        \n",
    "    Returns:\n",
    "        Video features of shape (1, num_features).\n",
    "    \"\"\"\n",
    "    return model(video)['default']\n",
    "\n",
    "def calculate_frechet_distance(mu1, sigma1, mu2, sigma2):\n",
    "    \"\"\"\n",
    "    Compute the Frechet Distance between two Gaussian distributions.\n",
    "    \n",
    "    Args:\n",
    "        mu1, sigma1: Mean and covariance of the first distribution.\n",
    "        mu2, sigma2: Mean and covariance of the second distribution.\n",
    "        \n",
    "    Returns:\n",
    "        The Frechet distance.\n",
    "    \"\"\"\n",
    "    diff = mu1 - mu2\n",
    "    covmean, _ = linalg.sqrtm(sigma1.dot(sigma2), disp=False)\n",
    "    \n",
    "    # Numerical stability check\n",
    "    if np.iscomplexobj(covmean):\n",
    "        covmean = covmean.real\n",
    "    \n",
    "    return (diff.dot(diff) + np.trace(sigma1 + sigma2 - 2 * covmean))\n",
    "\n",
    "def compute_fvd(video1, video2, model):\n",
    "    \"\"\"\n",
    "    Compute FVD between two videos.\n",
    "    \n",
    "    Args:\n",
    "        video1, video2: Input videos as numpy arrays of shape (frames, height, width, channels).\n",
    "        model: Pre-trained I3D model.\n",
    "        \n",
    "    Returns:\n",
    "        FVD score.\n",
    "    \"\"\"\n",
    "    # Preprocess and extract features\n",
    "    video1_preprocessed = preprocess_video(video1)\n",
    "    video2_preprocessed = preprocess_video(video2)\n",
    "    \n",
    "    features1 = extract_features(video1_preprocessed, model)\n",
    "    features2 = extract_features(video2_preprocessed, model)\n",
    "\n",
    "    # Compute mean and covariance\n",
    "    mu1, sigma1 = np.mean(features1, axis=0), np.cov(features1, rowvar=False)\n",
    "    mu2, sigma2 = np.mean(features2, axis=0), np.cov(features2, rowvar=False)\n",
    "    \n",
    "    # Compute FVD score\n",
    "    return calculate_frechet_distance(mu1, sigma1, mu2, sigma2)\n",
    "\n",
    "# Example usage\n",
    "# Load two GIF files (11 frames, 128x128)\n",
    "video1 = load_gif('/gt/A2C.USm.1.2.840.114089.1.0.1.2887499449.1641693197.4144.17402_1_21.mp4.gif')\n",
    "video2 = load_gif('/pred/A2C.USm.1.2.840.114089.1.0.1.2887499449.1641693197.4144.17402_1_21.mp4_pred.gif')\n",
    "\n",
    "# Compute FVD score\n",
    "fvd_score = compute_fvd(video1, video2, i3d_model)\n",
    "print(f\"FVD Score: {fvd_score}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "module 'torch.linalg' has no attribute 'sqrtm'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[7], line 97\u001b[0m\n\u001b[1;32m     94\u001b[0m     \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m两个视频之间的FVD值为:\u001b[39m\u001b[38;5;124m'\u001b[39m, fvd_value)\n\u001b[1;32m     96\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;18m__name__\u001b[39m \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m__main__\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[0;32m---> 97\u001b[0m     \u001b[43mmain\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "Cell \u001b[0;32mIn[7], line 93\u001b[0m, in \u001b[0;36mmain\u001b[0;34m()\u001b[0m\n\u001b[1;32m     90\u001b[0m sigma2 \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mfrom_numpy(np\u001b[38;5;241m.\u001b[39mcov(features2\u001b[38;5;241m.\u001b[39mnumpy(), rowvar\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m))\n\u001b[1;32m     92\u001b[0m \u001b[38;5;66;03m# 计算FVD\u001b[39;00m\n\u001b[0;32m---> 93\u001b[0m fvd_value \u001b[38;5;241m=\u001b[39m \u001b[43mcompute_fvd\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmu1\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msigma1\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmu2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msigma2\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     94\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m两个视频之间的FVD值为:\u001b[39m\u001b[38;5;124m'\u001b[39m, fvd_value)\n",
      "Cell \u001b[0;32mIn[7], line 34\u001b[0m, in \u001b[0;36mcompute_fvd\u001b[0;34m(mu1, sigma1, mu2, sigma2)\u001b[0m\n\u001b[1;32m     32\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcompute_fvd\u001b[39m(mu1, sigma1, mu2, sigma2):\n\u001b[1;32m     33\u001b[0m     diff \u001b[38;5;241m=\u001b[39m mu1 \u001b[38;5;241m-\u001b[39m mu2\n\u001b[0;32m---> 34\u001b[0m     covmean, _ \u001b[38;5;241m=\u001b[39m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlinalg\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msqrtm\u001b[49m(sigma1 \u001b[38;5;241m@\u001b[39m sigma2, disp\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[1;32m     35\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m torch\u001b[38;5;241m.\u001b[39misfinite(covmean)\u001b[38;5;241m.\u001b[39mall():\n\u001b[1;32m     36\u001b[0m         offset \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39meye(sigma1\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m0\u001b[39m)) \u001b[38;5;241m*\u001b[39m \u001b[38;5;241m1e-6\u001b[39m\n",
      "\u001b[0;31mAttributeError\u001b[0m: module 'torch.linalg' has no attribute 'sqrtm'"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torchvision.transforms as transforms\n",
    "from PIL import Image\n",
    "import numpy as np\n",
    "\n",
    "# 定义读取GIF并提取帧的函数\n",
    "def read_gif(file_path):\n",
    "    frames = []\n",
    "    with Image.open(file_path) as im:\n",
    "        try:\n",
    "            while True:\n",
    "                frame = im.copy()\n",
    "                frames.append(frame)\n",
    "                im.seek(im.tell() + 1)\n",
    "        except EOFError:\n",
    "            pass\n",
    "    return frames\n",
    "\n",
    "# 定义处理帧的函数\n",
    "def process_frames(frames, transform):\n",
    "    processed_frames = []\n",
    "    for frame in frames:\n",
    "        frame = frame.convert('RGB')  # 转换为RGB\n",
    "        frame = transform(frame)\n",
    "        processed_frames.append(frame)\n",
    "    # 将帧堆叠成形状为[T, C, H, W]的张量\n",
    "    video_tensor = torch.stack(processed_frames)  # Shape: [T, C, H, W]\n",
    "    return video_tensor\n",
    "\n",
    "# 定义计算FVD的函数\n",
    "def compute_fvd(mu1, sigma1, mu2, sigma2):\n",
    "    diff = mu1 - mu2\n",
    "    covmean, _ = torch.linalg.sqrtm(sigma1 @ sigma2, disp=False)\n",
    "    if not torch.isfinite(covmean).all():\n",
    "        offset = torch.eye(sigma1.size(0)) * 1e-6\n",
    "        covmean = torch.linalg.sqrtm((sigma1 + offset) @ (sigma2 + offset))\n",
    "    fvd = diff @ diff + torch.trace(sigma1 + sigma2 - 2 * covmean)\n",
    "    return fvd.item()\n",
    "\n",
    "def main():\n",
    "    # 读取GIF文件\n",
    "    frames1 = read_gif('/gt/A2C.USm.1.2.840.114089.1.0.1.2887499449.1641693197.4144.17402_1_21.mp4.gif')\n",
    "    frames2 = read_gif('/pred/A2C.USm.1.2.840.114089.1.0.1.2887499449.1641693197.4144.17402_1_21.mp4_pred.gif')\n",
    "\n",
    "    # 定义图像转换\n",
    "    transform = transforms.Compose([\n",
    "        transforms.Resize((224, 224)),\n",
    "        transforms.ToTensor(),\n",
    "        # 根据I3D模型的要求进行归一化\n",
    "        transforms.Normalize(mean=[0.5]*3, std=[0.5]*3)\n",
    "    ])\n",
    "\n",
    "    # 处理帧\n",
    "    video1 = process_frames(frames1, transform)  # Shape: [T, C, H, W]\n",
    "    video2 = process_frames(frames2, transform)\n",
    "\n",
    "    # 调整维度为[C, T, H, W]\n",
    "    video1 = video1.permute(1, 0, 2, 3)  # Shape: [C, T, H, W]\n",
    "    video2 = video2.permute(1, 0, 2, 3)\n",
    "\n",
    "    # 添加批次维度\n",
    "    video1 = video1.unsqueeze(0)  # Shape: [B, C, T, H, W]\n",
    "    video2 = video2.unsqueeze(0)\n",
    "\n",
    "    # 加载I3D模型\n",
    "    import sys\n",
    "    sys.path.append('/pytorch-i3d')\n",
    "    from pytorch_i3d import InceptionI3d  # 请确保已安装pytorch_i3d模块\n",
    "    i3d = InceptionI3d()\n",
    "\n",
    "    # 加载预训练权重（需要提前下载）\n",
    "    # i3d.load_state_dict(torch.load('path_to_i3d_weights.pt'))\n",
    "\n",
    "    i3d.eval()\n",
    "\n",
    "    # 提取特征\n",
    "    with torch.no_grad():\n",
    "        features1 = i3d.extract_features(video1)  # Shape: [B, 1024, T/8, 7, 7]\n",
    "        features2 = i3d.extract_features(video2)\n",
    "\n",
    "    # 展平特征\n",
    "    features1 = features1.view(features1.size(0), -1)\n",
    "    features2 = features2.view(features2.size(0), -1)\n",
    "\n",
    "    # 计算均值和协方差\n",
    "    mu1 = torch.mean(features1, dim=0)\n",
    "    mu2 = torch.mean(features2, dim=0)\n",
    "    sigma1 = torch.from_numpy(np.cov(features1.numpy(), rowvar=False))\n",
    "    sigma2 = torch.from_numpy(np.cov(features2.numpy(), rowvar=False))\n",
    "\n",
    "    # 计算FVD\n",
    "    fvd_value = compute_fvd(mu1, sigma1, mu2, sigma2)\n",
    "    print('两个视频之间的FVD值为:', fvd_value)\n",
    "\n",
    "if __name__ == '__main__':\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: torch in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (1.13.1)\n",
      "Requirement already satisfied: typing-extensions in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from torch) (4.5.0)\n",
      "Requirement already satisfied: nvidia-cuda-runtime-cu11==11.7.99 in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from torch) (11.7.99)\n",
      "Requirement already satisfied: nvidia-cudnn-cu11==8.5.0.96 in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from torch) (8.5.0.96)\n",
      "Requirement already satisfied: nvidia-cublas-cu11==11.10.3.66 in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from torch) (11.10.3.66)\n",
      "Requirement already satisfied: nvidia-cuda-nvrtc-cu11==11.7.99 in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from torch) (11.7.99)\n",
      "Requirement already satisfied: setuptools in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from nvidia-cublas-cu11==11.10.3.66->torch) (72.1.0)\n",
      "Requirement already satisfied: wheel in /home/local/PARTNERS/yl463/anaconda3/envs/VBbench/lib/python3.8/site-packages (from nvidia-cublas-cu11==11.10.3.66->torch) (0.44.0)\n"
     ]
    }
   ],
   "source": [
    "!pip install torch"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "VBbench",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
