Commit 2227214a authored by Kethmini Rupasinghe's avatar Kethmini Rupasinghe

feat: Model Building

parent f7d8a68d
{"metadata":{"kernelspec":{"language":"python","display_name":"Python 3","name":"python3"},"language_info":{"name":"python","version":"3.7.12","mimetype":"text/x-python","codemirror_mode":{"name":"ipython","version":3},"pygments_lexer":"ipython3","nbconvert_exporter":"python","file_extension":".py"}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"import matplotlib.pyplot as plt\nimport numpy as np\nimport pandas as pd\nimport seaborn as sns\nimport os\n\n# Importing Deep Learning Libraries\n\nfrom keras.preprocessing.image import load_img, img_to_array\nfrom keras.preprocessing.image import ImageDataGenerator\nfrom keras.layers import Dense,Input,Dropout,GlobalAveragePooling2D,Flatten,Conv2D,BatchNormalization,Activation,MaxPooling2D\nfrom keras.models import Model,Sequential","metadata":{"_uuid":"8f2839f25d086af736a60e9eeb907d3b93b6e0e5","_cell_guid":"b1076dfc-b9ad-4769-8c92-a6c4dae69d19","execution":{"iopub.status.busy":"2021-12-13T18:08:28.381737Z","iopub.execute_input":"2021-12-13T18:08:28.382443Z","iopub.status.idle":"2021-12-13T18:08:33.857642Z","shell.execute_reply.started":"2021-12-13T18:08:28.382349Z","shell.execute_reply":"2021-12-13T18:08:33.856887Z"},"trusted":true},"execution_count":1,"outputs":[]},{"cell_type":"code","source":"from tensorflow.keras.optimizers import Adam,SGD,RMSprop","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:09:40.507653Z","iopub.execute_input":"2021-12-13T18:09:40.508367Z","iopub.status.idle":"2021-12-13T18:09:40.833605Z","shell.execute_reply.started":"2021-12-13T18:09:40.508325Z","shell.execute_reply":"2021-12-13T18:09:40.832816Z"},"trusted":true},"execution_count":2,"outputs":[]},{"cell_type":"code","source":"picture_size = 48\nfolder_path = \"../input/face-expression-recognition-dataset/images/\"","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:09:48.028275Z","iopub.execute_input":"2021-12-13T18:09:48.028919Z","iopub.status.idle":"2021-12-13T18:09:48.032993Z","shell.execute_reply.started":"2021-12-13T18:09:48.028877Z","shell.execute_reply":"2021-12-13T18:09:48.032153Z"},"trusted":true},"execution_count":3,"outputs":[]},{"cell_type":"code","source":"expression = 'disgust'\n\nplt.figure(figsize= (12,12))\nfor i in range(1, 10, 1):\n plt.subplot(3,3,i)\n img = load_img(folder_path+\"train/\"+expression+\"/\"+\n os.listdir(folder_path + \"train/\" + expression)[i], target_size=(picture_size, picture_size))\n plt.imshow(img) \nplt.show()","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:09:54.101252Z","iopub.execute_input":"2021-12-13T18:09:54.101864Z","iopub.status.idle":"2021-12-13T18:09:55.192017Z","shell.execute_reply.started":"2021-12-13T18:09:54.101806Z","shell.execute_reply":"2021-12-13T18:09:55.191333Z"},"trusted":true},"execution_count":4,"outputs":[]},{"cell_type":"code","source":"batch_size = 128\n\ndatagen_train = ImageDataGenerator()\ndatagen_val = ImageDataGenerator()\n\ntrain_set = datagen_train.flow_from_directory(folder_path+\"train\",\n target_size = (picture_size,picture_size),\n color_mode = \"grayscale\",\n batch_size=batch_size,\n class_mode='categorical',\n shuffle=True)\n\n\ntest_set = datagen_val.flow_from_directory(folder_path+\"validation\",\n target_size = (picture_size,picture_size),\n color_mode = \"grayscale\",\n batch_size=batch_size,\n class_mode='categorical',\n shuffle=False)","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:10:12.146756Z","iopub.execute_input":"2021-12-13T18:10:12.147500Z","iopub.status.idle":"2021-12-13T18:10:34.791611Z","shell.execute_reply.started":"2021-12-13T18:10:12.147459Z","shell.execute_reply":"2021-12-13T18:10:34.790904Z"},"trusted":true},"execution_count":5,"outputs":[]},{"cell_type":"markdown","source":"Model Building","metadata":{}},{"cell_type":"code","source":"no_of_classes = 7\n\nmodel = Sequential()\n\n#1st CNN layer\nmodel.add(Conv2D(64,(3,3),padding = 'same',input_shape = (48,48,1)))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(MaxPooling2D(pool_size = (2,2)))\nmodel.add(Dropout(0.25))\n\n#2nd CNN layer\nmodel.add(Conv2D(128,(5,5),padding = 'same'))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(MaxPooling2D(pool_size = (2,2)))\nmodel.add(Dropout (0.25))\n\n#3rd CNN layer\nmodel.add(Conv2D(512,(3,3),padding = 'same'))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(MaxPooling2D(pool_size = (2,2)))\nmodel.add(Dropout (0.25))\n\n#4th CNN layer\nmodel.add(Conv2D(512,(3,3), padding='same'))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(MaxPooling2D(pool_size=(2, 2)))\nmodel.add(Dropout(0.25))\n\nmodel.add(Flatten())\n\n#Fully connected 1st layer\nmodel.add(Dense(256))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(Dropout(0.25))\n\n\n# Fully connected layer 2nd layer\nmodel.add(Dense(512))\nmodel.add(BatchNormalization())\nmodel.add(Activation('relu'))\nmodel.add(Dropout(0.25))\n\nmodel.add(Dense(no_of_classes, activation='softmax'))\n\n\n\nopt = Adam(lr = 0.0001)\nmodel.compile(optimizer=opt,loss='categorical_crossentropy', metrics=['accuracy'])\nmodel.summary()","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:51:47.491726Z","iopub.execute_input":"2021-12-13T18:51:47.491990Z","iopub.status.idle":"2021-12-13T18:51:47.672808Z","shell.execute_reply.started":"2021-12-13T18:51:47.491955Z","shell.execute_reply":"2021-12-13T18:51:47.672157Z"},"trusted":true},"execution_count":17,"outputs":[]},{"cell_type":"markdown","source":"Fitting the Model with Training and Validation Data","metadata":{}},{"cell_type":"code","source":"from keras.callbacks import ModelCheckpoint, EarlyStopping, ReduceLROnPlateau\n\ncheckpoint = ModelCheckpoint(\"./model.h5\", monitor='val_acc', verbose=1, save_best_only=True, mode='max')\n\nearly_stopping = EarlyStopping(monitor='val_loss',\n min_delta=0,\n patience=3,\n verbose=1,\n restore_best_weights=True\n )\n\nreduce_learningrate = ReduceLROnPlateau(monitor='val_loss',\n factor=0.2,\n patience=3,\n verbose=1,\n min_delta=0.0001)\n\ncallbacks_list = [early_stopping,checkpoint,reduce_learningrate]\n\nepochs = 48\n\nmodel.compile(loss='categorical_crossentropy',\n optimizer = Adam(lr=0.001),\n metrics=['accuracy'])","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:52:04.835357Z","iopub.execute_input":"2021-12-13T18:52:04.835618Z","iopub.status.idle":"2021-12-13T18:52:04.848952Z","shell.execute_reply.started":"2021-12-13T18:52:04.835588Z","shell.execute_reply":"2021-12-13T18:52:04.848233Z"},"trusted":true},"execution_count":18,"outputs":[]},{"cell_type":"code","source":"history = model.fit_generator(generator=train_set,\n steps_per_epoch=train_set.n//train_set.batch_size,\n epochs=epochs,\n validation_data = test_set,\n validation_steps = test_set.n//test_set.batch_size,\n callbacks=callbacks_list\n )","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:52:09.759448Z","iopub.execute_input":"2021-12-13T18:52:09.759706Z","iopub.status.idle":"2021-12-13T18:57:55.374441Z","shell.execute_reply.started":"2021-12-13T18:52:09.759670Z","shell.execute_reply":"2021-12-13T18:57:55.373647Z"},"trusted":true},"execution_count":19,"outputs":[]},{"cell_type":"code","source":"plt.style.use('dark_background')\n\nplt.figure(figsize=(20,10))\nplt.subplot(1, 2, 1)\nplt.suptitle('Optimizer : Adam', fontsize=10)\nplt.ylabel('Loss', fontsize=16)\nplt.plot(history.history['loss'], label='Training Loss')\nplt.plot(history.history['val_loss'], label='Validation Loss')\nplt.legend(loc='upper right')\n\nplt.subplot(1, 2, 2)\nplt.ylabel('Accuracy', fontsize=16)\nplt.plot(history.history['accuracy'], label='Training Accuracy')\nplt.plot(history.history['val_accuracy'], label='Validation Accuracy')\nplt.legend(loc='lower right')\nplt.show()","metadata":{"execution":{"iopub.status.busy":"2021-12-13T18:59:06.255454Z","iopub.execute_input":"2021-12-13T18:59:06.255714Z","iopub.status.idle":"2021-12-13T18:59:06.582348Z","shell.execute_reply.started":"2021-12-13T18:59:06.255683Z","shell.execute_reply":"2021-12-13T18:59:06.581699Z"},"trusted":true},"execution_count":21,"outputs":[]}]}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment