{"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":"6ac6c656-d7f6-416d-8b3f-588813dead6a"},"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":2216},{"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":2217},{"cell_type":"code","source":"#!g1.1\ndef ablation(_experiment_name, _eps_list, _temper_list, _dataset):\n    seed = 228\n    torch.manual_seed(seed)\n    np.random.seed(seed)\n    torch.cuda.manual_seed(seed)\n\n    device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n    \n    net = models.resnet50(pretrained=False).to(device)\n    net.load_state_dict(torch.load('re0.pth'))\n#     net = models.resnet18(pretrained=True).to(device)\n    net.eval()\n    \n    in_loader_gridsearch, out_loader_gridsearch = code.get_data(in_path='imagenet/val_repack/gridsearch', out_path=f'./{_dataset}_repack/gridsearch')\n\n    if not os.path.exists('./ablation'):\n        os.makedirs('./ablation')\n        \n    directory = f'./ablation/{_experiment_name}'\n    if not os.path.exists(directory):\n        os.makedirs(directory)\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_gridsearch, net, device, silent=True)\n            s_out, g_out = code.get_s_and_g(eps, temper, out_loader_gridsearch, 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'./ablation/{_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'./ablation/{_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'./ablation/{_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'./ablation/{_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'./ablation/{_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'./ablation/{_experiment_name}/sg.txt')","metadata":{"cellId":"ic5nuriycrhkx1h9e0quuo","trusted":true},"outputs":[],"execution_count":2218},{"cell_type":"code","source":"#!g1.1\neps_ablation = np.linspace(0, 0.004, 21)\ntemper_ablation = np.array([1.0, 2.0, 5.0, 10.0, 20.0, 50.0, 100.0, 200.0, 500.0, 1000.0])\n\neps_dummy = np.array([0.0])\ntemper_dummy = np.array([1.0])","metadata":{"cellId":"8blz4hvduab3oo0hei33or","trusted":true},"outputs":[],"execution_count":2219},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_io_only_eps', eps_ablation, temper_dummy, 'imagenet-o')","metadata":{"cellId":"nt1rkegssh9dgpsndd1g8i","trusted":true},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 3000\nOutlier dataset length: 600\nCPU times: user 2h 21min 54s, sys: 3min 53s, total: 2h 25min 47s\nWall time: 2h 23min 14s\n"}],"execution_count":2220},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ir_only_eps', eps_ablation, temper_dummy, 'imagenet-r')","metadata":{"cellId":"mlq4200y4kn0tcvnk9zdo5","execution_id":"e18b0e62-def1-4c03-98ce-24bba17b21d8","trusted":true},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 3000\nOutlier dataset length: 600\n"}],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ia_only_eps', eps_ablation, temper_dummy, 'imagenet-a')","metadata":{"cellId":"j6r7ok8geuex6xpbv45pse","execution_id":"9bdd3675-2695-4235-854d-778d7824ff70","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ic_only_eps', eps_ablation, temper_dummy, 'imagenet-c')","metadata":{"cellId":"76nzn510no2pqmjl28eoc","execution_id":"574abb4f-162f-4bfc-b62e-dae3e4ee3b0f","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_io_only_temper', eps_dummy, temper_ablation, 'imagenet-o')","metadata":{"cellId":"3n1ff1kyj7rijx2dx43vd","execution_id":"e8491496-2dba-4fa0-985a-acbf21e91ab1","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ir_only_temper', eps_dummy, temper_ablation, 'imagenet-r')","metadata":{"cellId":"kqid6s005smckr0ovb7t5p","execution_id":"4c124053-838c-4db7-887d-b2fe611c2fc3","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ia_only_temper', eps_dummy, temper_ablation, 'imagenet-a')","metadata":{"cellId":"xj49z62cenqsx5yfk6euup","execution_id":"ec285e0c-18e3-451b-a410-d308c4eb7e2e","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n%%time\nablation('r50_ic_only_temper', eps_dummy, temper_ablation, 'imagenet-c')","metadata":{"cellId":"bff57l8ppxsh5n9luobzk","execution_id":"47532ab8-6b67-4faf-907b-269786c5f0d2","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n","metadata":{"cellId":"ttdssxafp2y6oabevdcki"},"outputs":[],"execution_count":null}]}