{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as patches\n",
    "from matplotlib.colors import ListedColormap\n",
    "import matplotlib.image as mpimg\n",
    "\n",
    "def rect_to_gaussian_params(rect):\n",
    "    \"\"\"\n",
    "    Convert rectangle to Gaussian parameters.\n",
    "    rect: tuple (x1, y1, x2, y2)\n",
    "    Returns: mean and covariance matrix\n",
    "    \"\"\"\n",
    "    x1, y1, x2, y2 = rect\n",
    "    width = x2 - x1\n",
    "    height = y2 - y1\n",
    "    mean = [(x1 + x2) / 2, (y1 + y2) / 2]\n",
    "    area = width * height\n",
    "    variance = 1 / 5*area  # Inversely proportional to the area\n",
    "    cov = [[7*variance * width**2, 0], [0, 7*variance * height**2]]\n",
    "    return mean, cov\n",
    "\n",
    "# Example rectangle coordinates with values between 0 and 1\n",
    "rectangles = [\n",
    "    (0.1, 0.1, 0.3, 0.4),\n",
    "    (0.5, 0.5, 0.7, 0.8),\n",
    "    (0.2, 0.5, 0.4, 0.6)\n",
    "]\n",
    "\n",
    "# Generate sample data from these rectangles\n",
    "np.random.seed(0)\n",
    "X = np.vstack([\n",
    "    np.clip(np.random.multivariate_normal(*rect_to_gaussian_params(rect),20), 0, 1)\n",
    "    for rect in rectangles\n",
    "])\n",
    "\n",
    "# Fit the Gaussian Mixture Model\n",
    "means = np.array([rect_to_gaussian_params(rect)[0] for rect in rectangles])\n",
    "covariances = np.array([rect_to_gaussian_params(rect)[1] for rect in rectangles])\n",
    "weights = np.array([1.0 / (rect[2] - rect[0]) / (rect[3] - rect[1]) for rect in rectangles])\n",
    "weights /= weights.sum()  # Normalize to sum to 1\n",
    "\n",
    "gmm = GaussianMixture(n_components=len(rectangles), covariance_type='full')\n",
    "gmm.weights_ = weights\n",
    "gmm.means_ = means\n",
    "gmm.covariances_ = covariances\n",
    "gmm.precisions_cholesky_ = np.linalg.cholesky(np.linalg.inv(covariances))\n",
    "\n",
    "# Predict the regions\n",
    "labels = gmm.predict(X)\n",
    "\n",
    "img = mpimg.imread(r'C:\\Users\\dell\\Documents\\space\\lake.png')\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.imshow(img, extent=[0, 1, 0, 1])  # Assuming the image covers the [0, 1] x [0, 1] area\n",
    "cmap = ListedColormap(['r', 'g', 'b'])\n",
    "\n",
    "# Scatter plot of the data points\n",
    "scatter = ax.scatter(X[:, 0], X[:, 1], c=labels, s=40, cmap=cmap, edgecolors='k')\n",
    "\n",
    "# Draw the rectangles\n",
    "for rect in rectangles:\n",
    "    x1, y1, x2, y2 = rect\n",
    "    width = x2 - x1\n",
    "    height = y2 - y1\n",
    "    rect_patch = patches.Rectangle((x1, y1), width, height, linewidth=2, edgecolor='w', facecolor='none')\n",
    "    ax.add_patch(rect_patch)\n",
    "\n",
    "plt.xlim(0, 1)\n",
    "plt.ylim(0, 1)\n",
    "plt.title('Gaussian Mixture Model Clustering with Background Image')\n",
    "plt.xlabel('X-axis')\n",
    "plt.ylabel('Y-axis')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "\n",
    "with open(r'C:\\Users\\dell\\Documents\\space\\pred_process_no_ft.json', 'r') as file:\n",
    "    pred_process = json.load(file)\n",
    "with open(r'C:\\Users\\dell\\Documents\\space\\region_list.json', 'r') as file:\n",
    "    region_list = json.load(file)\n",
    "    \n",
    "for item in pred_process:\n",
    "    [x1,y1,x2,y2] = item['gt_r']\n",
    "    item['gt_r'] = (x1,y1,x2,y2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "null\n",
      "null\n",
      "null\n",
      "null\n",
      "null\n",
      "null\n",
      "[(0.6418652057647705, 0.46151906590172453, 0.7853203773498535, 0.9416204105384662), (0.007582515478134155, 0.6120208919398239, 0.22777259349822998, 0.7805214600087146)]\n"
     ]
    }
   ],
   "source": [
    "proposals_list = []\n",
    "proposals = []\n",
    "for regions in region_list:\n",
    "    # print(item)\n",
    "    if len(regions)==0:\n",
    "        proposals_list.append('null')\n",
    "        print('null')\n",
    "        continue\n",
    "    proposals = []\n",
    "    for item in regions:\n",
    "        [[x1,y1],[x2,y2]] = item\n",
    "        proposal = (x1,y1,x2,y2)\n",
    "        proposals.append(proposal)\n",
    "    proposals_list.append(proposals)\n",
    "\n",
    "print(proposals_list[0])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_iou(rect1, rect2):\n",
    "    # rect1 and rect2 are tuples in the form (x1, y1, x2, y2)\n",
    "\n",
    "    # Calculate intersection coordinates\n",
    "    intersection_x1 = max(rect1[0], rect2[0])\n",
    "    intersection_y1 = max(rect1[1], rect2[1])\n",
    "    intersection_x2 = min(rect1[2], rect2[2])\n",
    "    intersection_y2 = min(rect1[3], rect2[3])\n",
    "\n",
    "    # Check if intersection exists\n",
    "    if intersection_x1 > intersection_x2 or intersection_y1 > intersection_y2:\n",
    "        return 0.0\n",
    "\n",
    "    # Calculate intersection area\n",
    "    intersection_area = max(0, intersection_x2 - intersection_x1) * max(0, intersection_y2 - intersection_y1)\n",
    "\n",
    "    # Calculate union area\n",
    "    area_rect1 = (rect1[2] - rect1[0]) * (rect1[3] - rect1[1])\n",
    "    area_rect2 = (rect2[2] - rect2[0]) * (rect2[3] - rect2[1])\n",
    "    union_area = area_rect1 + area_rect2 - intersection_area\n",
    "\n",
    "    # Calculate IOU\n",
    "    iou = intersection_area / union_area\n",
    "\n",
    "    return iou"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "def rect_to_gaussian_params(rect):\n",
    "    \"\"\"\n",
    "    Convert rectangle to Gaussian parameters.\n",
    "    rect: tuple (x1, y1, x2, y2)\n",
    "    Returns: mean and covariance matrix\n",
    "    \"\"\"\n",
    "    x1, y1, x2, y2 = rect\n",
    "    width = x2 - x1\n",
    "    height = y2 - y1\n",
    "    mean = [(x1 + x2) / 2, (y1 + y2) / 2]\n",
    "    area = width * height\n",
    "    variance = 1 / 10*area  # Inversely proportional to the area\n",
    "    cov = [[10*variance * width**2, 0], [0,10*variance * height**2]]\n",
    "    return mean, cov"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "match: 0.8889538281706605\n",
      "null pred:  128\n",
      "null proposal 6\n"
     ]
    }
   ],
   "source": [
    "count = 0\n",
    "null_pred_count = 0\n",
    "null_prop_count = 0\n",
    "for index in range(3422):\n",
    "    if proposals_list[index]=='null':\n",
    "        # print('null_proposal')\n",
    "        null_prop_count +=1\n",
    "        continue\n",
    "    rectangles = proposals_list[index]\n",
    "\n",
    "    # Generate sample data from these rectangles\n",
    "    np.random.seed(0)\n",
    "    if len(pred_process[index]['pred_points'])==0:\n",
    "        # print('null_pred')\n",
    "        null_pred_count +=1\n",
    "        continue\n",
    "    X = np.vstack(pred_process[index]['pred_points'])\n",
    "\n",
    "    gt = pred_process[index]['gt_r']\n",
    "\n",
    "\n",
    "    # Fit the Gaussian Mixture Model\n",
    "    means = np.array([rect_to_gaussian_params(rect)[0] for rect in rectangles])\n",
    "    covariances = np.array([rect_to_gaussian_params(rect)[1] for rect in rectangles])\n",
    "    weights = np.array([1.0 / (rect[2] - rect[0]) / (rect[3] - rect[1]) for rect in rectangles])\n",
    "    weights /= weights.sum()  # Normalize to sum to 1\n",
    "\n",
    "    gmm = GaussianMixture(n_components=len(rectangles), covariance_type='full')\n",
    "    gmm.weights_ = weights\n",
    "    gmm.means_ = means\n",
    "    gmm.covariances_ = covariances\n",
    "    gmm.precisions_cholesky_ = np.linalg.cholesky(np.linalg.inv(covariances))\n",
    "\n",
    "    # Predict the regions\n",
    "    labels = gmm.predict(X)\n",
    "\n",
    "    prediction = np.argmax(np.bincount(labels))\n",
    "\n",
    "    iou = calculate_iou(rectangles[prediction],gt)\n",
    "    if iou>0.5:\n",
    "        count +=1\n",
    "\n",
    "print('match:',count/3422)\n",
    "print('null pred: ', null_pred_count)\n",
    "print('null proposal',null_prop_count)\n",
    "\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
