{"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":"361e3d09-2357-4836-be98-f2692b98468a"},"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","metadata":{"cellId":"7j7c6jno5jgfdom5jxq5st","trusted":true},"outputs":[],"execution_count":2259},{"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":2260},{"cell_type":"code","source":"#!g1.1\ndef evaluate_and_bootstrap(dataset, model, method_params, path):\n    seed = 228\n    torch.manual_seed(seed)\n    np.random.seed(seed)\n    torch.cuda.manual_seed(seed)\n    \n    eps_s = method_params['eps_s']\n    t_s = method_params['t_s']\n    eps_g = method_params['eps_g']\n    t_g = method_params['t_g']\n    eps_sg = method_params['eps_sg']\n    t_sg = method_params['t_sg']\n    \n    device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n    \n    if model == 'resnet-18':\n        net = models.resnet18(pretrained=True).to(device)\n    else:\n        net = models.resnet50(pretrained=False).to(device)\n        net.load_state_dict(torch.load('re0.pth'))\n        \n    net.eval()\n    \n    in_loader_small_test, out_loader_small_test = code.get_data(in_path='imagenet/val_repack/small_test', out_path=f'./{dataset}_repack/small_test')\n    in_loader_big_test, out_loader_big_test = code.get_data(in_path='imagenet/val_repack/test', out_path=f'./{dataset}_repack/test')\n        \n    ### msp ###\n    in_msp_small_test = code.baseline(in_loader_small_test, net, device, silent=True)\n    out_msp_small_test = code.baseline(out_loader_small_test, net, device, silent=True)\n    in_msp_big_test = code.baseline(in_loader_big_test, net, device, silent=True)\n    out_msp_big_test = code.baseline(out_loader_big_test, net, device, silent=True)\n    \n    in_msp_total_test = np.hstack((in_msp_small_test, in_msp_big_test))\n    out_msp_total_test = np.hstack((out_msp_small_test, out_msp_big_test))\n    \n    code.save_and_bootstrap(path, 'msp', in_msp_total_test, out_msp_total_test, bootstrap_num=100)\n    print('msp finished!')\n    ### msp ###\n    \n    ### ml ###\n    in_ml_small_test = code.max_logit(in_loader_small_test, net, device, silent=True)\n    out_ml_small_test = code.max_logit(out_loader_small_test, net, device, silent=True)\n    in_ml_big_test = code.max_logit(in_loader_big_test, net, device, silent=True)\n    out_ml_big_test = code.max_logit(out_loader_big_test, net, device, silent=True)\n    \n    in_ml_total_test = np.hstack((in_ml_small_test, in_ml_big_test))\n    out_ml_total_test = np.hstack((out_ml_small_test, out_ml_big_test))\n    \n    code.save_and_bootstrap(path, 'ml', in_ml_total_test, out_ml_total_test, bootstrap_num=100)\n    print('ml finished!')\n    ### ml ###\n    \n    ### s ###\n    in_s_small_test, _ = code.get_s_and_g(eps_s, t_s, in_loader_small_test, net, device, silent=True)\n    in_s_big_test, _ = code.get_s_and_g(eps_s, t_s, in_loader_big_test, net, device, silent=True)\n    \n    out_s_small_test, _ = code.get_s_and_g(eps_s, t_s, out_loader_small_test, net, device, silent=True)\n    out_s_big_test, _ = code.get_s_and_g(eps_s, t_s, out_loader_big_test, net, device, silent=True)\n    \n    in_s_total_test = -np.hstack((in_s_small_test, in_s_big_test))\n    out_s_total_test = -np.hstack((out_s_small_test, out_s_big_test))\n    \n    code.save_and_bootstrap(path, 's_part', in_s_total_test, out_s_total_test, bootstrap_num=100)\n    print('s_part finished!')\n    ### s ###\n    \n    ### g ###\n    _, in_g_small_test = code.get_s_and_g(eps_g, t_g, in_loader_small_test, net, device, silent=True)\n    _, in_g_big_test = code.get_s_and_g(eps_g, t_g, in_loader_big_test, net, device, silent=True)\n    \n    _, out_g_small_test = code.get_s_and_g(eps_g, t_g, out_loader_small_test, net, device, silent=True)\n    _, out_g_big_test = code.get_s_and_g(eps_g, t_g, out_loader_big_test, net, device, silent=True)\n    \n    in_g_total_test = np.hstack((in_g_small_test, in_g_big_test))\n    out_g_total_test = np.hstack((out_g_small_test, out_g_big_test))\n    \n    code.save_and_bootstrap(path, 'g_part', in_g_total_test, out_g_total_test, bootstrap_num=100)\n    print('g_part finished!')\n    ### g ###\n    \n    \n    ### sg ###\n    a, b = code.get_s_and_g(eps_sg, t_sg, in_loader_small_test, net, device, silent=True)\n    in_sg_small_test = a * b\n    a, b = code.get_s_and_g(eps_sg, t_sg, in_loader_big_test, net, device, silent=True)\n    in_sg_big_test = a * b\n    \n    a, b = code.get_s_and_g(eps_sg, t_sg, out_loader_small_test, net, device, silent=True)\n    out_sg_small_test = a * b\n    a, b = code.get_s_and_g(eps_sg, t_sg, out_loader_big_test, net, device, silent=True)\n    out_sg_big_test = a * b\n    \n    in_sg_total_test = np.hstack((in_sg_small_test, in_sg_big_test))\n    out_sg_total_test = np.hstack((out_sg_small_test, out_sg_big_test))\n    \n    code.save_and_bootstrap(path, 'sg_part', in_sg_total_test, out_sg_total_test, bootstrap_num=100)\n    print('sg_part finished!')\n    ### sg ###","metadata":{"cellId":"fv8p2lc43mp4o0u39qeel","trusted":true},"outputs":[],"execution_count":2261},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0004, 't_s': 1000.0, 'eps_g': 0.001, 't_g': 10.0, 'eps_sg': 0.0008, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-r', 'resnet-18', params, 'r18_ir_s_and_g')","metadata":{"cellId":"02fod4owvlj4q7zlhvsrg2a","trusted":true},"outputs":[],"execution_count":2262},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0, 't_s': 2.0, 'eps_g': 0.0, 't_g': 2.0, 'eps_sg': 0.0008, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-a', 'resnet-18', params, 'r18_ia_s_and_g')","metadata":{"cellId":"q09lp1qbudedfoq2lhwrf","trusted":true},"outputs":[],"execution_count":2263},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.004, 't_s': 20.0, 'eps_g': 0.0034, 't_g': 20.0, 'eps_sg': 0.004, 't_sg': 5.0}\n# evaluate_and_bootstrap('imagenet-o', 'resnet-18', params, 'r18_io_s_and_g')","metadata":{"cellId":"n9a6dcsjrm984mvr8cib43","trusted":true},"outputs":[],"execution_count":2264},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0, 't_s': 1000.0, 'eps_g': 0.0, 't_g': 5.0, 'eps_sg': 0.004, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-c', 'resnet-18', params, 'r18_ic_s_and_g')","metadata":{"cellId":"n18zcbbr3kds5xuqrrpa6","trusted":true},"outputs":[],"execution_count":2265},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0002, 't_s': 10.0, 'eps_g': 0.0022, 't_g': 10.0, 'eps_sg': 0.0006, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-r', 'resnet-50', params, 'r50_ir_s_and_g')","metadata":{"cellId":"wi3ziy2vcxpaoneqwb6667","trusted":true},"outputs":[],"execution_count":2266},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0, 't_s': 2.0, 'eps_g': 0.0, 't_g': 2.0, 'eps_sg': 0.0006, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-a', 'resnet-50', params, 'r50_ia_s_and_g')","metadata":{"cellId":"grr39tn0sunnwbcakxya","trusted":true},"outputs":[],"execution_count":2267},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.004, 't_s': 500.0, 'eps_g': 0.002, 't_g': 20.0, 'eps_sg': 0.0022, 't_sg': 5.0}\n# evaluate_and_bootstrap('imagenet-o', 'resnet-50', params, 'r50_io_s_and_g')","metadata":{"cellId":"4mpd7bu8o9f1espmi3onba","trusted":true},"outputs":[],"execution_count":2268},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_s': 0.0, 't_s': 1000.0, 'eps_g': 0.0, 't_g': 5.0, 'eps_sg': 0.004, 't_sg': 2.0}\n# evaluate_and_bootstrap('imagenet-c', 'resnet-50', params, 'r50_ic_s_and_g')","metadata":{"cellId":"1tittf0ukogvooe1pkkqtc","trusted":true},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 2000\nOutlier dataset length: 2000\nInlier dataset length: 45000\nOutlier dataset length: 45000\nmsp finished!\nml finished!\ns_part finished!\ng_part finished!\nsg_part finished!\n"}],"execution_count":2270},{"cell_type":"code","source":"#!g1.1\n","metadata":{"cellId":"td83oq5f5vjjgjf82bruxq"},"outputs":[],"execution_count":null}]}