{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.patches import Rectangle\n",
    "from PIL import Image as PIL_Image\n",
    "from joblib import Parallel, delayed\n",
    "import glob\n",
    "\n",
    "def load_image_from_path(image_path):\n",
    "    try:\n",
    "        img = PIL_Image.open(image_path)\n",
    "        return img\n",
    "    except IOError as e:\n",
    "        print(f\"Error opening image from {image_path}: {e}\")\n",
    "        return None\n",
    "\n",
    "def visualize_objects(image_info, image_path, output_path):\n",
    "    img = load_image_from_path(image_path)\n",
    "\n",
    "    if img is None:\n",
    "        return\n",
    "\n",
    "    plt.figure(frameon=False)\n",
    "    plt.imshow(img)\n",
    "    ax = plt.gca()\n",
    "\n",
    "    for obj in image_info['objects']:\n",
    "        bndbox = obj['bndbox']\n",
    "        xmin = int(bndbox['xmin'])\n",
    "        ymin = int(bndbox['ymin'])\n",
    "        width = int(bndbox['xmax']) - xmin\n",
    "        height = int(bndbox['ymax']) - ymin\n",
    "        ax.add_patch(Rectangle((xmin, ymin), width, height, fill=False, edgecolor='red', linewidth=2))\n",
    "        bbox_number = obj.get('bbox_number', 'N/A') \n",
    "        ax.text(xmin, ymin-10, f'Obj.{bbox_number}', style='italic', color='white', fontsize=12,\n",
    "                bbox={'facecolor': 'black', 'alpha': 0.75, 'pad': 3})\n",
    "        # ax.text(xmin, ymin, f'Obj.{bbox_number}', style='italic', bbox={'facecolor': 'white', 'alpha': 0.5, 'pad': 3})\n",
    "\n",
    "    plt.axis('off')\n",
    "    plt.gca().set_axis_off()\n",
    "    plt.subplots_adjust(left=0, right=1, top=1, bottom=0, wspace=0, hspace=0)\n",
    "    plt.margins(0, 0)\n",
    "    plt.gca().xaxis.set_major_locator(plt.NullLocator())\n",
    "    plt.gca().yaxis.set_major_locator(plt.NullLocator())\n",
    "\n",
    "    plt.savefig(output_path, bbox_inches='tight', pad_inches=0)\n",
    "    plt.close()\n",
    "\n",
    "def process_json_file(json_file, output_folder, base_image_folder):\n",
    "    filename = os.path.basename(json_file)\n",
    "    output_path = os.path.join(output_folder, os.path.splitext(filename)[0] + '.png')\n",
    "\n",
    "    try:\n",
    "        with open(json_file, 'r') as file:\n",
    "            image_info = json.load(file)\n",
    "        json_image_folder = image_info.get('folder', '')\n",
    "\n",
    "        image_filename = image_info['filename']\n",
    "        image_path = os.path.join(base_image_folder, json_image_folder, image_filename)\n",
    "\n",
    "        visualize_objects(image_info, image_path, output_path)\n",
    "    except Exception as e:\n",
    "        print(f\"Error processing file {json_file}: {e}\")\n",
    "\n",
    "def process_images_parallel(json_folder, output_folder, base_image_folder):\n",
    "    if not os.path.exists(output_folder):\n",
    "        os.makedirs(output_folder)\n",
    "\n",
    "    json_files = glob.glob(os.path.join(json_folder, '*.json'))\n",
    "    Parallel(n_jobs=-1)(delayed(process_json_file)(json_file, output_folder, base_image_folder) for json_file in json_files)\n",
    "\n",
    "json_folder = '1000_0.01_5_new' \n",
    "output_folder = '' \n",
    "base_image_folder = 'images/train2017/'\n",
    "\n",
    "process_images_parallel(json_folder, output_folder, base_image_folder)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mRunning cells with 'Python 3.9.2' requires the ipykernel package.\n",
      "\u001b[1;31mRun the following command to install 'ipykernel' into the Python environment. \n",
      "\u001b[1;31mCommand: '\"c:/Program Files/Python39/python.exe\" -m pip install ipykernel -U --user --force-reinstall'"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.patches import Rectangle\n",
    "from PIL import Image as PIL_Image\n",
    "\n",
    "def load_image_from_path(image_path):\n",
    "    try:\n",
    "        img = PIL_Image.open(image_path)\n",
    "        return img\n",
    "    except IOError as e:\n",
    "        print(f\"Error opening image from {image_path}: {e}\")\n",
    "        return None\n",
    "def visualize_objects(image_info, image_path, output_path):\n",
    "    img = load_image_from_path(image_path)\n",
    "\n",
    "    if img is None:\n",
    "        return\n",
    "\n",
    "    plt.figure(frameon=False)\n",
    "    plt.imshow(img)\n",
    "    ax = plt.gca()\n",
    "\n",
    "    colors = ['red', 'green', 'blue', 'yellow', 'purple']\n",
    "\n",
    "    for idx, obj in enumerate(image_info['objects']):\n",
    "        bndbox = obj['bndbox']\n",
    "        xmin = int(bndbox['xmin'])\n",
    "        ymin = int(bndbox['ymin'])\n",
    "        width = int(bndbox['xmax']) - xmin\n",
    "        height = int(bndbox['ymax']) - ymin\n",
    "        color = colors[idx % len(colors)] \n",
    "        ax.add_patch(Rectangle((xmin, ymin), width, height, fill=False, edgecolor=color, linewidth=2))\n",
    "\n",
    "    plt.axis('off')\n",
    "    plt.gca().set_axis_off()\n",
    "    plt.subplots_adjust(left=0, right=1, top=1, bottom=0, wspace=0, hspace=0)\n",
    "    plt.margins(0, 0)\n",
    "    plt.gca().xaxis.set_major_locator(plt.NullLocator())\n",
    "    plt.gca().yaxis.set_major_locator(plt.NullLocator())\n",
    "\n",
    "    plt.savefig(output_path, bbox_inches='tight', pad_inches=0)\n",
    "    plt.close()\n",
    "\n",
    "def process_json_file(json_file, output_folder, base_image_folder):\n",
    "    filename = os.path.basename(json_file)\n",
    "    output_path = os.path.join(output_folder, os.path.splitext(filename)[0] + '.png')\n",
    "\n",
    "    try:\n",
    "        with open(json_file, 'r') as file:\n",
    "            image_info = json.load(file)\n",
    "\n",
    "        json_image_folder = image_info.get('folder', '')\n",
    "\n",
    "        image_filename = image_info['filename']\n",
    "        image_path = os.path.join(base_image_folder, json_image_folder, image_filename)\n",
    "\n",
    "        visualize_objects(image_info, image_path, output_path)\n",
    "    except Exception as e:\n",
    "        print(f\"Error processing file {json_file}: {e}\")\n",
    "\n",
    "json_folder = '1000_0.01_5'  \n",
    "output_folder = 'test_image' \n",
    "base_image_folder = 'images/train2017/' \n",
    "\n",
    "json_file = os.path.join(json_folder, '000000561454.json')  \n",
    "\n",
    "process_json_file(json_file, output_folder, base_image_folder)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.patches import Rectangle\n",
    "from PIL import Image as PIL_Image\n",
    "from joblib import Parallel, delayed\n",
    "import glob\n",
    "\n",
    "def load_image_from_path(image_path):\n",
    "    try:\n",
    "        img = PIL_Image.open(image_path)\n",
    "        return img\n",
    "    except IOError as e:\n",
    "        print(f\"Error opening image from {image_path}: {e}\")\n",
    "        return None\n",
    "def visualize_objects(image_info, image_path, output_path):\n",
    "    img = load_image_from_path(image_path)\n",
    "\n",
    "    if img is None:\n",
    "        return\n",
    "\n",
    "    plt.figure(frameon=False)\n",
    "    plt.imshow(img)\n",
    "    ax = plt.gca()\n",
    "\n",
    "    for obj in image_info['objects']:\n",
    "        bndbox = obj['bndbox']\n",
    "        xmin = int(bndbox['xmin'])\n",
    "        ymin = int(bndbox['ymin'])\n",
    "        width = int(bndbox['xmax']) - xmin\n",
    "        height = int(bndbox['ymax']) - ymin\n",
    "        bbox_color = [color / 255.0 for color in obj['bbox_color']]\n",
    "        ax.add_patch(Rectangle((xmin, ymin), width, height, fill=False, edgecolor=bbox_color, linewidth=2))\n",
    "\n",
    "    plt.axis('off')\n",
    "    plt.gca().set_axis_off()\n",
    "    plt.subplots_adjust(left=0, right=1, top=1, bottom=0, wspace=0, hspace=0)\n",
    "    plt.margins(0, 0)\n",
    "    plt.gca().xaxis.set_major_locator(plt.NullLocator())\n",
    "    plt.gca().yaxis.set_major_locator(plt.NullLocator())\n",
    "\n",
    "    plt.savefig(output_path, bbox_inches='tight', pad_inches=0)\n",
    "    plt.close()\n",
    "\n",
    "def process_json_file(json_file, output_folder, base_image_folder):\n",
    "    filename = os.path.basename(json_file)\n",
    "    output_path = os.path.join(output_folder, os.path.splitext(filename)[0] + '.png')\n",
    "\n",
    "    try:\n",
    "        with open(json_file, 'r') as file:\n",
    "            image_info = json.load(file)\n",
    "\n",
    "        json_image_folder = image_info.get('folder', '')\n",
    "        image_filename = image_info['filename']\n",
    "        image_path = os.path.join(base_image_folder, json_image_folder, image_filename)\n",
    "\n",
    "        visualize_objects(image_info, image_path, output_path)\n",
    "    except Exception as e:\n",
    "        print(f\"Error processing file {json_file}: {e}\")\n",
    "\n",
    "def process_images_parallel(json_folder, output_folder, base_image_folder):\n",
    "    if not os.path.exists(output_folder):\n",
    "        os.makedirs(output_folder)\n",
    "\n",
    "    json_files = glob.glob(os.path.join(json_folder, '*.json'))\n",
    "    Parallel(n_jobs=-1)(delayed(process_json_file)(json_file, output_folder, base_image_folder) for json_file in json_files)\n",
    "\n",
    "json_folder = '1000_0.01_5_color' \n",
    "output_folder = '1000_0.01_5_visualized_color'\n",
    "base_image_folder = 'images/train2017/' \n",
    "\n",
    "process_images_parallel(json_folder, output_folder, base_image_folder)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "detectai",
   "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.9.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
