{"nbformat":4,"nbformat_minor":4,"metadata":{"accelerator":"GPU","colab":{"collapsed_sections":[],"name":"Копия lenet-mnist.ipynb","provenance":[]},"kernelspec":{"name":"python3","display_name":"Yandex DataSphere Kernel","language":"python"},"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.7.7"},"notebookId":"114f7cfe-0adb-4951-a79f-64efb80fc492"},"cells":[{"cell_type":"code","source":"#!L\nimport warnings\nwarnings.filterwarnings('ignore')\n\nimport torch\nimport torch.nn as nn\nimport torch.optim \nimport torch.nn.functional as F\nimport torchvision.datasets as datasets \nimport torchvision.transforms as transforms   \nimport torchvision.models as models\n\nimport numpy as np\nimport os","metadata":{"cellId":"7j7c6jno5jgfdom5jxq5st","trusted":true},"outputs":[],"execution_count":2175},{"cell_type":"code","source":"#!L\nimport code\n\nimport importlib\nimportlib.reload(code)","metadata":{"cellId":"1qim2v1qdoam3c35w8v2oo","trusted":true},"outputs":[{"output_type":"display_data","data":{"text/plain":"<module 'code' from '/home/jupyter/work/resources/code.py'>"},"metadata":{}}],"execution_count":2176},{"cell_type":"code","source":"#!L\nseed = 228\ntorch.manual_seed(seed)\nnp.random.seed(seed)\ntorch.cuda.manual_seed(seed)\n\ndataset = 'imagenet-c'\nexperiment_name = 'r50_iс_s_and_g'\n\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(device)\n\n# net = models.densenet161(pretrained=True).to(device)\n# net = models.resnet18(pretrained=True).to(device)\n\nnet = models.resnet50(pretrained=False).to(device)\nnet.load_state_dict(torch.load('re0.pth'))\n\nnet.eval()\nfilename = f'_{experiment_name}.txt'\n\nin_loader_test, out_loader_test = code.get_data(in_path='imagenet/val_repack/small_test', out_path=f'./{dataset}_repack/small_test')\nin_loader_gridsearch, out_loader_gridsearch = code.get_data(in_path='imagenet/val_repack/gridsearch', out_path=f'./{dataset}_repack/gridsearch')\n\nin_loader_huge_test, out_loader_huge_test = code.get_data(in_path='imagenet/val_repack/test', out_path=f'./{dataset}_repack/test')\n\nprint('Done!')","metadata":{"cellId":"v11nstr6n7hacib46bcw8t","trusted":true},"outputs":[{"output_type":"stream","name":"stdout","text":"cuda\nInlier dataset length: 2000\nOutlier dataset length: 2000\nInlier dataset length: 3000\nOutlier dataset length: 3000\nInlier dataset length: 45000\nOutlier dataset length: 45000\nDone!\n"}],"execution_count":2177},{"cell_type":"code","source":"#!g1.1\ndef gridsearch(_in_loader, _out_loader, net, device):\n    eps_list = np.linspace(0, 0.004, 21)\n    temper_list = np.array([1.0, 2.0, 5.0, 10.0, 20.0, 50.0, 100.0, 200.0, 500.0, 1000.0])\n\n    best_score_s = -1.0\n    best_params_s = (0.0, 1.0)\n    \n    best_score_g = -1.0\n    best_params_g = (0.0, 1.0)\n    \n    best_score_sg = -1.0\n    best_params_sg = (0.0, 1.0)\n    \n    for eps in eps_list:\n        for temper in temper_list:\n            s_in, g_in = code.get_s_and_g(eps, temper, _in_loader, net, device, silent=True)\n            s_out, g_out = code.get_s_and_g(eps, temper, _out_loader, net, device, silent=True)\n\n            thresholds = np.linspace(min(np.min(-s_in), np.min(-s_out)), max(np.max(-s_in), np.max(-s_out)), 10000)\n            roc_auc, fpr_at_95 = code.my_roc_auc_score(-s_in, -s_out, thresholds, graph=False)\n            if roc_auc >= best_score_s:\n                best_score_s = roc_auc\n                best_params_s = (eps, temper)\n            code.append_to_file(f'eps = {eps}, T = {temper}: roc-auc={roc_auc}, fpr at 95% tpr={fpr_at_95}'+'\\n', f'./{experiment_name}/s.txt')\n                \n            thresholds = np.linspace(min(np.min(g_in), np.min(g_out)), max(np.max(g_in), np.max(g_out)), 10000)\n            roc_auc, fpr_at_95 = code.my_roc_auc_score(g_in, g_out, thresholds, graph=False)\n            if roc_auc >= best_score_g:\n                best_score_g = roc_auc\n                best_params_g = (eps, temper)\n            code.append_to_file(f'eps = {eps}, T = {temper}: roc-auc={roc_auc}, fpr at 95% tpr={fpr_at_95}'+'\\n', f'./{experiment_name}/g.txt')\n                \n            sg_in = s_in * g_in\n            sg_out = s_out * g_out\n            thresholds = np.linspace(min(np.min(sg_in), np.min(sg_out)), max(np.max(sg_in), np.max(sg_out)), 10000)\n            roc_auc, fpr_at_95 = code.my_roc_auc_score(sg_in, sg_out, thresholds, graph=False)\n            if roc_auc >= best_score_sg:\n                best_score_sg = roc_auc\n                best_params_sg = (eps, temper)\n            code.append_to_file(f'eps = {eps}, T = {temper}: roc-auc={roc_auc}, fpr at 95% tpr={fpr_at_95}'+'\\n', f'./{experiment_name}/sg.txt')\n\n    code.append_to_file(f'best score = {best_score_s} is when eps = {best_params_s[0]}, T = {best_params_s[1]}'+'\\n', f'./{experiment_name}/s.txt')\n    code.append_to_file(f'best score = {best_score_g} is when eps = {best_params_g[0]}, T = {best_params_g[1]}'+'\\n', f'./{experiment_name}/g.txt')\n    code.append_to_file(f'best score = {best_score_sg} is when eps = {best_params_sg[0]}, T = {best_params_sg[1]}'+'\\n', f'./{experiment_name}/sg.txt')","metadata":{"cellId":"ic5nuriycrhkx1h9e0quuo","trusted":true},"outputs":[],"execution_count":2178},{"cell_type":"code","source":"#!g1.1\n%%time\ndirectory = f'./{experiment_name}'\nif not os.path.exists(directory):\n    os.makedirs(directory)\ngridsearch(in_loader_gridsearch, out_loader_gridsearch, net, device)","metadata":{"cellId":"nt1rkegssh9dgpsndd1g8i","execution_id":"7dc737f6-870f-4504-8c4d-fd18cedc9839","trusted":true},"outputs":[],"execution_count":null}]}