{"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":"016f1f15-ec07-47cf-97d9-2ab68ce2e98a"},"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":2209},{"cell_type":"code","source":"#!L\nimport code\nimport wideresnet\n\nimport importlib\nimportlib.reload(code)\nimportlib.reload(wideresnet)","metadata":{"cellId":"1qim2v1qdoam3c35w8v2oo","trusted":true},"outputs":[{"output_type":"display_data","data":{"text/plain":"<module 'wideresnet' from '/home/jupyter/work/resources/wideresnet.py'>"},"metadata":{}}],"execution_count":2210},{"cell_type":"code","source":"#!L\nseed = 228\ntorch.manual_seed(seed)\nnp.random.seed(seed)\ntorch.cuda.manual_seed(seed)\n\nexperiment_name = 'cifar'\n\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(device)\n\nmodel_path = f'{0}.pth.tar'\nnet = wideresnet.WideResNet(28, 10, widen_factor=10)\n\ncheckpoint = torch.load(model_path)\nnet.load_state_dict(checkpoint['state_dict'])\n\nnet = net.to(device)\nnet.eval()\n\nin_loader_test, out_loader_test, in_loader_gridsearch, out_loader_gridsearch = code.get_data_cifar()\n\nprint('Done!')","metadata":{"cellId":"v11nstr6n7hacib46bcw8t","trusted":true},"outputs":[{"output_type":"stream","name":"stdout","text":"cuda\nFiles already downloaded and verified\nInlier dataset total length: 10000\nOutlier dataset total length: 10000\n[3291, 9786, 9018, 1355, 6415, 5920, 2164, 3289, 6345, 5700]\n[5859, 1893, 3864, 102, 1500, 7807, 7930, 2098, 237, 9698]\nDone!\n"}],"execution_count":2211},{"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, mode='cifar')\n            s_out, g_out = code.get_s_and_g(eps, temper, _out_loader, net, device, silent=True, mode='cifar')\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":2212},{"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":"c0964558-ac75-41e0-ba34-28f2f99f82ca","trusted":true},"outputs":[],"execution_count":null},{"cell_type":"code","source":"#!g1.1\n","metadata":{"cellId":"dj9m2ee1wlm924r3r0vw8"},"outputs":[],"execution_count":null}]}