{
 "metadata": {
  "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.7.0-final"
  },
  "orig_nbformat": 2,
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3",
   "language": "python"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2,
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import gc\n",
    "import datetime\n",
    "import sys\n",
    "import time\n",
    "from pathlib import Path            \n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from sklearn.metrics import confusion_matrix, ConfusionMatrixDisplay\n",
    "import matplotlib.pyplot as plt\n",
    "import cv2\n",
    "sys.path.append('../src')\n",
    "import models\n",
    "from utils import load_model, handle_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "field_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-18.npz\"\n",
    "dl = np.load(field_fn)\n",
    "data = dl[\"arr_0\"].squeeze()\n",
    "dl.close()\n",
    "\n",
    "x = data[0:3, :, :] / 255\n",
    "plt.imshow(x.transpose(1,2,0))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "forest_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-50.npz\"\n",
    "dl = np.load(forest_fn)\n",
    "data = dl[\"arr_0\"].squeeze()\n",
    "dl.close()\n",
    "\n",
    "x = data[0:3, :, :] / 255\n",
    "plt.imshow(x.transpose(1,2,0))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "water_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-293.npz\"\n",
    "dl = np.load(water_fn)\n",
    "data = dl[\"arr_0\"].squeeze()\n",
    "dl.close()\n",
    "\n",
    "x = data[0:3, :, :] / 255\n",
    "plt.imshow(x.transpose(1,2,0))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "others_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-test_patches/de_1m_2013-m_3807529_nw_18_1-131.npz\"\n",
    "dl = np.load(others_fn)\n",
    "data = dl[\"arr_0\"].squeeze()\n",
    "dl.close()\n",
    "\n",
    "x = data[0:3, :, :] / 255\n",
    "plt.imshow(x.transpose(1,2,0))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "water_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-293.npz\"\n",
    "forest_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-50.npz\"\n",
    "field_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-val_patches/de_1m_2013-m_3807514_nw_18_1-18.npz\"\n",
    "others_fn = \"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-test_patches/de_1m_2013-m_3807529_nw_18_1-131.npz\"\n",
    "\n",
    "fns = [water_fn, forest_fn, field_fn, others_fn]\n",
    "anchors = np.zeros((5,4,240,240))\n",
    "for i in range(4):\n",
    "    dl = np.load(fns[i])\n",
    "    data = dl[\"arr_0\"].squeeze()\n",
    "    dl.close()\n",
    "    x = data[:4, :240, :240] / 255\n",
    "    anchors[i+1, :, :, :] = x\n",
    "np.save(\"/scratch/forest/attention-conv/data/anchors.npy\", anchors)\n",
    "a = np.load(\"/scratch/forest/attention-conv/data/anchors.npy\")\n",
    "a = torch.tensor(a)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for i in range(0,500):\n",
    "#     fn = f\"/scratch/forest/datasets/chesapeake_data/de_1m_2013_extended-test_patches/de_1m_2013-m_3807529_nw_18_1-{i}.npz\"\n",
    "#     dl = np.load(fn)\n",
    "#     data = dl[\"arr_0\"].squeeze()\n",
    "#     dl.close()\n",
    "#     label = handle_labels(data[8, :, :], \"/scratch/forest/attention-conv/data/cheaseapeake_to_hr_labels.txt\")\n",
    "#     label_cnt = (label == 4).sum()\n",
    "#     if label_cnt / 256**2 > 0.7:\n",
    "#         print(fn)\n",
    "#         break\n",
    "\n",
    "\n",
    "# x = data[0:3, :, :] / 255\n",
    "# plt.imshow(x.transpose(1,2,0))\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ]
}