{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "acf35278-7609-4171-a2e3-21edd0931a8f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/users/PAS2644/yang7268/Qifan/Wildfire_Detection\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import shutil\n",
    "\n",
    "cwd = os.getcwd()\n",
    "print(cwd)\n",
    "\n",
    "def readlog(training_log_path):\n",
    "    with open(training_log_path, 'r') as file:\n",
    "        lines = file.readlines()\n",
    "    precision = float(lines[-4].split(':')[-1].strip())\n",
    "    recall = float(lines[-3].split(':')[-1].strip())\n",
    "    iou = float(lines[-2].split(':')[-1].strip())\n",
    "    f1 = float(lines[-1].split(':')[-1].strip())\n",
    "    \n",
    "    return precision, recall, iou, f1\n",
    "\n",
    "def pickup_update(v, v_pickup, fire_index, model, model_pickup):\n",
    "    if fire_index:\n",
    "        if v > v_pickup:\n",
    "            update = model\n",
    "            v_pickup = v\n",
    "        else:\n",
    "            update = model_pickup\n",
    "    else:\n",
    "        if v < v_pickup:\n",
    "            update = model\n",
    "            v_pickup = v\n",
    "        else:\n",
    "            update = model_pickup\n",
    "    return v_pickup, update"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2e5a7180-9cd1-43b3-800e-40450eb7cf35",
   "metadata": {},
   "outputs": [],
   "source": [
    "modename = ['all_bands',                        #0\n",
    "            'all_bands_aerosol',                #1\n",
    "            'rgb',                              #2\n",
    "            'rgb_aerosol',                      #3\n",
    "            'swir',                             #4\n",
    "            'swir_aerosol',                     #5\n",
    "            'nbr',                              #6\n",
    "            'nbr_aerosol',                      #7   \n",
    "            'ndvi',                             #8\n",
    "            'ndvi_aerosol',                     #9 \n",
    "            'rgb_swir_nbr_ndvi',                #10\n",
    "            'rgb_swir_nbr_ndvi_aerosol',]       #11\n",
    "\n",
    "mode = 5\n",
    "Exp_folder = os.path.join('./Exp', 'input_' + modename[mode],)\n",
    "Exp_dirs =os.listdir(Exp_folder)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ba17abe7-3e5e-465b-8593-004a0626b13d",
   "metadata": {},
   "outputs": [],
   "source": [
    "precision_txt = open(os.path.join('./Exp_notes', \"Model_pickup_precision.txt\"), \"w\")\n",
    "recall_txt = open(os.path.join('./Exp_notes', \"Model_pickup_recall.txt\"), \"w\")\n",
    "iou_txt = open(os.path.join('./Exp_notes', \"Model_pickup_iou.txt\"), \"w\")\n",
    "f1_txt = open(os.path.join('./Exp_notes', \"Model_pickup_f1.txt\"), \"w\")\n",
    "\n",
    "for model_type in Exp_dirs:\n",
    "    if model_type == '.ipynb_checkpoints':\n",
    "        continue\n",
    "    elif '_LAM' in model_type:\n",
    "        fire_index = True\n",
    "    else:\n",
    "        fire_index = False\n",
    "\n",
    "    model_type_dir = os.path.join(Exp_folder,  model_type)\n",
    "    model_list = os.listdir(model_type_dir)\n",
    "\n",
    " \n",
    "    for model_num_layer in model_list:\n",
    "        model_dir = os.path.join(model_type_dir, model_num_layer)\n",
    "        sub_models = os.listdir(model_dir)\n",
    "        if '.ipynb_checkpoints' in model_dir:\n",
    "            continue\n",
    "        if fire_index:\n",
    "            precision_pickup, recall_pickup, iou_pickup, f1_pickup = 0,0,0,0\n",
    "        else:\n",
    "            precision_pickup, recall_pickup, iou_pickup, f1_pickup = 100,100,100,100\n",
    "\n",
    "        model_pickup_precision, model_pickup_recall, model_pickup_iou, model_pickup_f1 = 'a', 'a', 'a', 'a'\n",
    "        \n",
    "        precision_list = []\n",
    "        recall_list = []\n",
    "        iou_list = []\n",
    "        f1_list = []\n",
    "        \n",
    "        sum_precision, sum_recall, sum_iou, sum_f1 = 0, 0, 0, 0\n",
    "        cnt = 0\n",
    "        for model in sub_models:\n",
    "            if model != '.ipynb_checkpoints':\n",
    "                model_subdir = os.path.join(model_type_dir, model_num_layer, model)\n",
    "                \n",
    "                files = os.listdir(model_subdir)\n",
    "                if not any('test_info.npz' in item for item in files):\n",
    "                    #shutil.rmtree(model_subdir)\n",
    "                    continue\n",
    "                \n",
    "                cnt += 1\n",
    "                training_log_path = os.path.join(model_subdir, 'Training_log.txt')\n",
    "                precision, recall, iou, f1 = readlog(training_log_path)\n",
    "                \n",
    "                precision_list.append(precision)\n",
    "                recall_list.append(recall)\n",
    "                iou_list.append(iou)\n",
    "                f1_list.append(f1)\n",
    "                \n",
    "                sum_precision += precision\n",
    "                sum_recall += recall\n",
    "                sum_iou += iou\n",
    "                sum_f1 += f1\n",
    "                \n",
    "                \n",
    "                precision_pickup, model_pickup_precision = pickup_update(precision, precision_pickup, fire_index, model, model_pickup_precision)\n",
    "                recall_pickup, model_pickup_recall = pickup_update(recall, recall_pickup, fire_index, model, model_pickup_recall)\n",
    "                iou_pickup, model_pickup_iou = pickup_update(iou, iou_pickup, fire_index, model, model_pickup_iou)\n",
    "                f1_pickup, model_pickup_f1 = pickup_update(f1, f1_pickup, fire_index, model, model_pickup_f1)\n",
    "       \n",
    "        precision_txt.write(model_type + '_' + model_num_layer + ':' + model_pickup_precision + ',' + str(precision_pickup)\n",
    "                            + ',' + 'Mean: ' + '%.2f' %(sum_precision/cnt) + ',' + str(precision_list) + '\\n')\n",
    "        recall_txt.write(model_type + '_' + model_num_layer + ':' + model_pickup_recall + ',' + str(recall_pickup)\n",
    "                            + ',' + 'Mean: ' + '%.2f' %(sum_recall/cnt) + ',' + str(recall_list) + '\\n')\n",
    "        iou_txt.write(model_type + '_' + model_num_layer + ':' + model_pickup_iou + ',' + str(iou_pickup)\n",
    "                            + ',' + 'Mean: ' + '%.2f' %(sum_iou/cnt) + ',' + str(iou_list) + '\\n')\n",
    "        f1_txt.write(model_type + '_' + model_num_layer + ':'+ model_pickup_f1 + ',' + str(f1_pickup)\n",
    "                            + ',' + 'Mean: ' + '%.2f' %(sum_f1/cnt) + ',' + str(f1_list) + '\\n')\n",
    "\n",
    "precision_txt.close()\n",
    "recall_txt.close()\n",
    "iou_txt.close()\n",
    "f1_txt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61c3fd53-f473-48ef-b9f8-4983bcd210e4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a0d7164-4e92-4be4-9bad-240fe3059150",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9 (Conda 2022.05) [python/3.9-2022.05]",
   "language": "python",
   "name": "python39_202205"
  },
  "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
