{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6e2cd64d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/workspace/miniconda3/envs/torch/lib/python3.8/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import os\n",
    "from PIL import Image, ImageOps\n",
    "import requests\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "import torch\n",
    "import requests\n",
    "from tqdm import tqdm\n",
    "from io import BytesIO\n",
    "# from diffusers import StableDiffusionImg2ImgPipeline\n",
    "import torchvision.transforms as T\n",
    "\n",
    "# from utils import preprocess, recover_image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f0f243cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "to_pil = T.ToPILImage()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d07171fc",
   "metadata": {},
   "source": [
    "### First lets instantiate a stable diffusion model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "41808097",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from dataclasses import dataclass, field\n",
    "from einops import rearrange\n",
    "import os\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "\n",
    "import tgs\n",
    "from tgs.models.image_feature import ImageFeature\n",
    "from tgs.utils.saving import SaverMixin\n",
    "from tgs.utils.config import parse_structured\n",
    "from tgs.utils.ops import points_projection\n",
    "from tgs.utils.misc import load_module_weights\n",
    "from tgs.utils.typing import *\n",
    "\n",
    "class TGS(torch.nn.Module, SaverMixin):\n",
    "    @dataclass\n",
    "    class Config:\n",
    "        weights: Optional[str] = None\n",
    "        weights_ignore_modules: Optional[List[str]] = None\n",
    "\n",
    "        camera_embedder_cls: str = \"\"\n",
    "        camera_embedder: dict = field(default_factory=dict)\n",
    "\n",
    "        image_feature: dict = field(default_factory=dict)\n",
    "\n",
    "        image_tokenizer_cls: str = \"\"\n",
    "        image_tokenizer: dict = field(default_factory=dict)\n",
    "\n",
    "        tokenizer_cls: str = \"\"\n",
    "        tokenizer: dict = field(default_factory=dict)\n",
    "\n",
    "        backbone_cls: str = \"\"\n",
    "        backbone: dict = field(default_factory=dict)\n",
    "\n",
    "        post_processor_cls: str = \"\"\n",
    "        post_processor: dict = field(default_factory=dict)\n",
    "\n",
    "        renderer_cls: str = \"\"\n",
    "        renderer: dict = field(default_factory=dict)\n",
    "\n",
    "        pointcloud_generator_cls: str = \"\"\n",
    "        pointcloud_generator: dict = field(default_factory=dict)\n",
    "\n",
    "        pointcloud_encoder_cls: str = \"\"\n",
    "        pointcloud_encoder: dict = field(default_factory=dict)\n",
    "    \n",
    "    cfg: Config\n",
    "\n",
    "    def load_weights(self, weights: str, ignore_modules: Optional[List[str]] = None):\n",
    "        state_dict = load_module_weights(\n",
    "            weights, ignore_modules=ignore_modules, map_location=\"cpu\"\n",
    "        )\n",
    "        self.load_state_dict(state_dict, strict=False)\n",
    "\n",
    "    def __init__(self, cfg):\n",
    "        super().__init__()\n",
    "        self.cfg = parse_structured(self.Config, cfg)\n",
    "        self._save_dir: Optional[str] = None\n",
    "\n",
    "        self.image_tokenizer = tgs.find(self.cfg.image_tokenizer_cls)(\n",
    "            self.cfg.image_tokenizer\n",
    "        )\n",
    "\n",
    "        assert self.cfg.camera_embedder_cls == 'tgs.models.networks.MLP'\n",
    "        weights = self.cfg.camera_embedder.pop(\"weights\") if \"weights\" in self.cfg.camera_embedder else None\n",
    "        self.camera_embedder = tgs.find(self.cfg.camera_embedder_cls)(**self.cfg.camera_embedder)\n",
    "        if weights:\n",
    "            from tgs.utils.misc import load_module_weights\n",
    "            weights_path, module_name = weights.split(\":\")\n",
    "            state_dict = load_module_weights(\n",
    "                weights_path, module_name=module_name, map_location=\"cpu\"\n",
    "            )\n",
    "            self.camera_embedder.load_state_dict(state_dict)\n",
    "\n",
    "        self.image_feature = ImageFeature(self.cfg.image_feature)\n",
    "\n",
    "        self.tokenizer = tgs.find(self.cfg.tokenizer_cls)(self.cfg.tokenizer)\n",
    "\n",
    "        self.backbone = tgs.find(self.cfg.backbone_cls)(self.cfg.backbone)\n",
    "\n",
    "        self.post_processor = tgs.find(self.cfg.post_processor_cls)(\n",
    "            self.cfg.post_processor\n",
    "        )\n",
    "\n",
    "        self.renderer = tgs.find(self.cfg.renderer_cls)(self.cfg.renderer)\n",
    "\n",
    "        # pointcloud generator\n",
    "        self.pointcloud_generator = tgs.find(self.cfg.pointcloud_generator_cls)(self.cfg.pointcloud_generator)\n",
    "\n",
    "        self.point_encoder = tgs.find(self.cfg.pointcloud_encoder_cls)(self.cfg.pointcloud_encoder)\n",
    "\n",
    "        # load checkpoint\n",
    "        if self.cfg.weights is not None:\n",
    "            self.load_weights(self.cfg.weights, self.cfg.weights_ignore_modules)\n",
    "    \n",
    "    def _forward(self, batch: Dict[str, Any]) -> Dict[str, Any]:\n",
    "        # generate point cloud\n",
    "        out = self.pointcloud_generator(batch)\n",
    "        pointclouds = out[\"points\"]\n",
    "\n",
    "        batch_size, n_input_views = batch[\"rgb_cond\"].shape[:2]\n",
    "\n",
    "        # Camera modulation\n",
    "        camera_extri = batch[\"c2w_cond\"].view(*batch[\"c2w_cond\"].shape[:-2], -1)\n",
    "        camera_intri = batch[\"intrinsic_normed_cond\"].view(*batch[\"intrinsic_normed_cond\"].shape[:-2], -1)\n",
    "        camera_feats = torch.cat([camera_intri, camera_extri], dim=-1)\n",
    "\n",
    "        camera_feats = self.camera_embedder(camera_feats)\n",
    "\n",
    "        input_image_tokens: Float[Tensor, \"B Cit Nit\"] = self.image_tokenizer(\n",
    "            rearrange(batch[\"rgb_cond\"], 'B Nv H W C -> B Nv C H W'),\n",
    "            modulation_cond=camera_feats,\n",
    "        )\n",
    "        input_image_tokens = rearrange(input_image_tokens, 'B Nv C Nt -> B (Nv Nt) C', Nv=n_input_views)\n",
    "\n",
    "        # get image features for projection\n",
    "        image_features = self.image_feature(\n",
    "            rgb = batch[\"rgb_cond\"],\n",
    "            mask = batch.get(\"mask_cond\", None),\n",
    "            feature = input_image_tokens\n",
    "        )\n",
    "        # print(\"image feature : \",image_features.shape) # 1,773,252,252\n",
    "        # only support number of input view is one\n",
    "        c2w_cond = batch[\"c2w_cond\"].squeeze(1)\n",
    "        intrinsic_cond = batch[\"intrinsic_cond\"].squeeze(1)\n",
    "        proj_feats = points_projection(pointclouds, c2w_cond, intrinsic_cond, image_features)\n",
    "        # print(proj_feats.shape) torch.Size([1, 16384, 773])\n",
    "        point_cond_embeddings = self.point_encoder(torch.cat([pointclouds, proj_feats], dim=-1))\n",
    "        tokens: Float[Tensor, \"B Ct Nt\"] = self.tokenizer(batch_size, cond_embeddings=point_cond_embeddings)\n",
    "\n",
    "        tokens = self.backbone(\n",
    "            tokens,\n",
    "            encoder_hidden_states=input_image_tokens,\n",
    "            modulation_cond=None,\n",
    "        )\n",
    "\n",
    "        scene_codes = self.post_processor(self.tokenizer.detokenize(tokens))\n",
    "        rend_out = self.renderer(scene_codes,\n",
    "                                query_points=pointclouds,\n",
    "                                additional_features=proj_feats,\n",
    "                                **batch)\n",
    "\n",
    "        return {**out, **rend_out}\n",
    "        \n",
    "    def get_image_feature(self, batch):\n",
    "        # generate point cloud\n",
    "        out = self.pointcloud_generator(batch)\n",
    "        pointclouds = out[\"points\"]\n",
    "\n",
    "        return pointclouds\n",
    "\n",
    "\n",
    "    def forward(self, batch):\n",
    "        out = self._forward(batch)\n",
    "        batch_size = batch[\"index\"].shape[0]\n",
    "        for b in range(batch_size):\n",
    "            if batch[\"view_index\"][b, 0] == 0:\n",
    "                out[\"3dgs\"][b].save_ply(self.get_save_path(f\"3dgs/{batch['instance_id'][b]}.ply\"))\n",
    "\n",
    "            for index, render_image in enumerate(out[\"comp_rgb\"][b]):\n",
    "                view_index = batch[\"view_index\"][b, index]\n",
    "                self.save_image_grid(\n",
    "                    f\"video/{batch['instance_id'][b]}/{view_index}.png\",\n",
    "                    [\n",
    "                        {\n",
    "                            \"type\": \"rgb\",\n",
    "                            \"img\": render_image,\n",
    "                            \"kwargs\": {\"data_format\": \"HWC\"},\n",
    "                        }\n",
    "                    ]\n",
    "                )\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1a164d72",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['-f', '/root/.local/share/jupyter/runtime/kernel-2e0fb89a-5baf-47d9-86e9-7c8000a69b08.json']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/workspace/miniconda3/envs/torch/lib/python3.8/site-packages/huggingface_hub/file_download.py:1132: FutureWarning: `resume_download` is deprecated and will be removed in version 1.0.0. Downloads always resume when possible. If you want to force a new download, use `force_download=True`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "load model ckpt done.\n"
     ]
    }
   ],
   "source": [
    "import argparse\n",
    "import subprocess\n",
    "from tgs.utils.config import ExperimentConfig, load_config\n",
    "from tgs.data import CustomImageOrbitDataset\n",
    "from tgs.utils.misc import todevice, get_device\n",
    "\n",
    "parser = argparse.ArgumentParser(\"Triplane Gaussian Splatting\")\n",
    "parser.add_argument(\"--config\", default='config.yaml', help=\"path to config file\")\n",
    "parser.add_argument(\"--out\", default=\"outputs\", help=\"path to output folder\")\n",
    "parser.add_argument(\"--cam_dist\", default=1.9, type=float, help=\"distance between camera center and scene center\")\n",
    "parser.add_argument(\"--image_preprocess\", action=\"store_true\",default = True, help=\"whether to segment the input image by rembg and SAM\")\n",
    "args, extras = parser.parse_known_args()\n",
    "print(extras)\n",
    "\n",
    "device = get_device()\n",
    "\n",
    "\n",
    "cfg: ExperimentConfig = load_config(args.config)\n",
    "\n",
    "from huggingface_hub import hf_hub_download\n",
    "model_path = hf_hub_download(repo_id=\"VAST-AI/TriplaneGaussian\", local_dir=\"./checkpoints\", filename=\"model_lvis_rel.ckpt\", repo_type=\"model\")\n",
    "# model_path = \"checkpoints/model_lvis_rel.ckpt\"\n",
    "cfg.system.weights=model_path\n",
    "\n",
    "model = TGS(cfg=cfg.system).to(device)\n",
    "model.set_save_dir(args.out)\n",
    "print(\"load model ckpt done.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fedd809",
   "metadata": {},
   "outputs": [],
   "source": [
    "# run image segmentation for images\n",
    "cfg.data.image_list = ['example_images/an_otter_wearing_sunglasses.webp']\n",
    "if args.image_preprocess:\n",
    "    segmented_image_list = []\n",
    "    for image_path in cfg.data.image_list:\n",
    "        filepath, ext = os.path.splitext(image_path)\n",
    "        save_path = os.path.join(filepath + \"_rgba.png\")\n",
    "        segmented_image_list.append(save_path)\n",
    "        subprocess.run([f\"python image_preprocess/run_sam.py --image_path {image_path} --save_path {save_path}\"], shell=True)\n",
    "    cfg.data.image_list = segmented_image_list\n",
    "print(\"preprocessed image: \", save_path)\n",
    "\n",
    "cfg.data.cond_camera_distance = args.cam_dist\n",
    "cfg.data.eval_camera_distance = args.cam_dist\n",
    "dataset = CustomImageOrbitDataset(cfg.data)\n",
    "dataloader = DataLoader(dataset,\n",
    "                    batch_size=cfg.data.eval_batch_size, \n",
    "                    num_workers=cfg.data.num_workers,\n",
    "                    shuffle=False,\n",
    "                    collate_fn=dataset.collate\n",
    "                )\n",
    "print(\"segmented_image_list: \", segmented_image_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b59c4b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "cfg.data.cond_camera_distance = args.cam_dist\n",
    "cfg.data.eval_camera_distance = args.cam_dist\n",
    "dataset = CustomImageOrbitDataset(cfg.data)\n",
    "dataloader = DataLoader(dataset,\n",
    "                    batch_size=cfg.data.eval_batch_size, \n",
    "                    num_workers=cfg.data.num_workers,\n",
    "                    shuffle=False,\n",
    "                    collate_fn=dataset.collate\n",
    "                )\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41424264",
   "metadata": {},
   "outputs": [],
   "source": [
    "for batch in dataloader:\n",
    "    batch = todevice(batch)\n",
    "    print(batch['rgb_cond'].shape)  # torch.Size([1, 1, 252, 252, 3])\n",
    "    image_features = model.get_image_feature(batch)  \n",
    "    print(image_features.shape) # torch.Size([1, 16384, 3])\n",
    "\n",
    "# model(batch)\n",
    "# model.save_img_sequences(\n",
    "#     \"video\",\n",
    "#     \"(\\d+)\\.png\",\n",
    "#     save_format=\"mp4\",\n",
    "#     fps=30,\n",
    "#     delete=True,\n",
    "# )\n",
    "# print(\"save to :\", args.out)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eb12107b",
   "metadata": {},
   "source": [
    "### Now let's get any image from the internet and resize it properly"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "feba61a6",
   "metadata": {},
   "source": [
    "### Simple attack implementation\n",
    "Now we implement a simple PGD attack "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15d701f6",
   "metadata": {
    "tags": []
   },
   "source": [
    "\n",
    "\n",
    "### Executing the attack\n",
    "Now we apply the attack to our image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf70bed7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from chamferdist import ChamferDistance\n",
    "def pgd_batch(batch, target, model, eps=0.1, step_size=0.015, iters=40, clamp_min=0, clamp_max=1, mask=None):\n",
    "\n",
    "    chamferDist = ChamferDistance()\n",
    "    \n",
    "    X = batch['rgb_cond']\n",
    "    # X_adv = X.clone().detach() + (torch.rand(*X.shape)*2*eps-eps).cuda()\n",
    "    adv_batch = batch\n",
    "    adv_batch['rgb_cond'] = batch['rgb_cond'].clone().detach() + (torch.rand(*X.shape)*2*eps-eps).cuda()\n",
    "\n",
    "    print(batch.keys())\n",
    "    pbar = tqdm(range(iters))\n",
    "    for i in pbar:\n",
    "        actual_step_size = step_size - (step_size - step_size / 100) / iters * i  \n",
    "\n",
    "        adv_batch['rgb_cond'].requires_grad_(True)\n",
    "        \n",
    "\n",
    "        # loss = model(adv_batch).mean().norm()  # self-degraded\n",
    "        loss = (model(adv_batch)).norm() # simple-target\n",
    "        \n",
    "        # loss = chamferDist(model(adv_batch),target)\n",
    "        pbar.set_description(f\"[Running attack]: Loss {loss.item():.5f} | step size: {actual_step_size:.4}\")\n",
    "\n",
    "        grad, = torch.autograd.grad(loss, [adv_batch['rgb_cond']])\n",
    "\n",
    "        adv_batch['rgb_cond'] = adv_batch['rgb_cond'] -  grad.detach().sign() * actual_step_size            \n",
    "        adv_batch['rgb_cond'] = torch.minimum(torch.maximum(adv_batch['rgb_cond'], batch['rgb_cond'] - eps),batch['rgb_cond'] + eps)\n",
    "        adv_batch['rgb_cond'].data = torch.clamp(adv_batch['rgb_cond'], min=clamp_min, max=clamp_max)\n",
    "        adv_batch['rgb_cond'].grad = None    \n",
    "        \n",
    "        if mask is not None:\n",
    "            # adv_batch['rgb_cond'].data = mask * adv_batch['rgb_cond'].data\n",
    "            \n",
    "            adv_batch['rgb_cond'].data[:, :, mask == 0] = 1.0  # 设置为白色\n",
    "            # print(adv_batch['rgb_cond'].data.shape)\n",
    "            \n",
    "    return adv_batch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "6733bb64",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0., device='cuda:0') tensor(1., device='cuda:0')\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "torch.Size([252, 252, 3])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import cv2\n",
    "gray_image = cv2.imread('mask.png', cv2.IMREAD_GRAYSCALE)\n",
    "\n",
    "# Apply binary thresholding to convert the grayscale image to binary\n",
    "_, binary_image = cv2.threshold(gray_image, 127, 255, cv2.THRESH_BINARY)\n",
    "\n",
    "mask= torch.from_numpy(binary_image).to(\"cuda\").unsqueeze(2).repeat(1, 1, 3) / 255 #tensor is zero, black\n",
    "\n",
    "print(mask.min(),mask.max())\n",
    "\n",
    "mask.shape\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "fd91ecfb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import math\n",
    "# def generate_spherical_point_cloud(num_points, radius):\n",
    "#     points = []\n",
    "#     for _ in range(num_points):\n",
    "#         # 生成球坐标\n",
    "#         phi = torch.rand(1) * 2 * math.pi\n",
    "#         theta = torch.acos(2 * torch.rand(1) - 1)\n",
    "\n",
    "#         # 转换为笛卡尔坐标\n",
    "#         x = radius * torch.sin(theta) * torch.cos(phi)\n",
    "#         y = radius * torch.sin(theta) * torch.sin(phi)\n",
    "#         z = radius * torch.cos(theta)\n",
    "\n",
    "#         points.append([x.item(), y.item(), z.item()])\n",
    "\n",
    "#     return torch.tensor(points).unsqueeze(0)\n",
    "\n",
    "# # 生成球形点云\n",
    "# num_points = 16000\n",
    "# radius = 0.5\n",
    "# point_cloud = generate_spherical_point_cloud(num_points, radius)\n",
    "# print(point_cloud)\n",
    "# print(point_cloud.shape)\n",
    "\n",
    "# target_point_cloud = point_cloud.to('cuda')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d7474f38",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0., device='cuda:0') tensor(1., device='cuda:0')\n",
      "dict_keys(['rgb_cond', 'c2w_cond', 'mask_cond', 'intrinsic_cond', 'intrinsic_normed_cond', 'view_index', 'rays_o', 'rays_d', 'intrinsic', 'intrinsic_normed', 'c2w', 'camera_positions', 'index', 'background_color', 'instance_id', 'path', 'height', 'width'])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[Running attack]: Loss 26.98368 | step size: 1.99e-05: 100%|████████████████████| 100/100 [00:49<00:00,  2.02it/s]\n"
     ]
    }
   ],
   "source": [
    "# import trimesh\n",
    "# # mesh = trimesh.load_mesh('modified/no_ear.ply')\n",
    "# mesh = trimesh.load_mesh('outputs/3dgs/green_parrot_rgba.ply')\n",
    "# # Get the vertices of the mesh\n",
    "# vertices = torch.tensor(mesh.vertices, dtype=torch.float)\n",
    "# target_point_cloud = torch.tensor(vertices).unsqueeze(0).to('cuda') * 0.5\n",
    "\n",
    "# target_point_cloud.requires_grad=False\n",
    "\n",
    "for batch in dataloader:\n",
    "    batch = todevice(batch)\n",
    "    print(batch['rgb_cond'].min(),batch['rgb_cond'].max())\n",
    "    # image_features = model.get_image_feature(batch)  \n",
    "    # print(image_features.shape) # torch.Size([1, 773, 252, 252])\n",
    "    with torch.autocast('cuda',enabled=False):\n",
    "    # eps=0.1, step_size=0.015, iters=40\n",
    "        adv_batch = pgd_batch(batch, \n",
    "                              target=None,\n",
    "                    model=model.get_image_feature, \n",
    "                    clamp_min=0, \n",
    "                    clamp_max=1,\n",
    "                    eps=2/255, # The higher, the less imperceptible the attack is \n",
    "                    step_size=0.001, # Set smaller than eps\n",
    "                    iters=100, # The higher, the stronger your attack will be\n",
    "                    mask = mask,\n",
    "                   )\n",
    "        \n",
    "        # convert pixels back to [0,1] range\n",
    "        # print(adv_batch['rgb_cond'].min(),adv_batch['rgb_cond'].max()) -0.0763,1\n",
    "        # adv_batch['rgb_cond'] = (adv_batch['rgb_cond'] / 2 + 0.5).clamp(0, 1)\n",
    "        # adv_batch['rgb_cond'] = (adv_batch['rgb_cond']).clamp(0, 1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a6aec388",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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1k9V46Ha6Xh6a3X1AkghT3Ottu0bWmt+oduagRl/z2vvue01Ozi3YcGnQf+Cou6jv/7+5e11C9FUKFEtCyAv3sQMj7D2uOnWW2696cZf+YPf6BrG3J5DLzt2wwt6xumDrtwKTIP+yq399JWv0ApMC9krtPDTl71yKzAN+iu39tNXvkIrMA36K7Tw05e9ciswDfort/bTV75CKzAN+iu08NOXvXIrMA36K7f201e+QiswDfortPDTl71yKzAN+iu39tNXvkIrMA36K7Tw05e9ciswDfort/bTV75CKzAN+iu08NOXvXIrMA36K7f201e+QiswDfortPDTl71yKzAN+iu39tNXvkIrMA36K7Tw05e9ciswDfort/bTV75CKzAN+iu08NOXvXIrMA36K7f201e+QiswDfortPDTl71yKzAN+iu39tNXvkIrMA36K7Tw05e9ciswDfort/bTV75CKzAN+iu08NOXvXIrMA36K7f201e+QiswDfortPDTl71yKzAN+iu39tNXvkIrMA36K7Tw05e9ciswDfort/bTV75CKzAN+iu08NOXvXIrMA36K7f201e+Qivw/wGRNAc1oZVwZAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=252x252>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# adv_image = to_pil(adv_batch['rgb_cond']).convert(\"RGB\")\n",
    "# adv_batch['rgb_cond'][:, :, mask == 0] = 1.0  # 设置为白色\n",
    "\n",
    "adv_image = to_pil(adv_batch['rgb_cond'].squeeze(0).permute(0, 3, 1, 2).squeeze(0).cpu()).convert(\"RGB\")\n",
    "adv_image.save('output.png')\n",
    "\n",
    "adv_image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cff8b49b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b9409f7b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "save to : outputs\n"
     ]
    }
   ],
   "source": [
    "model(adv_batch)\n",
    "\n",
    "model.save_img_sequences(\n",
    "    \"video\",\n",
    "    \"(\\d+)\\.png\",\n",
    "    save_format=\"mp4\",\n",
    "    fps=30,\n",
    "    delete=True,\n",
    ")\n",
    "print(\"save to :\", args.out)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70e607ef",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06b6264d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "250755f3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "595e185c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f4b608b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "language": "python",
   "name": "torch"
  },
  "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.8.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
