{ "nbformat": 4, "nbformat_minor": 0, "metadata": { "colab": { "name": "linear-clf.ipynb", "version": "0.3.2", "provenance": [], "collapsed_sections": [], "include_colab_link": true }, "kernelspec": { "name": "python3", "display_name": "Python 3" }, "accelerator": "GPU" }, "cells": [ { "cell_type": "markdown", "metadata": { "id": "view-in-github", "colab_type": "text" }, "source": [ "\"Open" ] }, { "metadata": { "id": "ri6UiGU5T5aj", "colab_type": "text" }, "cell_type": "markdown", "source": [ "**সাইকিট-লার্ন দিয়ে একটা সহজ লিনিয়ার ক্লাসিফিকেশন **\n", "\n", "চারটার জায়গায় দুটো ফিচার, তিনটার জায়গায় দুটো টার্গেট ভ্যারিয়েবল" ] }, { "metadata": { "colab_type": "text", "id": "3sKNXPKNBqwO" }, "cell_type": "markdown", "source": [ "চারটার জায়গায় দুটো। প্রস্তাব - এটাকে দুটো দিয়ে দেখান না কেন? বুঝলাম - জিনিসটাকে আরো পানির মতো করতে হবে। আমাকে অনেকে বলেন, আইরিস ডেটাসেটে চারটা অ্যাট্রিবিউট। ফলে ডেটা ভিজ্যুয়ালাইজেশনে একটার ভেতরে আরেকটা চলে যায়। খালি চোখে ডেটার মধ্যে ফারাক বের করা তো দুস্কর। প্রস্তাবটা ভালো। এটা একটা বড় সমস্যাকে আরো রিফাইন করে আনবে আমাদের ভালোভাবে বুঝতে। \n", "\n", " সত্যি বলতে সেই আইডিয়াটা নিয়ে লিখেছেন বেশ কয়েকজন লেখক। তবে, এখানে আইডিয়াটা এলো আমার একটা প্রিয় বই থেকে, ২০১৩তে লেখা। লার্নিং সাইকিট-লার্ন:: মেশিন লার্নিং ইন পাইথন, রাউল গ্যারেটার। \"কী করবো সামনে?\" চ্যাপ্টারে দ্রষ্টব্য। \n", "\n", "আচ্ছা, তিনটা প্রজাতি না বের করে, একটা প্রজাতি বের করা যায় না? আরো, ভালো! তাহলে তো একটা প্রজাতি ভার্সেস ওই প্রজাতি নয়। মানে, প্রেডিক্ট করতে হবে - ধরুন, ফুলটা \"সেটোসা\" অথবা \"সেটোসা নয়\"! তাহলে তো জিনিসটা একদম পানি হয়ে যাবে। " ] }, { "metadata": { "id": "gfRxmu0QT5a5", "colab_type": "text" }, "cell_type": "markdown", "source": [ "## লোড করে নেই আইরিস ডেটাসেট " ] }, { "metadata": { "id": "c32_FG83T5a7", "colab_type": "code", "colab": {} }, "cell_type": "code", "source": [ "import sklearn\n", "from sklearn import datasets\n", "\n", "iris = datasets.load_iris()\n", "X_temp = iris.data\n", "y_temp = iris.target" ], "execution_count": 0, "outputs": [] }, { "metadata": { "id": "TrVDNHPBT5bL", "colab_type": "text" }, "cell_type": "markdown", "source": [ "### ভাগ করে ফেলি টেস্ট এবং ট্রেনিং ডেটাসেট (ফিচার স্কেলিং সহ)" ] }, { "metadata": { "id": "zTvelXXOT5bM", "colab_type": "text" }, "cell_type": "markdown", "source": [ "এখানে আমাদের কাজ হচ্ছে ডেটাসেটকে দুভাগে ভাগ করে ফেলা। ৭৫% ব্যবহার হবে আমাদের ক্লাসিফায়ারকে ট্রেনিং করাতে। ২৫% যাবে ইভ্যালুয়েট করতে। ৪টা ফিচারের জায়গায় আমরা ব্যবহার করবো ২টা মাত্র। সিপাল দৈর্ঘ্য এবং প্রস্থ। শুধুমাত্র সিপাল অংশ। \n", "\n", "এর পাশাপাশি আমরা ফিচার স্কেলিং করবো আমাদের ফিচারগুলোর ডেটা রেঞ্জ স্ট্যান্ডার্ডাইজ করার জন্য। প্রতিটা ফিচারের জন্য এটা সব ভ্যালুকে গড় করে সেটাকে বিয়োগ দেয় ওই ফিচার ভ্যালু থেকে। এরপর তার উত্তরকে ভাগ দেয় সেটার স্ট্যান্ডার্ড ডেভিয়েশন দিয়ে। আমাদের এই স্কেলিং এর পর প্রতিটা ফিচারের গড় হবে শূন্য। পাশাপাশি স্ট্যান্ডার্ড ডেভিয়েশন হচ্ছে ১। \n", "\n", "এর ফলে ভ্যালুগুলোর স্ট্যান্ডার্ডাইজেশন হয়ে আসে। এটা খানিকটা স্ট্যান্ডার্ড প্র্যাক্টিস হয়ে গেছে ইন্ডিপেন্ডেন্ট ফিচার/ভ্যারিয়েবলগুলোর রেঞ্জকে একটা স্কেলের মধ্যে নিয়ে আসা। এটাকে আমরা ডেটা নর্মালাইজেশন বলতে পারি। এটা আমরা করি ডেটা প্রি-প্রসেসিং এর সময়। \n", "\n", "ডেটার রেঞ্জ নিয়ে আমাদের যেহেতু কোন ফিল্টার নেই, সেকারণে একটা ডেটাসেটে বিক্ষিপ্ত ডেটা মেশিন লার্নিংকে বিপদে ফেলতে পারে। বড় বড় ভ্যালুগুলো ফাইনাল আউটকামে সমস্যা করে। আর সেকারণে মেশিন লার্নিং অ্যালগরিদমকে ভালোভাবে কাজ করানোর জন্য এই স্কেলিং দরকার পড়ে অনেক সময়। তবে, \"\"গ্রাডিয়েন্ট ডিসেন্ট\"\" কনভার্জেন্স ভালো কাজ করে স্কেলিং দিয়ে। মজার কথা হচ্ছে এক্স ভ্যালুগুলোকে প্লট করলে আগে এবং পরে একই জিনিস পাওয়া যায়। " ] }, { "metadata": { "id": "RknPx8MPT5bN", "colab_type": "code", "colab": {} }, "cell_type": "code", "source": [ "from sklearn.model_selection import train_test_split\n", "from sklearn import preprocessing\n", "\n", "# শুধুমাত্র প্রথম দুটো অ্যাট্রিবিউট নিয়ে আমাদের ডেটাসেট \n", "X, y = X_temp[:, [0,1]], y_temp\n", "# আমাদের টেস্টসেট হবে ২৫%, দৈবচয়নের ভিত্তিতে \n", "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25, random_state=33)\n", " \n", "# ফিচারগুলোকে স্ট্যান্ডার্ডাইজ করছি এখানে \n", "scaler = preprocessing.StandardScaler().fit(X_train)\n", "X_train = scaler.transform(X_train)\n", "X_test = scaler.transform(X_test)" ], "execution_count": 0, "outputs": [] }, { "metadata": { "id": "IRRoCZxmT5bQ", "colab_type": "text" }, "cell_type": "markdown", "source": [ "চলুন, দেখি ফিচার স্কেলিং এর পর কি অবস্থা? এখানে গড় হচ্ছে \"০\", স্ট্যান্ডার্ড ডেভিয়েশন হচ্ছে \"১\"। ট্রেনিংসেটে ঠিকমতো হবে সবকিছু, তবে টেস্টসেটে ব্যাপারটা কাছাকাছি হবে। " ] }, { "metadata": { "id": "Xon7VkoGT5bR", "colab_type": "code", "outputId": "5ead9da0-71c7-4f2e-95c5-6862ebec473d", "colab": { "base_uri": "https://localhost:8080/", "height": 50 } }, "cell_type": "code", "source": [ "import numpy as np\n", "print ('Training set mean:{:.2f} and standard deviation:{:.2f}'.format(np.average(X_train),np.std(X_train)))\n", "print ('Testing set mean:{:.2f} and standard deviation:{:.2f}'.format(np.average(X_test),np.std(X_test)))\n" ], "execution_count": 3, "outputs": [ { "output_type": "stream", "text": [ "Training set mean:0.00 and standard deviation:1.00\n", "Testing set mean:0.13 and standard deviation:0.71\n" ], "name": "stdout" } ] }, { "metadata": { "id": "jFf9lDTeT5bV", "colab_type": "text" }, "cell_type": "markdown", "source": [ "ফিচার স্কেলিং এর পর ট্রেনিং ডেটাকে প্লটিং করি। একই জিনিস। " ] }, { "metadata": { "id": "DPCGNVefT5bW", "colab_type": "code", "outputId": "e853a9f3-480a-4dea-86fe-630cf69b9618", "colab": { "base_uri": "https://localhost:8080/", "height": 377 } }, "cell_type": "code", "source": [ "# প্লটিং লাইব্রেরি লোড করে নেই \n", "import matplotlib.pyplot as plt\n", "\n", "# তিন প্রজাতির তিনটা আলাদা রং, মার্কার সহ \n", "colour_mk = [ ['red','s'], ['green','o'], ['blue','x']]\n", "plt.figure('Training Data')\n", "\n", "# লুপে ফেলে দিলাম, x এবং y এক্সিসে \n", "for i in range(len(colour_mk)):\n", " xs = X_train[:, 0][y_train == i]\n", " ys = X_train[:, 1][y_train == i]\n", " plt.scatter(xs, ys, c=colour_mk[i][0], marker=colour_mk[i][1])\n", "\n", "# সাদা ব্যাকগ্রাউন্ড দরকার আমার, গুগল কোলাবে বাড়তি শেড দরকার নেই \n", "# plt.rcParams['axes.facecolor'] = 'white'\n", "plt.style.use('default')\n", "plt.grid(c='grey')\n", "\n", "# প্লটিং প্যারামিটার \n", "plt.title('Training instances, after scaling')\n", "plt.legend(iris.target_names)\n", "plt.xlabel('Sepal length')\n", "plt.ylabel('Sepal width')\n", "plt.show()\n" ], "execution_count": 4, "outputs": [ { "output_type": "display_data", "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "tags": [] } } ] }, { "metadata": { "id": "-fYy0VkkT5bb", "colab_type": "text" }, "cell_type": "markdown", "source": [ "### একটা লিনিয়ার বাইনারি ক্লাসিফিকেশন " ] }, { "metadata": { "id": "pfEKD6K5T5bc", "colab_type": "text" }, "cell_type": "markdown", "source": [ "মানুষের মাথা প্যাটার্ন বুঝতে ওস্তাদ। এই প্লট থেকে কী বুঝতে পারছেন? ঠিক ধরেছেন। খালি চোখে সেটোসা প্রজাতিকে বোঝা যাচ্ছে একদম আলাদা করে। কেমন হয়, কমপ্লেক্সিটি এড়াতে আমরা যদি বের করতে চাই শুধুমাত্র সেটোসা প্রজাতি বের করতে চাই। মানে, প্রেডিক্ট করতে হবে হয় \"সেটোসা\" অথবা \"সেটোসা না\"? এখন আমাদের দুটো টার্গেট ভ্যারিয়েবল। সেকারণে এটাকে আমরা কনভার্ট করছি বাইনারি ক্লাসিফিকেশন টাস্কে। আমাদের দুটো টার্গেট। হয় \"০\" অথবা \"১\", তাহলে কী করতে হবে? \"১\" নম্বর এবং \"২\" নম্বর ক্লাসকে আমরা \"১\" বানিয়ে ফেলেছি। \n", "\n" ] }, { "metadata": { "id": "yLoZKBnCT5bd", "colab_type": "code", "outputId": "b98e1fa2-654a-48ee-9b42-fba39dd88b49", "colab": { "base_uri": "https://localhost:8080/", "height": 101 } }, "cell_type": "code", "source": [ "import copy \n", "y_train_setosa = copy.copy(y_train) \n", "# আমাদের ট্রেনিংসেটের ১ এবং ২ ক্লাসকে ১ বানিয়ে ফেলছি \n", "y_train_setosa[y_train_setosa > 0]=1\n", "y_test_setosa = copy.copy(y_test)\n", "y_test_setosa[y_test_setosa > 0]=1\n", "# এখন দেখি ট্রেনিং টার্গেট ক্লাসগুলো কী কী?\n", "print ('New training target classes:\\n{0}'.format(y_train_setosa))\n" ], "execution_count": 5, "outputs": [ { "output_type": "stream", "text": [ "New training target classes:\n", "[1 0 1 1 1 0 0 1 0 1 0 0 1 1 0 1 1 1 1 1 0 0 1 0 0 1 1 1 1 1 1 1 0 0 1 1 0\n", " 1 1 1 1 0 1 0 1 0 1 1 0 1 1 0 0 1 0 0 0 1 1 0 1 0 1 0 1 1 1 1 1 0 1 0 1 1\n", " 0 0 0 0 1 1 0 1 1 1 1 0 0 1 1 1 0 1 1 0 1 1 1 1 1 0 1 0 0 0 1 1 1 1 1 1 1\n", " 0]\n" ], "name": "stdout" } ] }, { "metadata": { "id": "mj_02w5mT5bi", "colab_type": "text" }, "cell_type": "markdown", "source": [ "ছবিটা দেখে কী মনে হচ্ছে? একটা প্রজাতি একেবারে আলাদা। এটা আমাদের জন্য ভালো। \n", "\n", "আমরা যদি ভালোমতো করে ছবিটা দেখি - তাহলে \"সেটোসা\" প্রজাতিতে আমরা একেবারে আলাদা হাইপারপ্লেন এ দেখতে পাচ্ছি। অর্থাৎ একটা লাইন টেনে দুটো প্রজাতিকে আলাদা করতে পারছি। ব্যাপারটা কমন মেশিন লার্নিং কনসেপ্টে। আমাদের প্রশ্ন হচ্ছে নতুন মাপজোক দিলে সেটা থেকে বের করতে হবে নতুন জিনিসটা কোন প্রজাতির? এখন বাকি প্রজাতিগুলো যেহেতু একটা আরেকটার ভেতরে ঢুকে গেছে, সেকারনে ওই দুটোকে একটা প্রজাতি হিসেবে দেখাচ্ছি। \n", "\n", "যেহেতু, আমরা \"সেটোসা\"কে একেবারে একটা লাইন টেনে আলাদা করতে পারছি, সেকারণে এই জিনিসটাকে একটা লিনিয়ার ক্লাসিফিকেশন মডেলে পাঠাতে পারি। মানে, একটা সোজা লাইন টেনে দুটো টার্গেট ক্লাসকে আলাদা করবো এখানে। এটাকে আমরা বলতে পারি ফিচার স্পেসে একটা হাইপারপ্লেন। দুটো ফিচার স্পেসের মধ্যে লাইনটা ডিসিশন বাউন্ডারি। কে কোন প্রজাতির, সেটা নির্ভর করবে কে ওই লাইনটার কোন দিকে আছে। \n", "\n", "মনে আছে, আমাদের ওই এরর কমানোর কথা? লিস্ট স্কয়ার রিগ্রেশন, লস ফাংশন? যেটা আসলে বের করে আমাদের প্রতিটা ইনস্ট্যান্স থেকে ডিসিশন বাউন্ডারি কতো দুরে। এখানে আমাদের এই অ্যালগরিদম হাইপারপ্লেনের \"কোএফিসিয়েন্ট\" জানবে লসকে কমিয়ে। এখানে আমরা ইন্টারসেপ্টও জানবো সামনে। \n", "\n", "এ কারণে আমরা সাইকিট লার্ন থেকে `SGDClassifier` ব্যবহার করবো এই লিনিয়ার মডেল তৈরি করতে। আমাদের সাইকিট লার্নে \"SGDClassifier\" মডেল হিসেবে থাকলেও এটা আসলে ক্লাসিফায়ার নয়। বরং এটা একটা লিনিয়ার তবে এটাকে অপ্টিমাইজড করা হয়েছে স্টোকাস্টিক গ্র্যাডিয়েন্ট ডিসেন্ট দিয়ে। \n" ] }, { "metadata": { "id": "5KCIy6waT5bm", "colab_type": "text" }, "cell_type": "markdown", "source": [ "এই কাজ আমরা আগেও করেছি। \"linear_model\" কে ইম্পোর্ট করে নিয়ে আসছি sklearn থেকে। একটা ক্লাসিফায়ারের ইনস্ট্যান্স তৈরি করে হাইপারপ্যারামিটারকে বলছি \"লগ\" লস ফাংশন ব্যবহার করতে। এখানে ক্লাসিফায়ার হচ্ছে \"linear_model.SGDClassifier\"। এমুহুর্তে ব্যবহার করবো সব ডিফল্ট ভ্যালু। বেশি ঝামেলায় যাবো না। \n", "\n" ] }, { "metadata": { "id": "0jrNibUVT5bo", "colab_type": "code", "colab": {} }, "cell_type": "code", "source": [ "from sklearn import linear_model \n", "clf = linear_model.SGDClassifier(loss='log', random_state=42)" ], "execution_count": 0, "outputs": [] }, { "metadata": { "id": "djVcNsMYT5bv", "colab_type": "text" }, "cell_type": "markdown", "source": [ "এখন কি বাকি? ট্রেনিং করানো। ফিট মেথড কল করছি আমাদের ক্লাসিফায়ারকে ট্রেনিং করানোর জন্য। এখানে আমাদের ট্রেনিং ডেটা হচ্ছে \"সেটোসা\" সেট। \n" ] }, { "metadata": { "id": "h9Tf4RvNT5bx", "colab_type": "code", "outputId": "e606bfcd-43e5-4896-f67d-4f315dbfa28d", "colab": { "base_uri": "https://localhost:8080/", "height": 171 } }, "cell_type": "code", "source": [ "clf.fit(X_train, y_train_setosa)\n", "\n", " " ], "execution_count": 7, "outputs": [ { "output_type": "stream", "text": [ "/usr/local/lib/python3.6/dist-packages/sklearn/linear_model/stochastic_gradient.py:166: FutureWarning: max_iter and tol parameters have been added in SGDClassifier in 0.19. If both are left unset, they default to max_iter=5 and tol=None. If tol is not None, max_iter defaults to max_iter=1000. From 0.21, default max_iter will be 1000, and default tol will be 1e-3.\n", " FutureWarning)\n" ], "name": "stderr" }, { "output_type": "execute_result", "data": { "text/plain": [ "SGDClassifier(alpha=0.0001, average=False, class_weight=None,\n", " early_stopping=False, epsilon=0.1, eta0=0.0, fit_intercept=True,\n", " l1_ratio=0.15, learning_rate='optimal', loss='log', max_iter=None,\n", " n_iter=None, n_iter_no_change=5, n_jobs=None, penalty='l2',\n", " power_t=0.5, random_state=42, shuffle=True, tol=None,\n", " validation_fraction=0.1, verbose=0, warm_start=False)" ] }, "metadata": { "tags": [] }, "execution_count": 7 } ] }, { "metadata": { "id": "dVVYycW3T5b0", "colab_type": "text" }, "cell_type": "markdown", "source": [ "লিনিয়ার মডেল। মনে আছে \"y = mx + b\" এর কথা? নাহ, অংক পিছু ছাড়ছেই না, আমাদেরকে m এবং b পেতে হবে। মানে, clf.coef_ এবং clf.intercept_ ছাড়া আমাদের গতি নেই। \n", "\n", "\n", "এখন এই সমীকরণকে y = mx + b ধারণায় লিখলে কেমন দেখা যাবে?" ] }, { "metadata": { "id": "94ScDMvbT5b1", "colab_type": "code", "outputId": "ce1d81f0-8162-46fd-9ebd-1e47330ac0b1", "colab": { "base_uri": "https://localhost:8080/", "height": 34 } }, "cell_type": "code", "source": [ "print (clf.coef_,clf.intercept_)\n" ], "execution_count": 8, "outputs": [ { "output_type": "stream", "text": [ "[[ 31.0790909 -17.78632765]] [17.31337552]\n" ], "name": "stdout" } ] }, { "metadata": { "id": "bg1L0kSLT5b5", "colab_type": "text" }, "cell_type": "markdown", "source": [ "এখন তো ডিসিশন বাউন্ডারি আঁকাই যায়, কি বলুন? কোড দিলাম না ইচ্ছে করে। মেইন লিংকে পাওয়া যাবে। \n", "\n", "![](https://drive.google.com/uc?export=view&id=1qa2eGu6sPNS7YqMSuB_07TBQnfu2s8B5)" ] }, { "metadata": { "id": "ViC_b6UrT5b-", "colab_type": "text" }, "cell_type": "markdown", "source": [ "ঠিক ধরেছেন। এই নীল/কালো রেখাটাই হচ্ছে আমাদের ডিসিশন বাউন্ডারি। প্রতিবার ৩০.০৭ x \"সিপাল দৈর্ঘ্য\" - ১৭.৭৮ x \"সিপাল প্রস্থ্য\" - ১৭.৩১ এর আউটপুট যখন শূন্য থেকে বড় হবে তখন সেটা হবে আইরিস সেটোসা, মানে ক্লাস ০। \n", "\n", "চলুন, একটা প্রেডিক্ট করি। ফুলটা কি সেটোসা কি না? যদি একটা ফুলের পেটাল প্রস্থ্য ৪.৬ এবং পেটাল দৈর্ঘ্য ৩.২ হয়, তাহলে প্রজাতিটা কি সেটোসা হবে কি হবে না? " ] }, { "metadata": { "id": "J3_a65KZ8Si6", "colab_type": "code", "colab": { "base_uri": "https://localhost:8080/", "height": 34 }, "outputId": "6aa64133-9d0d-4812-99a0-8bef6f1bd9e3" }, "cell_type": "code", "source": [ "print ('If the flower has 4.6 petal width and 3.2 petal length is a {}'.format(\n", " iris.target_names[clf.predict(scaler.transform([[4.6, 3.2]]))]))" ], "execution_count": 9, "outputs": [ { "output_type": "stream", "text": [ "If the flower has 4.6 petal width and 3.2 petal length is a ['setosa']\n" ], "name": "stdout" } ] }, { "metadata": { "id": "gVKeWGJq9gZ4", "colab_type": "text" }, "cell_type": "markdown", "source": [ "উত্তর: সেটোসা!" ] } ] }