{
  "cells": [
    {
      "cell_type": "markdown",
      "id": "ebe9b7a2",
      "metadata": {},
      "source": [
        "# Imports"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 1,
      "id": "12f47ee1",
      "metadata": {},
      "outputs": [],
      "source": [
        "import os\n",
        "import os, sys\n",
        "sys.path.insert(0, \"..\") \n",
        "from dataloaders.SIXray.sixray_loader import SIXRAY\n",
        "import numpy as np\n",
        "import tensorflow as tf\n",
        "import pandas as pd\n",
        "\n",
        "from sklearn.utils import shuffle"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "id": "018d067d",
      "metadata": {},
      "outputs": [],
      "source": [
        "SEED = 42"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "3672c6a5",
      "metadata": {},
      "source": [
        "## Define paths"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "id": "31ae1722",
      "metadata": {},
      "outputs": [],
      "source": [
        "train_csv_path = r\"E:\\SIXRay\\ImageSet\\10\\train.csv\"\n",
        "test_csv_path = r\"E:\\SIXRay\\ImageSet\\10\\test.csv\""
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "id": "5a0ad710",
      "metadata": {},
      "outputs": [],
      "source": [
        "input_shape = (256,256)\n",
        "batch_size = 32"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "051fc9e8",
      "metadata": {},
      "source": [
        "## Datagens"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "id": "bb4d60ea",
      "metadata": {},
      "outputs": [],
      "source": [
        "train_gen = SIXRAY(batch_size,input_shape,train_csv_path, r\"E:\\SIXRay\\ALLIMGS\", balance=False)\n",
        "test_gen = SIXRAY(batch_size,input_shape,test_csv_path, r\"E:\\SIXRay\\ALLIMGS\",balance=False)"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "a7fc562c",
      "metadata": {},
      "source": [
        "## Convert datagens to tf.Data"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "id": "e61cd6c3",
      "metadata": {},
      "outputs": [],
      "source": [
        "from dataloaders.datasetFromSequence import DatasetFromSequenceClass "
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "id": "9717f702",
      "metadata": {},
      "outputs": [],
      "source": [
        "dims = list(input_shape) +[3]\n",
        "n_classes = 5"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "id": "f62bf8dd",
      "metadata": {},
      "outputs": [],
      "source": [
        "training = DatasetFromSequenceClass(train_gen, len(train_gen), 1,batch_size, dims=dims, out_dims=[n_classes])\n",
        "testing = DatasetFromSequenceClass(test_gen, len(test_gen), 1,batch_size, dims=dims, out_dims=[n_classes])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "id": "e8a06e3a",
      "metadata": {},
      "outputs": [],
      "source": [
        "image_normalization_mean = [0.485, 0.456, 0.406]\n",
        "image_normalization_std = [0.229, 0.224, 0.225]\n",
        "num_classes = 5\n",
        "def normalize_sixray(input_image, label):\n",
        "    input_image = tf.cast(input_image, tf.float32) / 255.0\n",
        "    input_image -= image_normalization_mean\n",
        "    input_image /= image_normalization_std\n",
        "    return input_image, label"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "id": "f242d07c",
      "metadata": {},
      "outputs": [],
      "source": [
        "from classification_models.tfkeras import Classifiers\n",
        "from tensorflow.keras import activations\n",
        "from tensorflow.keras import utils\n",
        "from tensorflow.keras.losses import BinaryCrossentropy\n",
        "from tensorflow.keras.layers import GlobalAveragePooling2D, Dense\n",
        "from tensorflow.keras.models import Model"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 12,
      "id": "6ee6a26e",
      "metadata": {},
      "outputs": [],
      "source": [
        "ResNet34, preprocess_input = Classifiers.get('resnet34')\n",
        "model = ResNet34(input_shape+(3,), classes=num_classes,weights='imagenet',include_top=False)\n",
        "gap_layer = GlobalAveragePooling2D()(model.output)\n",
        "out = Dense(num_classes,activation='sigmoid')(gap_layer)\n",
        "model = Model(model.input,out)\n",
        "# idx_of_layer_to_change = -1\n",
        "# model.layers[idx_of_layer_to_change].activation = activations.sigmoid\n",
        "# model.layers[idx_of_layer_to_change]._name = 'Sigmoid'"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 13,
      "id": "e957933d",
      "metadata": {},
      "outputs": [],
      "source": [
        "id_to_name={\n",
        "    0:'Gun',\n",
        "    1:'Knife',\n",
        "    2:'Wrench',\n",
        "    3:'Pliers',\n",
        "    4:'Scissors'\n",
        "}\n",
        "\n",
        "class_weights = dict()\n",
        "all_threats = sum([train_gen.df[id_to_name[k]].sum() for k in id_to_name])\n",
        "all_negative = (len(train_gen.df)*5)-all_threats\n",
        "initial_bias = np.array([])\n",
        "for k in id_to_name:\n",
        "    class_positive = (train_gen.df[id_to_name[k]].sum()/all_threats)\n",
        "    class_weights[k] = 1 - class_positive\n",
        "    initial_bias = np.append(initial_bias, (np.log([class_positive/all_negative])))\n",
        "class_weights\n",
        "\n",
        "\n",
        "\n",
        "output_bias = initial_bias\n",
        "model.set_weights(model.get_weights()[:-1] + [output_bias])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 14,
      "id": "010c2d65",
      "metadata": {},
      "outputs": [],
      "source": [
        "from tensorflow.keras.callbacks import ReduceLROnPlateau        \n",
        "reduce_lr = ReduceLROnPlateau(monitor='loss', factor=0.8,\n",
        "                              patience=2, min_lr=1e-7, min_delta=0.01, verbose=1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 91,
      "id": "98384d07",
      "metadata": {},
      "outputs": [],
      "source": [
        "from auxiliary.lr_finder import LRFinder"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 92,
      "id": "e385bb26",
      "metadata": {},
      "outputs": [],
      "source": [
        "lr_finder = LRFinder(min_lr=1e-5, max_lr=1e-1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 17,
      "id": "0e7a0d13",
      "metadata": {},
      "outputs": [],
      "source": [
        "from tensorflow.keras.optimizers import Adam\n",
        "import tensorflow_addons as tfa"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "3db238a5",
      "metadata": {},
      "outputs": [],
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": 94,
      "id": "a5920a96",
      "metadata": {},
      "outputs": [],
      "source": [
        "def loss_fn(y_true, y_pred):\n",
        "    return tfa.losses.sigmoid_focal_crossentropy(\n",
        "        y_true = y_true,\n",
        "        y_pred = y_pred,\n",
        "        from_logits= True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 18,
      "id": "ec21ed8e",
      "metadata": {},
      "outputs": [],
      "source": [
        "# opt = Adam(learning_rate=0.005)\n",
        "# from tensorflow.keras import backend as K\n",
        "# K.set_value(model.optimizer.learning_rate, 0.01)\n",
        "opt = tfa.optimizers.SGDW(learning_rate=0.01,momentum=0.9,weight_decay=1e-4)\n",
        "loss = BinaryCrossentropy(from_logits=True)\n",
        "# loss = loss_fn"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 96,
      "id": "18db04ee",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "name        N0660838N0609859N0287626N0235601N0807774N03021...\n",
              "Gun                                                      2705\n",
              "Knife                                                    1748\n",
              "Wrench                                                   2012\n",
              "Pliers                                                   3434\n",
              "Scissors                                                  807\n",
              "dtype: object"
            ]
          },
          "execution_count": 96,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "train_gen.df.sum()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 19,
      "id": "3802c4b2",
      "metadata": {},
      "outputs": [],
      "source": [
        "training = DatasetFromSequenceClass(train_gen, len(train_gen), 1,batch_size, dims=dims, out_dims=[n_classes])\n",
        "testing = DatasetFromSequenceClass(test_gen, len(test_gen), 1,batch_size, dims=dims, out_dims=[n_classes])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 20,
      "id": "a8e45434",
      "metadata": {},
      "outputs": [],
      "source": [
        "training = training.shuffle(buffer_size=200,seed=SEED).prefetch(buffer_size=tf.data.AUTOTUNE).cache().map(normalize_sixray)\n",
        "testing = testing.prefetch(buffer_size=tf.data.AUTOTUNE).cache().map(normalize_sixray)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "88eaff70",
      "metadata": {},
      "outputs": [],
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "ce597bb0",
      "metadata": {},
      "outputs": [],
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": 21,
      "id": "8e9a9f7c",
      "metadata": {},
      "outputs": [],
      "source": [
        "model.compile(loss=loss,optimizer=opt, metrics = [tf.keras.metrics.Precision(class_id=idx, name='precision_{}'.format(id_to_name[idx])) for idx in range(n_classes)])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 36,
      "id": "c1c35c3c",
      "metadata": {},
      "outputs": [
        {
          "ename": "SyntaxError",
          "evalue": "invalid syntax (<ipython-input-36-a19375d90403>, line 1)",
          "output_type": "error",
          "traceback": [
            "\u001b[1;36m  File \u001b[1;32m\"<ipython-input-36-a19375d90403>\"\u001b[1;36m, line \u001b[1;32m1\u001b[0m\n\u001b[1;33m    model.fit(training,epochs=1, callbacks=[lr_finder], class_weghts={0:})\u001b[0m\n\u001b[1;37m                                                                        ^\u001b[0m\n\u001b[1;31mSyntaxError\u001b[0m\u001b[1;31m:\u001b[0m invalid syntax\n"
          ]
        }
      ],
      "source": [
        "model.fit(training,epochs=1, callbacks=[lr_finder], class_weghts={0:})"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 85,
      "id": "968b8113",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Epoch 1/5\n",
            "2342/2342 [==============================] - 252s 102ms/step - loss: 0.0707 - precision_Gun: 0.7579 - precision_Knife: 0.6920 - precision_Wrench: 0.4869 - precision_Pliers: 0.6123 - precision_Scissors: 0.1264\n",
            "Epoch 2/5\n",
            "2342/2342 [==============================] - 232s 99ms/step - loss: 0.0309 - precision_Gun: 0.9573 - precision_Knife: 0.9440 - precision_Wrench: 0.7817 - precision_Pliers: 0.8145 - precision_Scissors: 0.8514\n",
            "Epoch 3/5\n",
            "2342/2342 [==============================] - 231s 99ms/step - loss: 0.0211 - precision_Gun: 0.9776 - precision_Knife: 0.9696 - precision_Wrench: 0.8593 - precision_Pliers: 0.8714 - precision_Scissors: 0.9352 13s - loss: 0.0211 - precision_Gun:  - ETA: 5s - loss: 0.0211 - precision_\n",
            "Epoch 4/5\n",
            "2342/2342 [==============================] - 233s 99ms/step - loss: 0.0218 - precision_Gun: 0.9725 - precision_Knife: 0.9560 - precision_Wrench: 0.8490 - precision_Pliers: 0.8637 - precision_Scissors: 0.8903\n",
            "\n",
            "Epoch 00004: ReduceLROnPlateau reducing learning rate to 0.007999999821186066.\n",
            "Epoch 5/5\n",
            "2342/2342 [==============================] - 232s 99ms/step - loss: 0.0179 - precision_Gun: 0.9760 - precision_Knife: 0.9687 - precision_Wrench: 0.8775 - precision_Pliers: 0.9005 - precision_Scissors: 0.9298\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.callbacks.History at 0x17b4ea4afd0>"
            ]
          },
          "execution_count": 85,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "#No CW No output bias\n",
        "model.fit(training,steps_per_epoch=len(train_gen),epochs=5, callbacks=[reduce_lr])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 86,
      "id": "77107974",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 32s 70ms/step - loss: 0.0476 - precision_Gun: 0.9192 - precision_Knife: 0.6987 - precision_Wrench: 0.4485 - precision_Pliers: 0.6915 - precision_Scissors: 0.6333\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.04758431017398834,\n",
              " 0.9191918969154358,\n",
              " 0.6987447738647461,\n",
              " 0.4484536051750183,\n",
              " 0.6915422677993774,\n",
              " 0.6333333253860474]"
            ]
          },
          "execution_count": 86,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 100,
      "id": "7470513a",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Epoch 1/5\n",
            "2342/2342 [==============================] - 246s 101ms/step - loss: 0.0871 - precision_Gun: 0.8701 - precision_Knife: 0.7390 - precision_Wrench: 0.5788 - precision_Pliers: 0.6080 - precision_Scissors: 0.4834 - loss: 0.0871 - precision_Gun: 0.8700 - precision_Knife: 0.7389 - precision_Wrench: 0.5787 - precision_Pliers: 0.6079 - precision_Scissors: 0.\n",
            "Epoch 2/5\n",
            "2342/2342 [==============================] - 233s 100ms/step - loss: 0.0316 - precision_Gun: 0.9612 - precision_Knife: 0.9405 - precision_Wrench: 0.7856 - precision_Pliers: 0.8103 - precision_Scissors: 0.817329s - loss: 0.0321 - precision_Gun: 0.9600 - precision_Knife: 0.9384 - prec\n",
            "Epoch 3/5\n",
            "2342/2342 [==============================] - 232s 99ms/step - loss: 0.0217 - precision_Gun: 0.9747 - precision_Knife: 0.9724 - precision_Wrench: 0.8531 - precision_Pliers: 0.8748 - precision_Scissors: 0.9149\n",
            "Epoch 4/5\n",
            "2342/2342 [==============================] - 230s 98ms/step - loss: 0.0213 - precision_Gun: 0.9728 - precision_Knife: 0.9706 - precision_Wrench: 0.8723 - precision_Pliers: 0.8809 - precision_Scissors: 0.8654s - loss: 0.0213 - precision_Gun: 0.9727 - precision_Knife: 0.9\n",
            "\n",
            "Epoch 00004: ReduceLROnPlateau reducing learning rate to 0.007999999821186066.\n",
            "Epoch 5/5\n",
            "2342/2342 [==============================] - 231s 99ms/step - loss: 0.0184 - precision_Gun: 0.9775 - precision_Knife: 0.9695 - precision_Wrench: 0.9160 - precision_Pliers: 0.9138 - precision_Scissors: 0.9069\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.callbacks.History at 0x18130669f40>"
            ]
          },
          "execution_count": 100,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "#No CW Yes output bias\n",
        "model.fit(training,steps_per_epoch=len(train_gen),epochs=5, callbacks=[reduce_lr])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 101,
      "id": "e82217e7",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 26s 58ms/step - loss: 0.0499 - precision_Gun: 0.9520 - precision_Knife: 0.9146 - precision_Wrench: 0.7400 - precision_Pliers: 0.6084 - precision_Scissors: 0.4197\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.04994448274374008,\n",
              " 0.9519519805908203,\n",
              " 0.9146341681480408,\n",
              " 0.7400000095367432,\n",
              " 0.6084142327308655,\n",
              " 0.4196891188621521]"
            ]
          },
          "execution_count": 101,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 22,
      "id": "fd0235e3",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Epoch 1/5\n",
            "2342/2342 [==============================] - 264s 105ms/step - loss: 0.0725 - precision_Gun: 0.8456 - precision_Knife: 0.7516 - precision_Wrench: 0.5532 - precision_Pliers: 0.6049 - precision_Scissors: 0.4463\n",
            "Epoch 2/5\n",
            "2342/2342 [==============================] - 238s 102ms/step - loss: 0.0236 - precision_Gun: 0.9629 - precision_Knife: 0.9397 - precision_Wrench: 0.7809 - precision_Pliers: 0.8206 - precision_Scissors: 0.8665\n",
            "Epoch 3/5\n",
            "2342/2342 [==============================] - 237s 101ms/step - loss: 0.0152 - precision_Gun: 0.9785 - precision_Knife: 0.9771 - precision_Wrench: 0.8597 - precision_Pliers: 0.8971 - precision_Scissors: 0.9233\n",
            "Epoch 4/5\n",
            "2342/2342 [==============================] - 239s 102ms/step - loss: 0.0164 - precision_Gun: 0.9759 - precision_Knife: 0.9575 - precision_Wrench: 0.8791 - precision_Pliers: 0.8856 - precision_Scissors: 0.8985\n",
            "\n",
            "Epoch 00004: ReduceLROnPlateau reducing learning rate to 0.007999999821186066.\n",
            "Epoch 5/5\n",
            "2342/2342 [==============================] - 239s 102ms/step - loss: 0.0139 - precision_Gun: 0.9787 - precision_Knife: 0.9730 - precision_Wrench: 0.9063 - precision_Pliers: 0.9192 - precision_Scissors: 0.9362\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.callbacks.History at 0x12046050cd0>"
            ]
          },
          "execution_count": 22,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "#CW + Output bias\n",
        "model.fit(training,steps_per_epoch=len(train_gen),epochs=5, callbacks=[reduce_lr], class_weight=class_weights)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 23,
      "id": "d2b7af9f",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 30s 67ms/step - loss: 0.0515 - precision_Gun: 0.9611 - precision_Knife: 0.9490 - precision_Wrench: 0.6294 - precision_Pliers: 0.5489 - precision_Scissors: 0.4840\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.0514560267329216,\n",
              " 0.961077868938446,\n",
              " 0.9490445852279663,\n",
              " 0.6293706297874451,\n",
              " 0.5489051342010498,\n",
              " 0.48404255509376526]"
            ]
          },
          "execution_count": 23,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 67,
      "id": "a3da180d",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Epoch 1/5\n",
            "2342/2342 [==============================] - 245s 100ms/step - loss: 0.0695 - precision_Gun: 0.8565 - precision_Knife: 0.7529 - precision_Wrench: 0.5724 - precision_Pliers: 0.6102 - precision_Scissors: 0.5391\n",
            "Epoch 2/5\n",
            "2342/2342 [==============================] - 233s 99ms/step - loss: 0.0243 - precision_Gun: 0.9630 - precision_Knife: 0.9426 - precision_Wrench: 0.7681 - precision_Pliers: 0.8246 - precision_Scissors: 0.8091\n",
            "Epoch 3/5\n",
            "2342/2342 [==============================] - 233s 100ms/step - loss: 0.0155 - precision_Gun: 0.9833 - precision_Knife: 0.9791 - precision_Wrench: 0.8495 - precision_Pliers: 0.8941 - precision_Scissors: 0.9101\n",
            "Epoch 4/5\n",
            "2342/2342 [==============================] - 232s 99ms/step - loss: 0.0167 - precision_Gun: 0.9737 - precision_Knife: 0.9661 - precision_Wrench: 0.8758 - precision_Pliers: 0.8881 - precision_Scissors: 0.8516\n",
            "\n",
            "Epoch 00004: ReduceLROnPlateau reducing learning rate to 0.007999999821186066.\n",
            "Epoch 5/5\n",
            "2342/2342 [==============================] - 232s 99ms/step - loss: 0.0139 - precision_Gun: 0.9783 - precision_Knife: 0.9741 - precision_Wrench: 0.9109 - precision_Pliers: 0.9254 - precision_Scissors: 0.9354\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.callbacks.History at 0x17b50e5fdc0>"
            ]
          },
          "execution_count": 67,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "#CW + Output bias\n",
        "model.fit(training,steps_per_epoch=len(train_gen),epochs=5, callbacks=[reduce_lr], class_weight=class_weights)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 68,
      "id": "4ab556b8",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 26s 57ms/step - loss: 0.0469 - precision_Gun: 0.9802 - precision_Knife: 0.9852 - precision_Wrench: 0.8608 - precision_Pliers: 0.8156 - precision_Scissors: 0.7810\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.04694594442844391,\n",
              " 0.9801980257034302,\n",
              " 0.9851852059364319,\n",
              " 0.8607594966888428,\n",
              " 0.815625011920929,\n",
              " 0.7809523940086365]"
            ]
          },
          "execution_count": 68,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 51,
      "id": "3a33345a",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Epoch 1/10\n",
            "2342/2342 [==============================] - 163s 70ms/step - loss: 0.0327 - precision_Gun: 0.9504 - precision_Knife: 0.8929 - precision_Wrench: 0.7125 - precision_Pliers: 0.7579 - precision_Scissors: 0.0000e+00\n",
            "Epoch 2/10\n",
            "2342/2342 [==============================] - 165s 70ms/step - loss: 0.0325 - precision_Gun: 0.9520 - precision_Knife: 0.8956 - precision_Wrench: 0.7151 - precision_Pliers: 0.7594 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00002: ReduceLROnPlateau reducing learning rate to 3.9062499126885086e-05.\n",
            "Epoch 3/10\n",
            "2342/2342 [==============================] - 165s 70ms/step - loss: 0.0323 - precision_Gun: 0.9528 - precision_Knife: 0.8976 - precision_Wrench: 0.7174 - precision_Pliers: 0.7610 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00003: ReduceLROnPlateau reducing learning rate to 1.9531249563442543e-05.\n",
            "Epoch 4/10\n",
            "2342/2342 [==============================] - 165s 70ms/step - loss: 0.0321 - precision_Gun: 0.9528 - precision_Knife: 0.8971 - precision_Wrench: 0.7181 - precision_Pliers: 0.7606 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00004: ReduceLROnPlateau reducing learning rate to 9.765624781721272e-06.\n",
            "Epoch 5/10\n",
            "2342/2342 [==============================] - 164s 70ms/step - loss: 0.0321 - precision_Gun: 0.9525 - precision_Knife: 0.8995 - precision_Wrench: 0.7178 - precision_Pliers: 0.7605 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00005: ReduceLROnPlateau reducing learning rate to 4.882812390860636e-06.\n",
            "Epoch 6/10\n",
            "2342/2342 [==============================] - 166s 71ms/step - loss: 0.0320 - precision_Gun: 0.9532 - precision_Knife: 0.9006 - precision_Wrench: 0.7179 - precision_Pliers: 0.7601 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00006: ReduceLROnPlateau reducing learning rate to 2.441406195430318e-06.\n",
            "Epoch 7/10\n",
            "2342/2342 [==============================] - 165s 70ms/step - loss: 0.0320 - precision_Gun: 0.9535 - precision_Knife: 0.9009 - precision_Wrench: 0.7177 - precision_Pliers: 0.7607 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00007: ReduceLROnPlateau reducing learning rate to 1.220703097715159e-06.\n",
            "Epoch 8/10\n",
            "2342/2342 [==============================] - 166s 71ms/step - loss: 0.0320 - precision_Gun: 0.9535 - precision_Knife: 0.9003 - precision_Wrench: 0.7177 - precision_Pliers: 0.7611 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00008: ReduceLROnPlateau reducing learning rate to 6.103515488575795e-07.\n",
            "Epoch 9/10\n",
            "2342/2342 [==============================] - 165s 70ms/step - loss: 0.0320 - precision_Gun: 0.9539 - precision_Knife: 0.9003 - precision_Wrench: 0.7174 - precision_Pliers: 0.7611 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00009: ReduceLROnPlateau reducing learning rate to 3.0517577442878974e-07.\n",
            "Epoch 10/10\n",
            "2342/2342 [==============================] - 166s 71ms/step - loss: 0.0320 - precision_Gun: 0.9539 - precision_Knife: 0.9003 - precision_Wrench: 0.7169 - precision_Pliers: 0.7612 - precision_Scissors: 0.0000e+00\n",
            "\n",
            "Epoch 00010: ReduceLROnPlateau reducing learning rate to 1.5258788721439487e-07.\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.callbacks.History at 0x29db16c7160>"
            ]
          },
          "execution_count": 51,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.fit(training,steps_per_epoch=len(train_gen),epochs=10, callbacks=[reduce_lr], class_weight=class_weights)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 52,
      "id": "b1ce37c9",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "<tensorflow.python.keras.engine.functional.Functional at 0x28d38810eb0>"
            ]
          },
          "execution_count": 52,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "# Check what happens when you input Scissors \n",
        "# "
      ]
    },
    {
      "cell_type": "markdown",
      "id": "68adf804",
      "metadata": {},
      "source": [
        "### im = Image.fromarray(test_gen.__getitem__(0)[0][0].astype('uint8'))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 37,
      "id": "fe2b320d",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "0        0\n",
              "1        0\n",
              "2        0\n",
              "3        0\n",
              "4        0\n",
              "        ..\n",
              "13407    0\n",
              "13408    0\n",
              "13409    0\n",
              "13410    0\n",
              "13411    0\n",
              "Name: Scissors, Length: 13412, dtype: int64"
            ]
          },
          "execution_count": 37,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "test_gen.df['Scissors']"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 103,
      "id": "36995c8a",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 33s 73ms/step - loss: 0.1231 - precision_Gun: 0.9123 - precision_Knife: 0.6276 - precision_Wrench: 0.3283 - precision_Pliers: 0.5614 - precision_Scissors: 0.2500: 14s - loss: 0.1240 - precision_Gun: 0.9333 - precision_Knife: 0.6116 - precision_Wrench: 0\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.12313887476921082,\n",
              " 0.9122806787490845,\n",
              " 0.6276150345802307,\n",
              " 0.32826748490333557,\n",
              " 0.5614035129547119,\n",
              " 0.25]"
            ]
          },
          "execution_count": 103,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing, steps=len(test_gen))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 50,
      "id": "1b7ad5c2",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 11s 24ms/step - loss: 0.0642 - precision_Gun: 0.9030 - precision_Knife: 0.7514 - precision_Wrench: 0.3373 - precision_Pliers: 0.5439 - precision_Scissors: 0.0000e+00\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.06417271494865417,\n",
              " 0.9030470848083496,\n",
              " 0.7514124512672424,\n",
              " 0.3372780978679657,\n",
              " 0.5438931584358215,\n",
              " 0.0]"
            ]
          },
          "execution_count": 50,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing, steps=len(test_gen))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 37,
      "id": "aa42ccbc",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 20s 43ms/step - loss: 0.0678 - precision_Gun: 0.8957 - precision_Knife: 0.6562 - precision_Wrench: 0.3292 - precision_Pliers: 0.5381 - precision_Scissors: 0.0000e+005s - loss: 0.0678 \n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.0678030475974083,\n",
              " 0.895652174949646,\n",
              " 0.65625,\n",
              " 0.32919254899024963,\n",
              " 0.5381443500518799,\n",
              " 0.0]"
            ]
          },
          "execution_count": 37,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing, steps=len(test_gen))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 41,
      "id": "39a863b6",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "419/419 [==============================] - 19s 39ms/step - loss: 0.0721 - precision_Gun: 0.9489 - precision_Knife: 0.7196 - precision_Wrench: 0.4000 - precision_Pliers: 0.5923 - precision_Scissors: 0.6667\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.07213450968265533,\n",
              " 0.9488818049430847,\n",
              " 0.7195767164230347,\n",
              " 0.4000000059604645,\n",
              " 0.5922619104385376,\n",
              " 0.6666666865348816]"
            ]
          },
          "execution_count": 41,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing, steps=len(test_gen))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 33,
      "id": "a60fcf33",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "13/13 [==============================] - 3s 43ms/step - loss: 0.0830 - precision_Gun: 0.9000 - precision_Knife: 0.6667 - precision_Wrench: 0.2000 - precision_Pliers: 0.8235 - precision_Scissors: 0.0000e+00\n"
          ]
        },
        {
          "data": {
            "text/plain": [
              "[0.0829537957906723,\n",
              " 0.8999999761581421,\n",
              " 0.6666666865348816,\n",
              " 0.20000000298023224,\n",
              " 0.8235294222831726,\n",
              " 0.0]"
            ]
          },
          "execution_count": 33,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.evaluate(testing, steps=len(test_gen))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 54,
      "id": "ed1b47fc",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "array([[1, 0, 1, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 1, 1, 1, 0],\n",
              "       [1, 1, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 1, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 1, 1, 1, 0],\n",
              "       [1, 1, 0, 0, 0],\n",
              "       [1, 1, 1, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0],\n",
              "       [1, 0, 0, 0, 0]], dtype=uint8)"
            ]
          },
          "execution_count": 54,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "train_gen.__getitem__(0)[1]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 21,
      "id": "52f878bd",
      "metadata": {},
      "outputs": [],
      "source": [
        "from sklearn.metrics import classification_report, multilabel_confusion_matrix"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 23,
      "id": "329b802b",
      "metadata": {},
      "outputs": [],
      "source": [
        "thresh = 0.5"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 25,
      "id": "e64a8119",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "              precision    recall  f1-score   support\n",
            "\n",
            "           0       1.00      0.67      0.80         3\n",
            "           1       1.00      1.00      1.00         3\n",
            "           2       1.00      0.50      0.67         4\n",
            "           3       0.67      0.50      0.57         4\n",
            "           4       0.00      0.00      0.00         0\n",
            "\n",
            "   micro avg       0.90      0.64      0.75        14\n",
            "   macro avg       0.73      0.53      0.61        14\n",
            "weighted avg       0.90      0.64      0.74        14\n",
            " samples avg       0.38      0.31      0.33        14\n",
            "\n"
          ]
        },
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "C:\\Users\\XXX (Anonimised for double-blind review)\\anaconda3\\envs\\tf2plat\\lib\\site-packages\\sklearn\\metrics\\_classification.py:1221: UndefinedMetricWarning: Precision and F-score are ill-defined and being set to 0.0 in labels with no predicted samples. Use `zero_division` parameter to control this behavior.\n",
            "  _warn_prf(average, modifier, msg_start, len(result))\n",
            "C:\\Users\\XXX (Anonimised for double-blind review)\\anaconda3\\envs\\tf2plat\\lib\\site-packages\\sklearn\\metrics\\_classification.py:1221: UndefinedMetricWarning: Recall and F-score are ill-defined and being set to 0.0 in labels with no true samples. Use `zero_division` parameter to control this behavior.\n",
            "  _warn_prf(average, modifier, msg_start, len(result))\n",
            "C:\\Users\\XXX (Anonimised for double-blind review)\\anaconda3\\envs\\tf2plat\\lib\\site-packages\\sklearn\\metrics\\_classification.py:1221: UndefinedMetricWarning: Precision and F-score are ill-defined and being set to 0.0 in samples with no predicted labels. Use `zero_division` parameter to control this behavior.\n",
            "  _warn_prf(average, modifier, msg_start, len(result))\n",
            "C:\\Users\\XXX (Anonimised for double-blind review)\\anaconda3\\envs\\tf2plat\\lib\\site-packages\\sklearn\\metrics\\_classification.py:1221: UndefinedMetricWarning: Recall and F-score are ill-defined and being set to 0.0 in samples with no true labels. Use `zero_division` parameter to control this behavior.\n",
            "  _warn_prf(average, modifier, msg_start, len(result))\n"
          ]
        }
      ],
      "source": [
        "print(classification_report(train_gen.__getitem__(1)[1],np.array([[1 if i > thresh else 0 for i in j] for j in model.predict(train_gen.__getitem__(1)[0])])))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 26,
      "id": "f0ffc2df",
      "metadata": {},
      "outputs": [],
      "source": [
        "preds = model.predict(test_gen)"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "569e6d9a",
      "metadata": {},
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": 65,
      "id": "2c2cd041",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "214592"
            ]
          },
          "execution_count": 65,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "len(preds)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 27,
      "id": "87fda2ec",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "text/plain": [
              "array([[1.2870832e-01, 8.5958451e-01, 4.4118139e-01, 9.4065759e-03,\n",
              "        6.5490077e-03],\n",
              "       [1.3764952e-04, 3.2067162e-04, 2.9707570e-03, 1.0166513e-03,\n",
              "        4.2261658e-03],\n",
              "       [5.7496654e-05, 3.1562802e-05, 3.2190082e-04, 1.5622318e-05,\n",
              "        3.2707540e-05],\n",
              "       ...,\n",
              "       [2.8580936e-04, 2.9629441e-03, 9.7197682e-02, 2.4582538e-01,\n",
              "        9.8052979e-02],\n",
              "       [1.3733788e-04, 1.3424207e-03, 3.8454615e-02, 2.1230265e-01,\n",
              "        5.6409635e-02],\n",
              "       [2.1105402e-04, 2.1628158e-03, 3.1264015e-02, 9.9472374e-02,\n",
              "        1.3535345e-01]], dtype=float32)"
            ]
          },
          "execution_count": 27,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "preds"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "eca2ffd4",
      "metadata": {},
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": "Python [conda env:tf2plat]",
      "language": "python",
      "name": "conda-env-tf2plat-py"
    },
    "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.5"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 5
}
