{"nbformat":4,"nbformat_minor":4,"metadata":{"language_info":{"name":"python","codemirror_mode":{"name":"ipython","version":3},"nbconvert_exporter":"python","version":"3.7.7","file_extension":".py","pygments_lexer":"ipython3","mimetype":"text/x-python"},"notebookId":"b6b3188d-a9a9-4000-987e-474483561732","kernelspec":{"name":"python3","display_name":"Yandex DataSphere Kernel","language":"python"}},"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"},"outputs":[],"execution_count":18},{"cell_type":"code","source":"#!L\nimport code\n\nimport importlib\nimportlib.reload(code)","metadata":{"cellId":"1qim2v1qdoam3c35w8v2oo"},"outputs":[{"output_type":"display_data","data":{"text/plain":"<module 'code' from '/home/jupyter/work/resources/code.py'>"},"metadata":{}}],"execution_count":19},{"cell_type":"code","source":"#!g1.1\ndef evaluate_ablation(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    os.mkdir(path)\n    \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    ### 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    if eps_g == eps_sg and t_g == t_sg:\n        in_sg_small_test = in_g_small_test\n        in_sg_big_test = in_g_big_test\n        out_sg_small_test = out_g_small_test\n        out_sg_big_test = out_g_big_test\n        print('I am skipping second computation because of equal params!')\n    else:\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"},"outputs":[],"execution_count":20},{"cell_type":"code","source":"#!g1.1\ndummy_t = 1.0\ndummy_eps = 0.0","metadata":{"cellId":"jbdzal0mn1h2d1i66a5f"},"outputs":[],"execution_count":21},{"cell_type":"code","source":"#!g1.1\nparams = {'eps_g': dummy_eps, 't_g': dummy_t, 'eps_sg': dummy_eps, 't_sg': dummy_t}\nevaluate_ablation('imagenet-a', 'resnet-18', params, 'ablation_r18_ia_vanilla')\n\n# params = {'eps_g': dummy_eps, 't_g': 2.0, 'eps_sg': dummy_eps, 't_sg': 1.0}\nevaluate_ablation('imagenet-a', 'resnet-50', params, 'ablation_r50_ia_vanilla')","metadata":{"cellId":"02fod4owvlj4q7zlhvsrg2a"},"outputs":[{"output_type":"stream","name":"stderr","text":"Downloading: \"https://download.pytorch.org/models/resnet18-5c106cde.pth\" to /tmp/xdg_cache/torch/hub/checkpoints/resnet18-5c106cde.pth\n"},{"output_type":"display_data","data":{"text/plain":"HBox(children=(HTML(value=''), FloatProgress(value=0.0, max=46827520.0), HTML(value='')))","application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"9de68dbb1764415781c763464e11f0c5"}},"metadata":{}},{"output_type":"stream","name":"stdout","text":"\nInlier dataset length: 2000\nOutlier dataset length: 395\nInlier dataset length: 45000\nOutlier dataset length: 6505\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\nInlier dataset length: 2000\nOutlier dataset length: 395\nInlier dataset length: 45000\nOutlier dataset length: 6505\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\n"}],"execution_count":22},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_g': dummy_eps, 't_g': dummy_t, 'eps_sg': 0.0, 't_sg': dummy_t}\nevaluate_ablation('imagenet-c', 'resnet-18', params, 'ablation_r18_ic_vanilla')\n\n# params = {'eps_g': dummy_eps, 't_g': 5.0, 'eps_sg': dummy_eps, 't_sg': 1.0}\nevaluate_ablation('imagenet-c', 'resnet-50', params, 'ablation_r50_ic_vanilla')","metadata":{"cellId":"td83oq5f5vjjgjf82bruxq"},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 2000\nOutlier dataset length: 2000\nInlier dataset length: 45000\nOutlier dataset length: 45000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\nInlier dataset length: 2000\nOutlier dataset length: 2000\nInlier dataset length: 45000\nOutlier dataset length: 45000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\n"}],"execution_count":23},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_g': 0.0, 't_g': dummy_t, 'eps_sg': 0.0, 't_sg': dummy_t}\nevaluate_ablation('imagenet-o', 'resnet-18', params, 'ablation_r18_io_vanilla')\n\n# params = {'eps_g': dummy_eps, 't_g': 20.0, 'eps_sg': dummy_eps, 't_sg': 2.0}\nevaluate_ablation('imagenet-o', 'resnet-50', params, 'ablation_r50_io_vanilla')","metadata":{"cellId":"cha53q0v515h6007kadlhm"},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 2000\nOutlier dataset length: 400\nInlier dataset length: 45000\nOutlier dataset length: 1000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\nInlier dataset length: 2000\nOutlier dataset length: 400\nInlier dataset length: 45000\nOutlier dataset length: 1000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\n"}],"execution_count":24},{"cell_type":"code","source":"#!g1.1\n# params = {'eps_g': 0.0002, 't_g': dummy_t, 'eps_sg': 0.0002, 't_sg': dummy_t}\nevaluate_ablation('imagenet-r', 'resnet-18', params, 'ablation_r18_ir_vanilla')\n\n# params = {'eps_g': dummy_eps, 't_g': 5.0, 'eps_sg': dummy_eps, 't_sg': 2.0}\nevaluate_ablation('imagenet-r', 'resnet-50', params, 'ablation_r50_ir_vanilla')","metadata":{"cellId":"ru5mp9k6jfmiuv6m7uwe5n"},"outputs":[{"output_type":"stream","name":"stdout","text":"Inlier dataset length: 2000\nOutlier dataset length: 400\nInlier dataset length: 45000\nOutlier dataset length: 29000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\nInlier dataset length: 2000\nOutlier dataset length: 400\nInlier dataset length: 45000\nOutlier dataset length: 29000\ng_part finished!\nI am skipping second computation because of equal params!\nsg_part finished!\n"}],"execution_count":25},{"cell_type":"code","source":"#!g1.1\n","metadata":{"cellId":"y9ltt0qltc385dpsrbs1t"},"outputs":[],"execution_count":null}]}