DoS_CNN.ipynb 32 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781
{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import csv\n",
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "def transferData(dir_, outputdir_) :\n",
    "    outputfile = open(outputdir_, 'w', newline='\\n')\n",
    "    fopen = open(dir_, 'r')\n",
    "    csvreader = csv.reader(fopen)\n",
    "    \n",
    "    fw = csv.writer(outputfile)\n",
    "    \n",
    "    for line in csvreader :\n",
    "        newdata = []\n",
    "        can_id = int(line[1], 16)\n",
    "        newdata.append(can_id)\n",
    "        newdata.append(line[2])\n",
    "        \n",
    "        ll = len(line)\n",
    "        num = int(line[2])\n",
    "        \n",
    "        data = []\n",
    "        if num == 8 :\n",
    "            data = line[3:11]\n",
    "        else :\n",
    "            data = line[3:3+num]\n",
    "            for _ in range(8-num):\n",
    "                data.append('0')\n",
    "        #print(line)\n",
    "        newdata.extend(list(map(lambda x:int(x, 16), data)))\n",
    "        \n",
    "        if line[-1] == 'T' :\n",
    "            newdata.append(0)\n",
    "        else :\n",
    "            newdata.append(1)\n",
    "        \n",
    "        fw.writerow(newdata)\n",
    "\n",
    "def Preprocess(dir_) :\n",
    "    f1 = open(dir_, 'r')\n",
    "    fr = csv.reader(f1)\n",
    "    d = [] \n",
    "    for line in fr :\n",
    "        l = []\n",
    "        l.append(line[0])\n",
    "        l.append(line[1])\n",
    "        l.extend(line[2:11])\n",
    "        \n",
    "        d.append(l)\n",
    "    return d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "transferData('DoS_dataset.csv', 'DoS.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "datalist = Preprocess('DoS.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "datalist = datalist[0:3665761]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['790', '8', '5', '33', '104', '9', '33', '33', '0', '111', '1']"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "datalist[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def createsequence(data) :\n",
    "    arr = []\n",
    "    for i in range(0, len(data)-11): \n",
    "        d = []\n",
    "        t = []\n",
    "        for x in range(i, i+11):\n",
    "            t = list(map(float, data[x]))\n",
    "            #t = np.array(t, dtype=np.float32)\n",
    "            #t = tf.convert_to_tensor(t)\n",
    "            d.append(t)\n",
    "        arr.append(d)\n",
    "    return arr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "resData = createsequence(datalist)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [305.0, 8.0, 0.0, 128.0, 0.0, 0.0, 76.0, 127.0, 10.0, 154.0, 1.0], [0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 37.0, 42.0, 71.0, 1.0], [0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0], [0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [1087.0, 8.0, 0.0, 64.0, 96.0, 255.0, 126.0, 203.0, 8.0, 0.0, 1.0], [0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 203.0, 8.0, 0.0, 1.0], [0.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]\n",
      "11\n",
      "<class 'list'>\n"
     ]
    }
   ],
   "source": [
    "print(resData[1478])\n",
    "print(len(resData[1478]))\n",
    "print(type(resData))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check(data):\n",
    "    check = []\n",
    "    \n",
    "    for e in data :\n",
    "        flag = False\n",
    "        for i in e :\n",
    "            if i[-1] == 0 :\n",
    "                check.append(0)\n",
    "                flag = True\n",
    "                break\n",
    "        if flag == False :\n",
    "            check.append(1)\n",
    "            \n",
    "    return check\n",
    "\n",
    "cc = check(resData)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2585455\n",
      "1080295\n"
     ]
    }
   ],
   "source": [
    "cnt = 0\n",
    "for e in cc:\n",
    "    if e == 1 :\n",
    "        cnt += 1\n",
    "        \n",
    "print(cnt)\n",
    "print(len(cc)-cnt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "import tensorflow as tf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 404,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame(resData)\n",
    "n = len(df)\n",
    "\n",
    "X_train = df.iloc[0:n, 0:11].values.tolist()\n",
    "Y_train = cc\n",
    "\n",
    "#X_train = pd.\n",
    "X_train = np.asarray(X_train)\n",
    "Y_train = np.asarray(Y_train)\n",
    "#X_train = tf.constant(X_train)\n",
    "#print(X_train[-1])\n",
    "#Y_train = tf.convert_to_tensor(Y_train)\n",
    "\n",
    "#Y_train = np.squeeze(Y_train, axis=1)\n",
    "x_train, x_test, y_train, y_test = train_test_split(X_train, Y_train, test_size=0.3, random_state=321)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 405,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(333251, 11)\n",
      "(3665750, 11, 11)\n",
      "(3665750,)\n"
     ]
    }
   ],
   "source": [
    "print(X_train_.shape)\n",
    "print(X_train.shape)\n",
    "print(Y_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 241,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in x_train:\n",
    "    for j in i:\n",
    "        if len(j) != 11:\n",
    "            print(j)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>4</th>\n",
       "      <th>5</th>\n",
       "      <th>6</th>\n",
       "      <th>7</th>\n",
       "      <th>8</th>\n",
       "      <th>9</th>\n",
       "      <th>10</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>[790.0, 8.0, 5.0, 33.0, 104.0, 9.0, 33.0, 33.0...</td>\n",
       "      <td>[399.0, 8.0, 254.0, 91.0, 0.0, 0.0, 0.0, 60.0,...</td>\n",
       "      <td>[608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....</td>\n",
       "      <td>[672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...</td>\n",
       "      <td>[809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...</td>\n",
       "      <td>[305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>[399.0, 8.0, 254.0, 91.0, 0.0, 0.0, 0.0, 60.0,...</td>\n",
       "      <td>[608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....</td>\n",
       "      <td>[672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...</td>\n",
       "      <td>[809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...</td>\n",
       "      <td>[305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>[608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....</td>\n",
       "      <td>[672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...</td>\n",
       "      <td>[809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...</td>\n",
       "      <td>[305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>[672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...</td>\n",
       "      <td>[809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...</td>\n",
       "      <td>[305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....</td>\n",
       "      <td>[1087.0, 8.0, 0.0, 64.0, 96.0, 255.0, 126.0, 2...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>[809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...</td>\n",
       "      <td>[305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....</td>\n",
       "      <td>[1087.0, 8.0, 0.0, 64.0, 96.0, 255.0, 126.0, 2...</td>\n",
       "      <td>[880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333246</th>\n",
       "      <td>[809.0, 8.0, 220.0, 183.0, 127.0, 20.0, 17.0, ...</td>\n",
       "      <td>[880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...</td>\n",
       "      <td>[1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...</td>\n",
       "      <td>[497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333247</th>\n",
       "      <td>[880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...</td>\n",
       "      <td>[1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...</td>\n",
       "      <td>[497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...</td>\n",
       "      <td>[305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333248</th>\n",
       "      <td>[1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....</td>\n",
       "      <td>[1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...</td>\n",
       "      <td>[1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...</td>\n",
       "      <td>[497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...</td>\n",
       "      <td>[305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333249</th>\n",
       "      <td>[1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...</td>\n",
       "      <td>[1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...</td>\n",
       "      <td>[497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...</td>\n",
       "      <td>[305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...</td>\n",
       "      <td>[1264.0, 8.0, 0.0, 0.0, 0.0, 128.0, 0.0, 105.0...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333250</th>\n",
       "      <td>[1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...</td>\n",
       "      <td>[497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...</td>\n",
       "      <td>[339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....</td>\n",
       "      <td>[2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...</td>\n",
       "      <td>[848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...</td>\n",
       "      <td>[1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....</td>\n",
       "      <td>[304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...</td>\n",
       "      <td>[305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...</td>\n",
       "      <td>[320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...</td>\n",
       "      <td>[1264.0, 8.0, 0.0, 0.0, 0.0, 128.0, 0.0, 105.0...</td>\n",
       "      <td>[1680.0, 8.0, 0.0, 0.0, 1.0, 0.0, 160.0, 34.0,...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>333251 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                       0   \\\n",
       "0       [790.0, 8.0, 5.0, 33.0, 104.0, 9.0, 33.0, 33.0...   \n",
       "1       [399.0, 8.0, 254.0, 91.0, 0.0, 0.0, 0.0, 60.0,...   \n",
       "2       [608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....   \n",
       "3       [672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...   \n",
       "4       [809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...   \n",
       "...                                                   ...   \n",
       "333246  [809.0, 8.0, 220.0, 183.0, 127.0, 20.0, 17.0, ...   \n",
       "333247  [880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "333248  [1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "333249  [1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...   \n",
       "333250  [1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...   \n",
       "\n",
       "                                                       1   \\\n",
       "0       [399.0, 8.0, 254.0, 91.0, 0.0, 0.0, 0.0, 60.0,...   \n",
       "1       [608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....   \n",
       "2       [672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...   \n",
       "3       [809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...   \n",
       "4       [1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...   \n",
       "...                                                   ...   \n",
       "333246  [880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "333247  [1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "333248  [1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...   \n",
       "333249  [1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...   \n",
       "333250  [497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...   \n",
       "\n",
       "                                                       2   \\\n",
       "0       [608.0, 8.0, 25.0, 33.0, 34.0, 48.0, 8.0, 142....   \n",
       "1       [672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...   \n",
       "2       [809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...   \n",
       "3       [1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...   \n",
       "4       [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...   \n",
       "...                                                   ...   \n",
       "333246  [1072.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "333247  [1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...   \n",
       "333248  [1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...   \n",
       "333249  [497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...   \n",
       "333250  [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "\n",
       "                                                       3   \\\n",
       "0       [672.0, 8.0, 100.0, 0.0, 154.0, 29.0, 151.0, 2...   \n",
       "1       [809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...   \n",
       "2       [1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...   \n",
       "3       [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...   \n",
       "4       [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "...                                                   ...   \n",
       "333246  [1088.0, 8.0, 255.0, 0.0, 0.0, 0.0, 255.0, 138...   \n",
       "333247  [1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...   \n",
       "333248  [497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...   \n",
       "333249  [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "333250  [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...   \n",
       "\n",
       "                                                       4   \\\n",
       "0       [809.0, 8.0, 64.0, 187.0, 127.0, 20.0, 17.0, 3...   \n",
       "1       [1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...   \n",
       "2       [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...   \n",
       "3       [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "4       [704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "...                                                   ...   \n",
       "333246  [1201.0, 8.0, 41.0, 39.0, 39.0, 35.0, 0.0, 0.0...   \n",
       "333247  [497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...   \n",
       "333248  [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "333249  [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...   \n",
       "333250  [848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...   \n",
       "\n",
       "                                                       5   \\\n",
       "0       [1349.0, 8.0, 216.0, 0.0, 0.0, 138.0, 0.0, 0.0...   \n",
       "1       [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...   \n",
       "2       [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "3       [704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "4       [304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...   \n",
       "...                                                   ...   \n",
       "333246  [497.0, 8.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0...   \n",
       "333247  [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "333248  [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...   \n",
       "333249  [848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...   \n",
       "333250  [1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....   \n",
       "\n",
       "                                                       6   \\\n",
       "0       [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 11.0,...   \n",
       "1       [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "2       [704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "3       [304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...   \n",
       "4       [305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...   \n",
       "...                                                   ...   \n",
       "333246  [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "333247  [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...   \n",
       "333248  [848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...   \n",
       "333249  [1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....   \n",
       "333250  [304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...   \n",
       "\n",
       "                                                       7   \\\n",
       "0       [339.0, 8.0, 0.0, 33.0, 16.0, 255.0, 0.0, 255....   \n",
       "1       [704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "2       [304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...   \n",
       "3       [305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...   \n",
       "4       [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...   \n",
       "...                                                   ...   \n",
       "333246  [2.0, 8.0, 0.0, 0.0, 0.0, 0.0, 0.0, 9.0, 8.0, ...   \n",
       "333247  [848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...   \n",
       "333248  [1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....   \n",
       "333249  [304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...   \n",
       "333250  [305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...   \n",
       "\n",
       "                                                       8   \\\n",
       "0       [704.0, 8.0, 20.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0....   \n",
       "1       [304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...   \n",
       "2       [305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...   \n",
       "3       [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...   \n",
       "4       [848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....   \n",
       "...                                                   ...   \n",
       "333246  [848.0, 8.0, 5.0, 32.0, 164.0, 104.0, 118.0, 0...   \n",
       "333247  [1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....   \n",
       "333248  [304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...   \n",
       "333249  [305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...   \n",
       "333250  [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...   \n",
       "\n",
       "                                                       9   \\\n",
       "0       [304.0, 8.0, 8.0, 128.0, 0.0, 255.0, 49.0, 128...   \n",
       "1       [305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...   \n",
       "2       [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...   \n",
       "3       [848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....   \n",
       "4       [1087.0, 8.0, 0.0, 64.0, 96.0, 255.0, 126.0, 2...   \n",
       "...                                                   ...   \n",
       "333246  [1349.0, 8.0, 216.0, 82.0, 0.0, 139.0, 0.0, 0....   \n",
       "333247  [304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...   \n",
       "333248  [305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...   \n",
       "333249  [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...   \n",
       "333250  [1264.0, 8.0, 0.0, 0.0, 0.0, 128.0, 0.0, 105.0...   \n",
       "\n",
       "                                                       10  \n",
       "0       [305.0, 8.0, 229.0, 127.0, 0.0, 0.0, 72.0, 127...  \n",
       "1       [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 8.0, 34.0, 43...  \n",
       "2       [848.0, 8.0, 5.0, 32.0, 20.0, 104.0, 119.0, 0....  \n",
       "3       [1087.0, 8.0, 0.0, 64.0, 96.0, 255.0, 126.0, 2...  \n",
       "4       [880.0, 8.0, 0.0, 32.0, 0.0, 0.0, 0.0, 0.0, 0....  \n",
       "...                                                   ...  \n",
       "333246  [304.0, 8.0, 17.0, 128.0, 0.0, 255.0, 251.0, 1...  \n",
       "333247  [305.0, 8.0, 233.0, 127.0, 0.0, 0.0, 63.0, 127...  \n",
       "333248  [320.0, 8.0, 0.0, 0.0, 0.0, 0.0, 22.0, 34.0, 4...  \n",
       "333249  [1264.0, 8.0, 0.0, 0.0, 0.0, 128.0, 0.0, 105.0...  \n",
       "333250  [1680.0, 8.0, 0.0, 0.0, 1.0, 0.0, 160.0, 34.0,...  \n",
       "\n",
       "[333251 rows x 11 columns]"
      ]
     },
     "execution_count": 211,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 406,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1099725, 11, 11)\n"
     ]
    }
   ],
   "source": [
    "print(x_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 358,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Model\n",
    "from keras.models import Sequential\n",
    "from keras.layers import Dense, LSTM, Conv1D, Dropout, GlobalAveragePooling1D, MaxPooling1D\n",
    "from keras.utils import np_utils\n",
    "from keras.layers.normalization import BatchNormalization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 407,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_53\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "conv1d_99 (Conv1D)           (None, 9, 64)             2176      \n",
      "_________________________________________________________________\n",
      "global_average_pooling1d_24  (None, 64)                0         \n",
      "_________________________________________________________________\n",
      "dropout_13 (Dropout)         (None, 64)                0         \n",
      "_________________________________________________________________\n",
      "dense_35 (Dense)             (None, 1)                 65        \n",
      "=================================================================\n",
      "Total params: 2,241\n",
      "Trainable params: 2,241\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "model = Sequential()\n",
    "model.add(Conv1D(64, 3, input_shape=(11, 11), activation='relu'))\n",
    "#model.add(Conv1D(64, 3, activation='relu'))\n",
    "#model.add(MaxPooling1D(2))\n",
    "#model.add(Conv1D(128, 2, activation='relu'))\n",
    "#model.add(Conv1D(128, 2, activation='relu'))\n",
    "model.add(GlobalAveragePooling1D())\n",
    "model.add(Dropout(0.5))\n",
    "model.add(Dense(1, activation='sigmoid'))\n",
    "model.compile(optimizer='adam', loss='binary_crossentropy', metrics=['accuracy'])\n",
    "model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 408,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/10\n",
      "25661/25661 [==============================] - 33s 1ms/step - loss: 0.0926 - accuracy: 0.9975 - val_loss: 0.0021 - val_accuracy: 0.9997\n",
      "Epoch 2/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 0.0019 - accuracy: 0.9997 - val_loss: 8.2212e-04 - val_accuracy: 0.9998\n",
      "Epoch 3/10\n",
      "25661/25661 [==============================] - 33s 1ms/step - loss: 0.0012 - accuracy: 0.9998 - val_loss: 5.0894e-04 - val_accuracy: 0.9999\n",
      "Epoch 4/10\n",
      "25661/25661 [==============================] - 33s 1ms/step - loss: 8.3683e-04 - accuracy: 0.9999 - val_loss: 4.0702e-04 - val_accuracy: 0.9999\n",
      "Epoch 5/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 6.7326e-04 - accuracy: 0.9999 - val_loss: 1.0525e-04 - val_accuracy: 1.0000\n",
      "Epoch 6/10\n",
      "25661/25661 [==============================] - 33s 1ms/step - loss: 4.6771e-04 - accuracy: 0.9999 - val_loss: 8.2441e-05 - val_accuracy: 1.0000\n",
      "Epoch 7/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 5.0164e-04 - accuracy: 0.9999 - val_loss: 2.7738e-05 - val_accuracy: 1.0000\n",
      "Epoch 8/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 4.3489e-04 - accuracy: 0.9999 - val_loss: 5.0454e-05 - val_accuracy: 1.0000\n",
      "Epoch 9/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 3.8201e-04 - accuracy: 0.9999 - val_loss: 3.5519e-05 - val_accuracy: 1.0000\n",
      "Epoch 10/10\n",
      "25661/25661 [==============================] - 32s 1ms/step - loss: 2.5039e-04 - accuracy: 1.0000 - val_loss: 3.4685e-05 - val_accuracy: 1.0000\n"
     ]
    }
   ],
   "source": [
    "history = model.fit(x_train, y_train, batch_size=100, epochs=10,validation_data=(x_test, y_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}