{"metadata":{"kernelspec":{"language":"python","display_name":"Python 3","name":"python3"},"language_info":{"name":"python","version":"3.8.17","mimetype":"text/x-python","codemirror_mode":{"name":"ipython","version":3},"pygments_lexer":"ipython3","nbconvert_exporter":"python","file_extension":".py"},"kaggle":{"accelerator":"tpuV5e8","dataSources":[{"sourceId":6366769,"sourceType":"datasetVersion","datasetId":3667914},{"sourceId":6404089,"sourceType":"datasetVersion","datasetId":3692663},{"sourceId":6425848,"sourceType":"datasetVersion","datasetId":3707275},{"sourceId":6437011,"sourceType":"datasetVersion","datasetId":3714877},{"sourceId":6442346,"sourceType":"datasetVersion","datasetId":3718333},{"sourceId":6444111,"sourceType":"datasetVersion","datasetId":3719523},{"sourceId":6632565,"sourceType":"datasetVersion","datasetId":3828939},{"sourceId":12889659,"sourceType":"datasetVersion","datasetId":8155136},{"sourceId":12892814,"sourceType":"datasetVersion","datasetId":8157210},{"sourceId":13114945,"sourceType":"datasetVersion","datasetId":8307826}],"isInternetEnabled":true,"language":"python","sourceType":"notebook","isGpuEnabled":false}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"# !apt-get update && apt-get install -y python3-opencv\n# !pip install -q /lib/wheels/tensorflow-2.9.1-cp38-cp38-linux_x86_64.whl\n# !pip install albumentations > /dev/null\n# !pip install opencv-python\n# !pip install scikit-learn\n# !pip install matplotlib\n# !pip install albumentations\n# !pip install fnmatch\n\nimport os\nimport fnmatch \nimport cv2 \nimport pandas as pd\nfrom glob import glob\nimport numpy as np\nimport matplotlib.pyplot as plt\nimport sys\nfrom PIL import Image, ImageEnhance\nfrom sklearn.metrics import auc\nfrom sklearn.metrics import confusion_matrix\nfrom sklearn.metrics import roc_curve, roc_auc_score, precision_recall_curve\nimport random","metadata":{"_uuid":"92b39e68-6798-4554-adc4-690dddef8683","_cell_guid":"f49ec470-d6d8-451e-9872-67fe04ae9cd8","trusted":true,"collapsed":false,"papermill":{"duration":140.060542,"end_time":"2023-06-04T22:19:12.663045","exception":false,"start_time":"2023-06-04T22:16:52.602503","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:11:07.928975Z","iopub.execute_input":"2023-09-07T10:11:07.929352Z","iopub.status.idle":"2023-09-07T10:13:45.993435Z","shell.execute_reply.started":"2023-09-07T10:11:07.929320Z","shell.execute_reply":"2023-09-07T10:13:45.992247Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"def read_mask_image(path, files):\n    \n    img_list =[]\n#     for file in glob (os.path.join(path,\"*.png\")):\n    for file in files:\n#         print(path+file)\n        img = cv2.imread(path+file,0)\n        img = cv2.resize(img,(256,256))\n#         img = np.asarray(img)\n        img_list.append(img)\n    \n    return img_list     \n\n\n\ndef read_image(path,files):\n    \n    img_list =[]\n#     for file in glob (os.path.join(path,\"*.png\")):\n    for file in files:\n#         print(path+file)\n        img = cv2.imread(path+file)\n        img = cv2.resize(img,(256,256))\n        img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)\n#         img = np.asarray(img).astype(np.int32)\n        img_list.append(img)\n    \n    return img_list \n\n\ndef get_train_image(image, augmentation =False):\n\n    train =image\n      \n    if augmentation:\n        all_train_img = [train]\n        flip_train = train[:,::-1,:]\n        all_train_img.append(flip_train)\n        \n        \n        for i in range(0,360,120):\n            all_train_img.append(rotate(train,i,axes=(1, 2), reshape=False))\n            \n            all_train_img.append(rotate(flip_train,i,axes=(1, 2), reshape=False))\n            \n        train = np.concatenate(all_train_img,axis =0)    \n#            \n        return train\n\n\n\ndef get_mask_image(image, augmentation =False):\n\n\n\n    train_mask = image\n   \n#     assert(np.min(train_mask)==0 and np.max(train_mask)==1)  \n      \n    if augmentation:\n        \n        all_mask_img =[train_mask]\n        \n        flip_mask =train_mask[:,:,::-1]\n        \n        all_mask_img.append(flip_mask)\n        \n        for i in range(0,360,120):\n            all_mask_img.append(rotate(train_mask,i,axes=(1, 2), reshape=False))\n            \n            all_mask_img.append(rotate(flip_mask,i,axes=(1, 2), reshape=False))  \n        train_mask =np.round(np.concatenate(all_mask_img,axis =0)) \n    return train_mask","metadata":{"_uuid":"3d9b31d8-d5fc-4b2a-93cd-566369fa8ef8","_cell_guid":"32d5c984-d38b-4faa-993c-a2e2007ebbb5","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:13:45.995516Z","iopub.execute_input":"2023-09-07T10:13:45.996080Z","iopub.status.idle":"2023-09-07T10:13:46.014143Z","shell.execute_reply.started":"2023-09-07T10:13:45.996046Z","shell.execute_reply":"2023-09-07T10:13:46.013039Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_file = sorted(os.listdir(\"/kaggle/input/segmenation-ksvr/train_aumentation/\"))","metadata":{"_uuid":"4eeb6a1e-16db-4341-a140-245aa36b942d","_cell_guid":"3c5c62f5-b344-434a-80c5-444509915b7c","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:13:46.015670Z","iopub.execute_input":"2023-09-07T10:13:46.015995Z","iopub.status.idle":"2023-09-07T10:13:46.651578Z","shell.execute_reply.started":"2023-09-07T10:13:46.015965Z","shell.execute_reply":"2023-09-07T10:13:46.650414Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_mask_file = sorted(os.listdir(\"/kaggle/input/segmenation-ksvr/train_mask_augmentation/\"))","metadata":{"_uuid":"28ea3af3-cea3-4763-81d2-b55327640470","_cell_guid":"9e6e85b8-ac43-4b0c-a27e-3c0ae548cc2c","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:13:46.654251Z","iopub.execute_input":"2023-09-07T10:13:46.654652Z","iopub.status.idle":"2023-09-07T10:13:47.185709Z","shell.execute_reply.started":"2023-09-07T10:13:46.654615Z","shell.execute_reply":"2023-09-07T10:13:47.184595Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_image1 = np.array((read_image(\"/kaggle/input/segmenation-ksvr/train_aumentation/\",train_file))).astype(\"float32\")/255.\ntrain_main_image1.shape","metadata":{"_uuid":"16d08f5d-bb6b-4256-be6b-46c9860e9ea5","_cell_guid":"7d4d5945-52fe-40ab-84b8-7d401b660511","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:13:47.186987Z","iopub.execute_input":"2023-09-07T10:13:47.187315Z","iopub.status.idle":"2023-09-07T10:18:10.150647Z","shell.execute_reply.started":"2023-09-07T10:13:47.187287Z","shell.execute_reply":"2023-09-07T10:18:10.149640Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_mask_image1 = np.array((read_mask_image(\"/kaggle/input/segmenation-ksvr/train_mask_augmentation/\",train_mask_file))).astype(\"float32\")/255.","metadata":{"_uuid":"9be8fba1-f3ba-4038-a589-8b063a18dab1","_cell_guid":"ecf81ec0-d097-48dd-8d35-c6d90a44684b","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:18:10.151922Z","iopub.execute_input":"2023-09-07T10:18:10.152209Z","iopub.status.idle":"2023-09-07T10:21:08.319208Z","shell.execute_reply.started":"2023-09-07T10:18:10.152183Z","shell.execute_reply":"2023-09-07T10:21:08.317919Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# train_main_mask_image1.shape","metadata":{"_uuid":"48768687-30db-48cc-b120-61ea5f8fe79b","_cell_guid":"3baf397e-5c0d-44c1-9922-7468a9aea54c","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:21:08.320512Z","iopub.execute_input":"2023-09-07T10:21:08.320815Z","iopub.status.idle":"2023-09-07T10:21:08.325666Z","shell.execute_reply.started":"2023-09-07T10:21:08.320788Z","shell.execute_reply":"2023-09-07T10:21:08.324694Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# train_main_image = get_train_image(train_main_image,augmentation =True)\n# train_main_mask_image = get_mask_image(train_main_mask_image,augmentation =True)","metadata":{"_uuid":"72ae5f25-9c23-4bb0-86fe-41ac3871cb6d","_cell_guid":"894fec57-a94e-46d2-a011-f9e46a3acd7f","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:21:08.327167Z","iopub.execute_input":"2023-09-07T10:21:08.327480Z","iopub.status.idle":"2023-09-07T10:21:08.336698Z","shell.execute_reply.started":"2023-09-07T10:21:08.327452Z","shell.execute_reply":"2023-09-07T10:21:08.335727Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_image2 = sorted(os.listdir(\"/kaggle/input/seg-new/train_aug/images/\"))\ntrain_main_mask_image2 = sorted(os.listdir(\"/kaggle/input/seg-new/train_aug/masks/\"))\ntrain_main_image2 = np.array((read_image(\"/kaggle/input/seg-new/train_aug/images/\",train_main_image2))).astype(\"float32\")/255.\ntrain_main_mask_image2 = np.array((read_mask_image(\"/kaggle/input/seg-new/train_aug/masks/\",train_main_mask_image2))).astype(\"float32\")/255.","metadata":{"_uuid":"2a0833a0-a961-4690-95e3-e2019d9b51ae","_cell_guid":"8d0dbd85-051b-4bc6-82fb-5a6d65ebeab6","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:21:08.337980Z","iopub.execute_input":"2023-09-07T10:21:08.338260Z","iopub.status.idle":"2023-09-07T10:24:34.659585Z","shell.execute_reply.started":"2023-09-07T10:21:08.338234Z","shell.execute_reply":"2023-09-07T10:24:34.658322Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_image3 = sorted(os.listdir(\"/kaggle/input/segmentation-ksivar/train_aug/images/\"))\ntrain_main_mask_image3 = sorted(os.listdir(\"/kaggle/input/segmentation-ksivar/train_aug/masks/\"))\ntrain_main_image3 = np.array((read_image(\"/kaggle/input/segmentation-ksivar/train_aug/images/\",train_main_image3))).astype(\"float32\")/255.\ntrain_main_mask_image3 = np.array((read_mask_image(\"/kaggle/input/segmentation-ksivar/train_aug/masks/\",train_main_mask_image3))).astype(\"float32\")/255.","metadata":{"_uuid":"b218ac31-f23b-4b21-8e74-4cefaf4cdba1","_cell_guid":"5559421d-d2d7-47cb-8af2-7db51419da6a","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:24:34.665889Z","iopub.execute_input":"2023-09-07T10:24:34.666199Z","iopub.status.idle":"2023-09-07T10:26:59.290394Z","shell.execute_reply.started":"2023-09-07T10:24:34.666173Z","shell.execute_reply":"2023-09-07T10:26:59.289137Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_image4 = sorted(os.listdir(\"/kaggle/input/kvsair-seg/train_augmentation/train_augmentation/images/\"))[:60000]\ntrain_main_mask_image4 = sorted(os.listdir(\"/kaggle/input/kvsair-seg/train_augmentation/train_augmentation/masks/\"))[:60000]\ntrain_main_image4 = np.array((read_image(\"/kaggle/input/kvsair-seg/train_augmentation/train_augmentation/images/\",train_main_image4))).astype(\"float32\")/255.\ntrain_main_mask_image4 = np.array((read_mask_image(\"/kaggle/input/kvsair-seg/train_augmentation/train_augmentation/masks/\",train_main_mask_image4))).astype(\"float32\")/255.","metadata":{"_uuid":"9fef0167-dcc5-41c9-b0d1-e10009815e86","_cell_guid":"80fb56d4-1b35-4850-9c03-ae980ff1e0c6","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_image = np.concatenate((train_main_image1,train_main_image2,train_main_image3,train_main_image4),axis=0)","metadata":{"_uuid":"43094648-90a9-450d-a5a0-129e7da5c901","_cell_guid":"52b64b21-b392-4df0-a2d2-3da87c69a4a3","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:26:59.291660Z","iopub.execute_input":"2023-09-07T10:26:59.291957Z","iopub.status.idle":"2023-09-07T10:27:09.740463Z","shell.execute_reply.started":"2023-09-07T10:26:59.291930Z","shell.execute_reply":"2023-09-07T10:27:09.739433Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_mask_image = np.concatenate((train_main_mask_image1,train_main_mask_image2,train_main_mask_image3,train_main_mask_image4),axis=0)","metadata":{"_uuid":"07050d3e-2585-49e6-b277-d9a27bd8e567","_cell_guid":"f96e92c6-88f7-444a-b541-3d3ae873cb77","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:09.741766Z","iopub.execute_input":"2023-09-07T10:27:09.742064Z","iopub.status.idle":"2023-09-07T10:27:13.257151Z","shell.execute_reply.started":"2023-09-07T10:27:09.742037Z","shell.execute_reply":"2023-09-07T10:27:13.256016Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"del train_main_image1,train_main_image2,train_main_image3,train_main_mask_image1,train_main_mask_image2,train_main_mask_image3","metadata":{"_uuid":"63cfa2df-72e8-4924-91e8-dadbc505d27b","_cell_guid":"1d4d78e4-fa8d-4f35-a98e-187c54c81d1f","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_file = sorted(os.listdir(\"/kaggle/input/seg-new/test/images/\"))\n# valid_mask_file = sorted(os.listdir(\"/kaggle/input/seg-new/test/masks/\"))\n# valid_main_image = np.array((read_image(\"/kaggle/input/seg-new/test/images/\",valid_file))).astype(\"float32\")/255.\n# valid_main_mask_image = np.array((read_mask_image(\"/kaggle/input/seg-new/test/masks/\",valid_mask_file))).astype(\"float32\")/255.","metadata":{"_uuid":"1e0891ba-42c4-4c71-8dde-30b5958db858","_cell_guid":"6cdc19ff-5ace-4fcb-ae33-7e5575180782","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:13.258534Z","iopub.execute_input":"2023-09-07T10:27:13.258868Z","iopub.status.idle":"2023-09-07T10:27:13.263260Z","shell.execute_reply.started":"2023-09-07T10:27:13.258836Z","shell.execute_reply":"2023-09-07T10:27:13.262337Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_main_image = np.array((read_image(\"/kaggle/input/seg-new/test/images/\",valid_file))).astype(\"float32\")/255.\n# valid_main_mask_image = np.array((read_mask_image(\"/kaggle/input/seg-new/test/masks/\",valid_mask_file))).astype(\"float32\")/255.","metadata":{"_uuid":"f4183e55-69d2-4675-9404-3049ce826d3f","_cell_guid":"35d4de6b-2f9a-44a2-b6fd-88e78eb6c310","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:13.264532Z","iopub.execute_input":"2023-09-07T10:27:13.264831Z","iopub.status.idle":"2023-09-07T10:27:13.277131Z","shell.execute_reply.started":"2023-09-07T10:27:13.264803Z","shell.execute_reply":"2023-09-07T10:27:13.276067Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_main_image = get_train_image(valid_main_image,augmentation =True)\n# valid_main_mask_image = get_mask_image(valid_main_mask_image,augmentation =True)","metadata":{"_uuid":"b194f47e-a585-4c91-bd23-395246e8e853","_cell_guid":"41438cd2-cf94-4769-ac2b-0e6569fcb476","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:13.278370Z","iopub.execute_input":"2023-09-07T10:27:13.278673Z","iopub.status.idle":"2023-09-07T10:27:13.286001Z","shell.execute_reply.started":"2023-09-07T10:27:13.278646Z","shell.execute_reply":"2023-09-07T10:27:13.284957Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"plt.figure(figsize=(20,20)) # specifying the overall grid size\n\nfor i in range(100):\n    plt.subplot(10,10,i+1)    # the number of images in the grid is 5*5 (25)\n    plt.imshow(train_main_image[i])\n\nplt.show()","metadata":{"_uuid":"8c1c5529-7404-4b5b-bffe-d3986f3d8316","_cell_guid":"61272b45-00d2-4928-adce-a7bbddfc5c16","trusted":true,"collapsed":false,"papermill":{"duration":0.076622,"end_time":"2023-06-04T22:19:15.736047","exception":false,"start_time":"2023-06-04T22:19:15.659425","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:13.286975Z","iopub.execute_input":"2023-09-07T10:27:13.287261Z","iopub.status.idle":"2023-09-07T10:27:26.445170Z","shell.execute_reply.started":"2023-09-07T10:27:13.287233Z","shell.execute_reply":"2023-09-07T10:27:26.444019Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"plt.figure(figsize=(20,20)) # specifying the overall grid size\n\nfor i in range(100):\n    plt.subplot(10,10,i+1)    # the number of images in the grid is 5*5 (25)\n    plt.imshow(train_main_mask_image[i],cmap= \"gray\")\n\nplt.show()","metadata":{"_uuid":"fef580d2-4f9e-4520-b588-ab483552ca93","_cell_guid":"ec1d0100-13f9-463c-8ee0-58754660fada","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:26.446631Z","iopub.execute_input":"2023-09-07T10:27:26.447001Z","iopub.status.idle":"2023-09-07T10:27:38.237407Z","shell.execute_reply.started":"2023-09-07T10:27:26.446972Z","shell.execute_reply":"2023-09-07T10:27:38.236231Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# plt.figure(figsize=(20,20)) # specifying the overall grid size\n\n# for i in range(100):\n#     plt.subplot(10,10,i+1)    # the number of images in the grid is 5*5 (25)\n#     plt.imshow(valid_main_image[i])\n\n# plt.show()","metadata":{"_uuid":"f8a2ae1f-c0ce-4522-96b5-928e08c06e54","_cell_guid":"11d9ea69-a9b0-4015-b060-acafc43b43db","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.238808Z","iopub.execute_input":"2023-09-07T10:27:38.239117Z","iopub.status.idle":"2023-09-07T10:27:38.243396Z","shell.execute_reply.started":"2023-09-07T10:27:38.239090Z","shell.execute_reply":"2023-09-07T10:27:38.242462Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# plt.figure(figsize=(20,20)) # specifying the overall grid size\n\n# for i in range(100):\n#     plt.subplot(10,10,i+1)    # the number of images in the grid is 5*5 (25)\n#     plt.imshow(valid_main_mask_image[i],cmap= \"gray\")\n\n# plt.show()","metadata":{"_uuid":"5361b366-25d4-4836-ad25-9d21977a9257","_cell_guid":"1e8dc332-9ba3-4c05-9e23-c261c6291e28","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.244613Z","iopub.execute_input":"2023-09-07T10:27:38.244982Z","iopub.status.idle":"2023-09-07T10:27:38.254696Z","shell.execute_reply.started":"2023-09-07T10:27:38.244954Z","shell.execute_reply":"2023-09-07T10:27:38.253587Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# train_main_mask_image.dtype","metadata":{"_uuid":"1cea8964-c97d-4f6c-9ec4-9c2120a640a9","_cell_guid":"126e23e0-bdfd-4784-a252-56e58fe665e6","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.255909Z","iopub.execute_input":"2023-09-07T10:27:38.256215Z","iopub.status.idle":"2023-09-07T10:27:38.263330Z","shell.execute_reply.started":"2023-09-07T10:27:38.256187Z","shell.execute_reply":"2023-09-07T10:27:38.262312Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# train_main_image.dtype","metadata":{"_uuid":"8096df74-bff4-4688-a9fe-55994a15f8d1","_cell_guid":"df221867-68e6-46d8-a524-9601582a3098","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.264487Z","iopub.execute_input":"2023-09-07T10:27:38.264756Z","iopub.status.idle":"2023-09-07T10:27:38.271126Z","shell.execute_reply.started":"2023-09-07T10:27:38.264731Z","shell.execute_reply":"2023-09-07T10:27:38.270232Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_main_mask_image.dtype","metadata":{"_uuid":"eae5d4db-9b68-4f24-8515-d71e5904bd24","_cell_guid":"977745b1-c4d9-49b8-a2c6-28579a8f39db","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.272147Z","iopub.execute_input":"2023-09-07T10:27:38.272428Z","iopub.status.idle":"2023-09-07T10:27:38.279737Z","shell.execute_reply.started":"2023-09-07T10:27:38.272402Z","shell.execute_reply":"2023-09-07T10:27:38.278813Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_main_image.dtype","metadata":{"_uuid":"a3182771-8d14-4983-9eb4-440bdd4f6d48","_cell_guid":"d8981d4e-1eb1-4569-85b7-2ca79ec89c96","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.281083Z","iopub.execute_input":"2023-09-07T10:27:38.281368Z","iopub.status.idle":"2023-09-07T10:27:38.287494Z","shell.execute_reply.started":"2023-09-07T10:27:38.281341Z","shell.execute_reply":"2023-09-07T10:27:38.286519Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"train_main_mask_image = train_main_mask_image.reshape(train_main_mask_image.shape[0],256,256,1)\ntrain_main_mask_image.shape","metadata":{"_uuid":"67354b99-6f7d-4e18-bd7b-32f3292df494","_cell_guid":"2a0a5429-5859-4b76-a852-d72886bbe0b6","trusted":true,"collapsed":false,"papermill":{"duration":0.083049,"end_time":"2023-06-04T22:25:44.377196","exception":false,"start_time":"2023-06-04T22:25:44.294147","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:38.288721Z","iopub.execute_input":"2023-09-07T10:27:38.289083Z","iopub.status.idle":"2023-09-07T10:27:38.297940Z","shell.execute_reply.started":"2023-09-07T10:27:38.289055Z","shell.execute_reply":"2023-09-07T10:27:38.296908Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"# valid_main_mask_image = valid_main_mask_image.reshape(valid_main_mask_image.shape[0],256,256,1)\n# valid_main_mask_image.shape","metadata":{"_uuid":"b72307bc-8cd0-4826-8af6-c1df5c49d2aa","_cell_guid":"6f8a2f5b-3a6d-432c-8a73-6417544e4590","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:38.299178Z","iopub.execute_input":"2023-09-07T10:27:38.299509Z","iopub.status.idle":"2023-09-07T10:27:38.305602Z","shell.execute_reply.started":"2023-09-07T10:27:38.299481Z","shell.execute_reply":"2023-09-07T10:27:38.304615Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"import tensorflow as tf\n\n# try: # detect TPUs\ntpu = tf.distribute.cluster_resolver.TPUClusterResolver.connect(\"local\") # TPU detection\nstrategy = tf.distribute.TPUStrategy(tpu)\n# except ValueError: # detect GPUs\n# strategy = tf.distribute.MirroredStrategy() # for GPU or multi-GPU machines\n\nprint(\"Number of accelerators: \", strategy.num_replicas_in_sync)","metadata":{"_uuid":"0be45736-d8e0-41ee-bd7a-821af5e3b101","_cell_guid":"b807f76a-d1e6-4c0a-a84d-373cc18938eb","trusted":true,"collapsed":false,"papermill":{"duration":9.780845,"end_time":"2023-06-04T22:25:54.227752","exception":false,"start_time":"2023-06-04T22:25:44.446907","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:38.306883Z","iopub.execute_input":"2023-09-07T10:27:38.307296Z","iopub.status.idle":"2023-09-07T10:27:47.170186Z","shell.execute_reply.started":"2023-09-07T10:27:38.307253Z","shell.execute_reply":"2023-09-07T10:27:47.168927Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"import tensorflow as tf\nimport tensorflow.keras\nfrom tensorflow.keras.models import *\nfrom tensorflow.keras.layers import *\nfrom tensorflow.keras.optimizers import *\nfrom tensorflow.keras import backend as K\nfrom tensorflow.keras.preprocessing.image import ImageDataGenerator\nfrom tensorflow.keras.callbacks import ModelCheckpoint, LearningRateScheduler\nfrom tensorflow.keras.callbacks import ModelCheckpoint, LearningRateScheduler, EarlyStopping, ReduceLROnPlateau\nfrom tensorflow.keras.callbacks import ModelCheckpoint\n\n\ndef dice_coef(y_true, y_pred):\n    y_true_f = K.flatten(y_true)\n    y_pred_f = K.flatten(y_pred)\n    intersection = K.sum(y_true_f * y_pred_f)\n    return (2. * intersection + 1) / (K.sum(y_true_f) + K.sum(y_pred_f) + 1)\n\ndef dice_coef_loss(y_true, y_pred):\n    return 1 - dice_coef(y_true, y_pred)\n\ndef jaccard_coef(y_true, y_pred):\n    y_true_f = K.flatten(y_true)\n    y_pred_f = K.flatten(y_pred)\n    intersection = K.sum(y_true_f * y_pred_f)\n    return (intersection + 1.0) / (K.sum(y_true_f) + K.sum(y_pred_f) - intersection + 1.0)\n\ndef jaccard_coef_loss(y_true, y_pred):\n    return 1 - jaccard_coef(y_true, y_pred) \n\ndef sensitivity( y_true, y_pred):\n        true_positives = K.sum(K.round(K.clip(y_true * y_pred, 0, 1)))\n        possible_positives = K.sum(K.round(K.clip(y_true, 0, 1)))\n        return true_positives / (possible_positives + K.epsilon())\n\ndef specificity( y_true, y_pred):\n    true_negatives = K.sum(\n        K.round(K.clip((1 - y_true) * (1 - y_pred), 0, 1)))\n    possible_negatives = K.sum(K.round(K.clip(1 - y_true, 0, 1)))\n    return true_negatives / (possible_negatives + K.epsilon())\n\ndef f1_score(y_true, y_pred):\n    y_true = K.flatten(y_true)\n    y_pred = K.flatten(y_pred)\n    tp = K.sum(y_true * y_pred)\n    fp = K.sum((1 - y_true) * y_pred)\n    fn = K.sum(y_true * (1 - y_pred))\n\n    precision = tp / (tp + fp + K.epsilon())\n    recall = tp / (tp + fn + K.epsilon())\n\n    f1 = 2 * (precision * recall) / (precision + recall + K.epsilon())\n    \n    return f1","metadata":{"_uuid":"e54c5302-0b63-427d-b824-fadf21499eb3","_cell_guid":"417a462f-46d6-427b-ab0d-7d60e97ad817","trusted":true,"collapsed":false,"papermill":{"duration":0.303736,"end_time":"2023-06-04T22:25:54.610827","exception":false,"start_time":"2023-06-04T22:25:54.307091","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:47.171645Z","iopub.execute_input":"2023-09-07T10:27:47.171954Z","iopub.status.idle":"2023-09-07T10:27:47.528818Z","shell.execute_reply.started":"2023-09-07T10:27:47.171925Z","shell.execute_reply":"2023-09-07T10:27:47.527093Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"metrics = [dice_coef, jaccard_coef,sensitivity,specificity,f1_score]\n\nloss = [dice_coef_loss]","metadata":{"_uuid":"8ff4bb2f-0af9-4f38-ac27-9365cb11e192","_cell_guid":"7820a037-5b11-47b8-a0ba-c0f557982594","trusted":true,"collapsed":false,"papermill":{"duration":0.086774,"end_time":"2023-06-04T22:25:55.141888","exception":false,"start_time":"2023-06-04T22:25:55.055114","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:47.533996Z","iopub.execute_input":"2023-09-07T10:27:47.534303Z","iopub.status.idle":"2023-09-07T10:27:47.540103Z","shell.execute_reply.started":"2023-09-07T10:27:47.534264Z","shell.execute_reply":"2023-09-07T10:27:47.538716Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"import os\nimport shutil\n# os.mkdir(\"/kaggle/working/imagenet\")\nos.mkdir(\"/kaggle/working/imagenet\")\nfiles = os.listdir(\"/kaggle/input/results-9-20/imagenet/\")\nfor i in files:\n    shutil.copy(\"/kaggle/input/results-9-20/imagenet/\"+i,\"/kaggle/working/imagenet/\")","metadata":{"_uuid":"5f3d5e92-97cb-496a-82b5-53b30b9c90fc","_cell_guid":"1c4b968a-a7c3-4234-906f-7852eba71847","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"import tensorflow as tf\nimport numpy as np\nimport pickle \nimport math\nimport cv2\nimport matplotlib.pyplot as plt\nfrom sklearn.metrics import auc\nfrom sklearn.metrics import confusion_matrix\nfrom sklearn.metrics import roc_curve, roc_auc_score, precision_recall_curve\nfrom sklearn.model_selection import train_test_split\nfrom tensorflow.keras.callbacks import LearningRateScheduler\nfrom scipy.ndimage.interpolation import zoom\nfrom tensorflow.keras.models import Model\nfrom tensorflow.keras.metrics import categorical_accuracy\nfrom tensorflow.keras.optimizers import Adam,SGD,Adamax,RMSprop\nfrom tensorflow.keras.models import load_model\nfrom tensorflow.keras import backend as K\nfrom tensorflow.keras.layers import Conv2D,Add,Concatenate,MaxPooling2D,Activation,GlobalAveragePooling2D\nfrom tensorflow.keras.layers import Dropout,Cropping2D, Input,DepthwiseConv2D, AveragePooling2D, Flatten, Dense, Reshape, BatchNormalization,Multiply\nfrom tensorflow.keras.layers import UpSampling2D,ZeroPadding2D,Dot,Lambda\nfrom tensorflow.keras.regularizers import l2,l1\nfrom sklearn.model_selection import train_test_split, StratifiedShuffleSplit\nfrom tensorflow.keras.callbacks import Callback, EarlyStopping, ReduceLROnPlateau\nimport albumentations as albu","metadata":{"_uuid":"54a8ee6f-7f06-4b99-9d55-9a53fda9930a","_cell_guid":"d3efbd80-b6d8-4eec-80a3-750d2ec7ede7","trusted":true,"collapsed":false,"execution":{"iopub.status.busy":"2023-09-07T10:27:47.541347Z","iopub.execute_input":"2023-09-07T10:27:47.541617Z","iopub.status.idle":"2023-09-07T10:27:47.907762Z","shell.execute_reply.started":"2023-09-07T10:27:47.541591Z","shell.execute_reply":"2023-09-07T10:27:47.906539Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"\nimport tensorflow as tf\nfrom tensorflow.keras.layers import Layer, LayerNormalization, Activation\nfrom tensorflow.keras.initializers import HeUniform, RandomNormal\n\nclass CLTM(tf.keras.layers.Layer):\n    def __init__(self,\n                 d_token=64,\n                 mixer=\"circulant\",\n                 activation=\"elu\",\n                 **kwargs):\n        super().__init__(**kwargs)\n        if mixer not in (\"circulant\",\"fft\"):\n            raise ValueError(\"mixer must be 'circulant' or 'fft'\")\n        self.d = d_token\n        self.mixer = mixer\n        self.activation = Activation(activation)\n\n    def build(self, input_shapes):\n        # Q/P projections\n        self.proj_q = []\n        self.proj_p = []\n        for i, shp in enumerate(input_shapes):\n            c = int(shp[-1])\n            self.proj_q.append(self.add_weight(\n                name=f\"proj_q_{i}\", shape=(c, self.d),\n                initializer=HeUniform(), trainable=True))\n            self.proj_p.append(self.add_weight(\n                name=f\"proj_p_{i}\", shape=(self.d, c),\n                initializer=HeUniform(), trainable=True))\n        # circulant mixer kernel + norms\n        if self.mixer == \"circulant\":\n            self.kernel = self.add_weight(\n                name=\"mixer_kernel\",\n                shape=(5,1,self.d,1),\n                initializer=RandomNormal(stddev=0.01),\n                trainable=True)\n            self.pre_norm  = LayerNormalization(name=\"pre_norm\")\n            self.post_norm = LayerNormalization(name=\"post_norm\")\n        # per-branch output norms\n        self.out_norms = [\n            LayerNormalization(name=f\"out_norm_{i}\")\n            for i in range(len(input_shapes))\n        ]\n        super().build(input_shapes)\n\n    def call(self, inputs):\n        # 1) project each feature-map into tokens\n        tokens = []\n        shapes = []\n        for x, Q in zip(inputs, self.proj_q):\n            B,H,W,C = tf.unstack(tf.shape(x))\n            # [B, H*W, C] @ [C, d] -> [B, H*W, d]\n            t = tf.reshape(x, [B, H*W, C]) @ Q\n            tokens.append(t)\n            shapes.append((H,W))\n        # 2) concat all tokens and mix\n        Z = tf.concat(tokens, axis=1)\n        # scale down magnitude\n        Z = Z * tf.math.rsqrt(tf.cast(self.d, Z.dtype))\n        if self.mixer == \"circulant\":\n            Z = tf.expand_dims(Z, 2)\n            Z = self.pre_norm(Z)\n            Z = tf.nn.depthwise_conv2d(Z, self.kernel,\n                                       strides=[1,1,1,1],\n                                       padding=\"SAME\")\n            Z = self.post_norm(Z)\n            Z = tf.squeeze(Z, 2)\n            Z = tf.clip_by_value(Z, -5.0, 5.0)\n        else:\n            Zc = tf.signal.fft(tf.cast(Z, tf.complex64))\n            Z  = tf.math.real(tf.signal.ifft(Zc))\n        # 3) split back and re-project + residual + normalize + activate\n        outputs = []\n        idx = 0\n        for i, ((H,W), P, x) in enumerate(zip(shapes, self.proj_p, inputs)):\n            S = H*W\n            part = Z[:, idx:idx+S, :] @ P        # [B, S, C]\n            idx += S\n            part = tf.reshape(part, [-1, H, W, P.shape[-1]])\n            out  = x + part                      # residual\n            out  = self.out_norms[i](out)       # re-normalize\n            out  = self.activation(out)         # re-activate\n            outputs.append(out)\n        return outputs","metadata":{"_uuid":"bedb4cc4-14af-4761-bbc4-dca5c39cf864","_cell_guid":"baedc2c4-579c-4670-a912-5e6752f518e8","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"init = \"he_uniform\"\n\nactivation  = \"elu\" \nbias = False\ndrop_out=.15\n\n\n\n\ndef REPETED_BLOCK(input_data,filter,K,activation,bias,drop_out,init,expand_ratio,regulizer,names,prefix ='', add= True):\n\n    F1 = filter*expand_ratio\n    if expand_ratio>1:\n    \n        conv1 = Conv2D(F1,(1,1),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        name =names+\"_conv_1_\"+prefix,\n                       kernel_regularizer=l2(regulizer),\n                        kernel_initializer=init)(input_data)\n        conv = BatchNormalization(axis=3)(conv1)\n        conv = Activation(activation)(conv)\n        \n        \n    else: \n        conv= input_data\n\n    conv2 = DepthwiseConv2D((K,K),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        name =names+\"_DWC_\"+prefix,\n                         depthwise_regularizer=l2(regulizer),\n                        depthwise_initializer=init)(conv)\n\n    conv22 = BatchNormalization(axis=3)(conv2)\n    conv2 = Activation(activation)(conv22)\n\n    conv = GlobalAveragePooling2D()(conv2)\n    \n    \n    \n    conv = Reshape((1,1,conv.shape[1]))(conv)\n    \n    \n\n    conv = Conv2D(conv.shape[3]//24,(1,1),strides=(1, 1),padding=\"same\",\n                        use_bias=False,\n                        activation =  activation,\n                        # name =names+\"_reshape_conv_1_\"+prefix,\n                        kernel_initializer=init,\n                        kernel_regularizer=l2(regulizer))(conv)\n    \n    conv = Conv2D(F1,(1,1),strides=(1, 1),padding=\"same\",\n                        use_bias=True,\n                        activation= \"sigmoid\",\n                        # name =names+\"_reshape_conv_2_\"+prefix,\n                        kernel_initializer=init,\n                        kernel_regularizer=l2(regulizer))(conv)\n\n    conv  = Multiply()([conv,conv2])\n\n    conv = Conv2D(filter,(1,1),\n                    strides=(1, 1),\n                    padding=\"same\",\n                    use_bias=bias,\n                    name =names+\"_conv_3_\"+prefix,\n                    kernel_regularizer=l2(regulizer),\n                    kernel_initializer=init)(conv)\n\n    \n    conv = BatchNormalization(axis=3)(conv)\n    conv = Dropout(drop_out)(conv)\n    if add ==True:\n        conv = Add()([conv,input_data])\n    \n\n    return conv\n\ndef REPETED_BLOCK_ONE(input_data,filter,K,activation,bias,drop_out,init,expand_ratio,regulizer,names,prefix ='', add= True):\n\n    F1 = filter*expand_ratio\n    if expand_ratio>1:\n    \n        conv1 = Conv2D(F1,(1,1),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        name =names+\"_conv_1_\"+prefix,\n                       kernel_regularizer=l2(regulizer),\n                        kernel_initializer=init)(input_data)\n        conv = BatchNormalization(axis=3)(conv1)\n        conv = Activation(activation)(conv)\n    else: \n        conv= input_data\n\n    conv2 = DepthwiseConv2D((K,K),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        name =names+\"_DWC_\"+prefix,\n                         depthwise_regularizer=l2(regulizer),\n                        depthwise_initializer=init)(conv)\n\n    conv22 = BatchNormalization(axis=3)(conv2)\n    conv2 = Activation(activation)(conv22)\n\n    conv = GlobalAveragePooling2D()(conv2)\n    conv = Reshape((1,1,conv.shape[1]))(conv)\n\n    conv = Conv2D(conv.shape[3]//24,(1,1),strides=(1, 1),padding=\"same\",\n                        use_bias=False,\n                        activation =  activation,\n                        # name =names+\"_reshape_conv_1_\"+prefix,\n                        kernel_initializer=init,\n                        kernel_regularizer=l2(regulizer))(conv)\n    conv = Conv2D(F1,(1,1),strides=(1, 1),padding=\"same\",\n                        use_bias=True,\n                        activation= \"sigmoid\",\n                        # name =names+\"_reshape_conv_2_\"+prefix,\n                        kernel_initializer=init,\n                        kernel_regularizer=l2(regulizer))(conv)\n\n    conv  = Multiply()([conv,conv2])\n\n    conv = Conv2D(filter,(1,1),\n                    strides=(1, 1),\n                    padding=\"same\",\n                    use_bias=bias,\n                    name =names+\"_conv_3_\"+prefix,\n                    kernel_regularizer=l2(regulizer),\n                    kernel_initializer=init)(conv)\n\n    \n    conv = BatchNormalization(axis=3)(conv)\n    conv = Dropout(drop_out)(conv)\n\n    return conv\n\n\n\n\ndef BLOCK(input_data,filter,K,activation,bias,drop_out,init,expand_ratio,regulizer,name,repeat, top= False):\n\n    \n    conv1 = DepthwiseConv2D((K,K),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        # name =names+\"_DWC_\"+prefix,\n                            depthwise_regularizer=l2(regulizer),\n                        depthwise_initializer=init)(input_data)\n\n    conv = BatchNormalization(axis=3)(conv1)\n    conv = Activation(activation)(conv)\n    print(\"---------\",repeat)\n    for i in range(repeat):\n        print(i)\n        conv =REPETED_BLOCK(conv,filter,K,activation,bias,drop_out,init,expand_ratio,regulizer,name,\"repeat----\"+str(i), True)\n    \n\n    conv = DepthwiseConv2D((K,K),\n                        strides=(1, 1),\n                        padding=\"same\",\n                        use_bias=bias,\n                        # name =names+\"_DWC_\"+prefix,\n                           depthwise_regularizer=l2(regulizer),\n                        depthwise_initializer=init)(conv)\n\n    conv = BatchNormalization(axis=3)(conv)\n    conv = Activation(activation)(conv)\n\n    # conv = Add()([conv,input_data])\n\n    return conv\n\n\n\ndef MODULE(input_data,init):\n        \n    conv = DepthwiseConv2D((5,5),strides=(1, 1),padding=\"same\",\n                           use_bias=False,\n                           depthwise_regularizer=l2(regulizer),\n                           depthwise_initializer=init)(input_data)\n    \n    \n    conv = BatchNormalization()(conv)\n    conv = Activation(\"elu\")(conv)\n\n    conv = ZeroPadding2D((2,2))(conv)\n\n    conv = DepthwiseConv2D((5,5),strides=(1, 1),padding=\"valid\",\n                           use_bias=False,\n                           depthwise_regularizer=l2(regulizer),\n                           depthwise_initializer=init)(conv)\n\n    conv = BatchNormalization()(conv)\n    conv = Activation(\"relu\")(conv)\n\n    return conv\n\n\ndef CONV_LAYER(input_data,F1,S,regulizer):\n    conv1 = Conv2D(F1,(1,1),\n                    strides=(S, S),\n                    padding=\"same\",\n                    use_bias=bias,\n                    kernel_regularizer=l2(regulizer),\n                    kernel_initializer=init)(input_data)\n\n    conv = BatchNormalization(axis=3)(conv1)\n    conv = Activation(\"elu\")(conv)\n# \n    return conv\n\n\n\ndef bn_act(x, act=True):\n    x = tf.keras.layers.BatchNormalization()(x)\n    if act == True:\n        x = tf.keras.layers.Activation(\"relu\")(x)\n    return x\n\ndef conv_block(x, filters, kernel_size=(3, 3), padding=\"same\", strides=1):\n    conv = bn_act(x)\n    conv = tf.keras.layers.Conv2D(filters, kernel_size, padding=padding, strides=strides)(conv)\n    return conv\n\ndef stem(x, filters, kernel_size=(3, 3), padding=\"same\", strides=1):\n    conv = tf.keras.layers.Conv2D(filters, kernel_size, padding=padding, strides=strides)(x)\n    conv = conv_block(conv, filters, kernel_size=kernel_size, padding=padding, strides=strides)\n    \n    shortcut = tf.keras.layers.Conv2D(filters, kernel_size=(1, 1), padding=padding, strides=strides)(x)\n    shortcut = bn_act(shortcut, act=False)\n    \n    output = tf.keras.layers.Add()([conv, shortcut])\n    return output\n\ndef residual_block(x, filters, kernel_size=(3, 3), padding=\"same\", strides=1):\n    res = conv_block(x, filters, kernel_size=kernel_size, padding=padding, strides=strides)\n    res = conv_block(res, filters, kernel_size=kernel_size, padding=padding, strides=1)\n    \n    shortcut = tf.keras.layers.Conv2D(filters, kernel_size=(1, 1), padding=padding, strides=strides)(x)\n    shortcut = bn_act(shortcut, act=False)\n    \n    output = tf.keras.layers.Add()([shortcut, res])\n    return output\n\ndef upsample_concat_block(x, xskip):\n    u = tf.keras.layers.UpSampling2D((2, 2))(x)\n    c = tf.keras.layers.Concatenate()([u, xskip])\n    return c\n\n\n\n\n\nr =1.32**2\nF1 = 32\nF2 = 24\nF3 =int(r*F2)\nF4 = int(r*F3)\nF5 =int(r*F4)\nF6 =int(r*F5)\nF7 =int(r*F6)\nF8 =int(r*F7)\nF9 =int(r*F8)\nF10 =int(r*F8)\nF11 = int(r*F10)\n\n\n\n\n\nr1 =1\nr2 =1\nr3 =1\nr4 =1\nr5 =1\nr6 =1\nr7 =1\nr8 =1\nr9 =1\nr10 =1\nr11 =1\n\nregulizer = 1e-4\n\nwith strategy.scope():\n    input_data =Input((256,256,3))\n    \n    conv = Conv2D(32,(3,3),strides=(1, 1),\n                padding=\"same\",\n                use_bias=False,\n                #   kernel_regularizer=l2(.000002),\n                kernel_initializer=init)(input_data)\n    conv = BatchNormalization(axis=3)(conv)\n    conv = Activation(\"elu\")(conv) #256\n    \n    conv1 = CONV_LAYER(conv,32,2,regulizer)\n    \n    conv_1 = BLOCK(conv1,F1,7,activation,bias,drop_out,init,6,regulizer,\"conv_1\",r1)\n    conv_1a = MODULE(conv_1,init)\n    conv_1a = Add()([conv_1a,conv_1]) #256\n    \n    # max_1  = AveragePooling2D()(conv_2)\n    \n    max_1 = CONV_LAYER(conv_1a,F2,2,regulizer)\n    conv_2 = BLOCK(max_1,F2,5,activation,bias,drop_out,init,6,regulizer,\"conv_3\",r2)\n    conv_2a =MODULE(conv_2,init)\n    conv_2a = Add()([conv_2a,max_1])\n    \n    print(\"777777\",conv_2a.shape)\n    \n    max_2 = CONV_LAYER(conv_2a,F3,2,regulizer)\n    conv_3 = BLOCK(max_2,F3,3,activation,bias,drop_out,init,6,regulizer,\"conv_5\",r3)\n    conv_3a =MODULE(conv_3,init)\n    conv_3a = Add()([conv_3a,max_2])\n    \n    \n    \n    max_3 = CONV_LAYER(conv_3a,F4,2,regulizer)\n    conv_4 = BLOCK(max_3,F4,3,activation,bias,drop_out,init,6,regulizer,\"conv_5a\",r4)\n    conv_4a =MODULE(conv_4,init)\n    conv_4a = Add()([conv_4a,max_3])\n    print(\"conv_4a\",conv_4a.shape)\n    \n    #     GAP1 = GlobalAveragePooling2D()(conv_4a)\n    \n    #     RESHAPE_1 = Reshape((1,1,GAP1.shape[1]))(GAP1)\n    \n    #     conv_7 = Conv2D(F2*.25,(1,1),strides=(1, 1),padding=\"same\",\n    #                         use_bias=True,\n    #                         activation = activation,\n    #                         kernel_initializer=init)(RESHAPE_1)\n    \n    #     conv_8 = Conv2D(F2,(1,1),strides=(1, 1),padding=\"same\",\n    #                         use_bias=True,\n    #                         activation=\"sigmoid\",\n    #                         kernel_initializer=init)(conv_7)\n    \n    #     ADD_1= Add()([conv_2a,conv_8])\n    #     print(ADD_1.shape)\n    \n    #     ADD_1 = CONV_LAYER(ADD_1,F5,1,regulizer)\n    \n    #     conv_5= BLOCK(ADD_1,F5,7,activation,bias,drop_out,init,6,regulizer,\"conv_1b\",r5)\n    #     conv_5a = MODULE(conv_5,init)\n    #     conv_5a = Add()([conv_5a,ADD_1])\n    \n    #     # max_1  = AveragePooling2D()(conv_2)\n    \n    #     max_4 = CONV_LAYER(conv_5a,F6,2,regulizer)\n    #     conv_6 = BLOCK(max_4,F6,5,activation,bias,drop_out,init,6,regulizer,\"conv_3b\",r6)\n    #     conv_6a =MODULE(conv_6,init)\n    #     conv_6a = Add()([conv_6a,max_4])\n    \n    #     max_5 = CONV_LAYER(conv_6a,F7,2,regulizer)\n    #     conv_7 = BLOCK(max_5,F7,3,activation,bias,drop_out,init,6,regulizer,\"conv_5b\",r7)\n    #     conv_7a =MODULE(conv_7,init)\n    #     conv_7a = Add()([conv_7a,max_5])\n    #     print(\"888888888888888\",conv_7a.shape)\n    \n    #     max_6 = CONV_LAYER(conv_7a,480,2,regulizer)\n    #     conv_8 = BLOCK(max_6,480,3,activation,bias,drop_out,init,6,regulizer,\"conv_5ab\",r7)\n    #     conv_8a =MODULE(conv_8,init)\n    #     conv_8a = Add()([conv_8a,max_6])\n    conv_8a = CONV_LAYER(conv_4a,512,2,regulizer)\n    print(conv_8a.shape)\n    max_7s = CONV_LAYER(conv_8a,512,2,regulizer)\n    print(max_7s.shape)\n    max_7 = Conv2D(512, (1, 1), activation='relu', padding='same')(max_7s)\n    max_7 = Conv2D(512, (1, 1), activation='relu', padding='same')(max_7)\n    \n    print(max_7.shape)\n    max_7,conv_8a, conv_2a,conv_3a, conv_1a, conv = CLTM(d_token=64, mixer=\"circulant\")(\n    [max_7,conv_8a, conv_2a, conv_3a,conv_1a, conv]\n    )\n    \n    # #     ## Decoder\n    u1 = upsample_concat_block(max_7, conv_8a)\n    d1 = residual_block(u1, F4)\n    print(\"d1\",d1.shape)\n    # d1 = residual_block(d1, F4)\n    #     d1 = residual_block(d1, F7)\n    #     d1 = residual_block(d1, F7)\n    #     d1 = residual_block(d1, F7)\n    \n    u2 = upsample_concat_block(d1, conv_4a)\n    d2 = residual_block(u2, F4)\n    # d2 = residual_block(d2, F4)\n    #     d2 = residual_block(d2, F6)\n    #     d2 = residual_block(d2, F6)\n    #     d2 = residual_block(d2, F6)\n    \n    u3 = upsample_concat_block(d2, conv_3a)\n    d3 = residual_block(u3, F3)\n    # d3 = residual_block(d3, F3)\n    #     d3 = residual_block(d3, F5)\n    #     d3 = residual_block(d3, F5)\n    #     d3 = residual_block(d3, F5)\n    \n    u4 = upsample_concat_block(d3, conv_2a)\n    d4 = residual_block(u4, F2)\n    # d4 = residual_block(d4, F2)\n    #     d4 = residual_block(d4, F4)\n    #     d4 = residual_block(d4, F4)\n    #     d4 = residual_block(d4, F4)\n    \n    \n    u5 = upsample_concat_block(d4, conv_1a)\n    d5 = residual_block(u5, F1)\n    # d5 = residual_block(d5, F1)\n    #     d5 = residual_block(d5, F1)\n    #     d5 = residual_block(d5, F1)\n    #     d5 = residual_block(d5, F1)\n    \n    \n    u5 = upsample_concat_block(d5, conv)\n    d5 = residual_block(u5, 32)\n    \n    outputs = tf.keras.layers.Conv2D(1, (1, 1), padding=\"same\", activation=\"sigmoid\")(d5)\n    \n    model = Model(inputs=input_data, outputs=outputs)\n    model.compile(optimizer=Adam(learning_rate=1e-4), loss=loss, metrics=metrics)\nmodel.summary()","metadata":{"_uuid":"bd166082-a695-4863-a482-512413c055c2","_cell_guid":"1cb85cae-10f5-47b9-acda-4b6e36f2c581","trusted":true,"collapsed":false,"papermill":{"duration":22.400513,"end_time":"2023-06-04T22:26:17.623568","exception":false,"start_time":"2023-06-04T22:25:55.223055","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:27:47.909504Z","iopub.execute_input":"2023-09-07T10:27:47.909797Z","iopub.status.idle":"2023-09-07T10:27:59.266976Z","shell.execute_reply.started":"2023-09-07T10:27:47.909770Z","shell.execute_reply":"2023-09-07T10:27:59.265627Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"weight_path=\"{}_res_unet.keras\".format('BEST')\n\n# reduceLROnPlat = ReduceLROnPlateau(monitor='val_loss', factor=0.5, \n#                                    patience=4, \n#                                    verbose=1, mode='min', epsilon=0.0001, cooldown=2, min_lr=1e-3)\n\n\nfrom tensorflow.keras.optimizers.schedules import ExponentialDecay\n\n# initial_learning_rate = 0.0135\n# decay_rate = .96\n\n# # Create an exponential learning rate scheduler\n# lr_schedule = ExponentialDecay(\n#     initial_learning_rate, decay_steps=5, decay_rate=decay_rate, staircase=True\n# )\n\n\ndecay_steps = 20\ninitial_learning_rate = .00075\nwarmup_steps = 1000\ntarget_learning_rate = 0.1\nlr_schedule = tf.keras.optimizers.schedules.CosineDecay(\n    initial_learning_rate, decay_steps\n)\n\n\n\nlr_callback = tf.keras.callbacks.LearningRateScheduler(\n    lr_schedule, verbose=True)\n\ncheckpoint = ModelCheckpoint(weight_path, monitor='val_loss', verbose=1, \n                             save_best_only=True, mode='auto')\nfilename='log.csv'\n\nback_up = tf.keras.callbacks.BackupAndRestore(\n    \"/kaggle/working/imagenet/\", save_freq=\"epoch\", delete_checkpoint=True\n)\n\nhistory_logger=tf.keras.callbacks.CSVLogger(filename, separator=\",\", append=True)\ncallbacks_list = [checkpoint,history_logger,back_up]","metadata":{"_uuid":"9fdfd77c-2d7a-4fcd-8ec3-0a8724d87981","_cell_guid":"f72c0b68-41f1-43f4-ae7d-b9c5c8915fe3","trusted":true,"collapsed":false,"papermill":{"duration":0.181031,"end_time":"2023-06-04T22:26:18.403392","exception":false,"start_time":"2023-06-04T22:26:18.222361","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:37:40.681397Z","iopub.execute_input":"2023-09-07T10:37:40.681773Z","iopub.status.idle":"2023-09-07T10:37:40.690579Z","shell.execute_reply.started":"2023-09-07T10:37:40.681744Z","shell.execute_reply":"2023-09-07T10:37:40.689590Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"res = model.fit(train_main_image,train_main_mask_image, \n                \n                validation_data=(valid_main_image,valid_main_mask_image), \n                batch_size=128, epochs=1000,\n                callbacks=callbacks_list)","metadata":{"_uuid":"85ec2afc-4ea3-4052-81d4-4ce906c1ff97","_cell_guid":"6991aac9-2b34-45a1-9b4d-a51f798e08ce","trusted":true,"collapsed":false,"papermill":{"duration":17827.96744,"end_time":"2023-06-05T03:23:26.541734","exception":false,"start_time":"2023-06-04T22:26:18.574294","status":"completed"},"tags":[],"execution":{"iopub.status.busy":"2023-09-07T10:37:42.859248Z","iopub.execute_input":"2023-09-07T10:37:42.859633Z","iopub.status.idle":"2023-09-07T14:37:56.661445Z","shell.execute_reply.started":"2023-09-07T10:37:42.859602Z","shell.execute_reply":"2023-09-07T14:37:56.660236Z"},"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"","metadata":{"_uuid":"1571d1be-37ef-4bd5-a26c-5e9537cd4d33","_cell_guid":"55076da4-9b40-4be5-9779-c3b6e448c4b8","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null},{"cell_type":"code","source":"","metadata":{"_uuid":"039d6c61-e6ad-4146-8fda-cb4e50eee5c0","_cell_guid":"20afed8c-c4a8-431e-9e39-dfe0f48faab2","trusted":true,"collapsed":false,"jupyter":{"outputs_hidden":false}},"outputs":[],"execution_count":null}]}