{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "print(\"Number of GPU: \", torch.cuda.device_count())\n",
    "print(\"GPU Name: \", torch.cuda.get_device_name())\n",
    "\n",
    "# device = 'cpu'\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print('Using device:', device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch, torchvision\n",
    "print(torch.__version__, torch.cuda.is_available())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Check Pytorch installation\n",
    "\n",
    "import torch\n",
    "print(torch.__version__, torch.cuda.is_available())\n",
    "\n",
    "from multiprocessing import Process\n",
    "\n",
    "if __name__ == '__main__':    \n",
    "    # Check MMAction2 installaation\n",
    "    import mmaction\n",
    "    print(mmaction.__version__)\n",
    "\n",
    "    import mmcv\n",
    "    print(mmcv.__version__)\n",
    "\n",
    "    # Check MMCV installation\n",
    "    from mmcv.ops import get_compiling_cuda_version, get_compiler_version\n",
    "    print(get_compiling_cuda_version())\n",
    "    print(get_compiler_version())\n",
    "\n",
    "    # Check MMEngine installation\n",
    "    from mmengine.utils.dl_utils import collect_env\n",
    "    print(collect_env())\n",
    "\n",
    "    from mmaction.apis import inference_recognizer, init_recognizer\n",
    "    from mmengine import Config\n",
    "\n",
    "    from operator import itemgetter\n",
    "\n",
    "    import os.path as osp\n",
    "    import mmengine\n",
    "    from mmengine.runner import Runner\n",
    "\n",
    "    # Choose to use a config and initialize the recognizer\n",
    "    # cfg = './swin-small-p244-w877_in1k-pre_8xb8-amp-32x2x1-30e_kinetics400-rgb.py'\n",
    "    cfg = #path to config file \n",
    "    cfg = Config.fromfile(cfg)\n",
    "\n",
    "    # Set up working dir to save files and logs.\n",
    "    cfg.work_dir = #path to work directory\n",
    "\n",
    "    # Create work_dir\n",
    "    mmengine.mkdir_or_exist(osp.abspath(cfg.work_dir))\n",
    "\n",
    "    # The original learning rate (LR) is set for 8-GPU training.\n",
    "    # We divide it by 8 since we only use one GPU.\n",
    "    cfg.train_dataloader.batch_size = cfg.train_dataloader.batch_size // 4\n",
    "    cfg.val_dataloader.batch_size = cfg.val_dataloader.batch_size // 4\n",
    "    cfg.test_dataloader.batch_size = 1\n",
    "    cfg.optim_wrapper.optimizer.lr = cfg.optim_wrapper.optimizer.lr / 8\n",
    "    cfg.train_cfg.max_epochs = 50\n",
    "\n",
    "\n",
    "    # We can initialize the logger for training and have a look\n",
    "    # at the final config used for training\n",
    "    print(f'Config:\\n{cfg.pretty_text}')\n",
    "\n",
    "    # Initialize the recognizer\n",
    "    model = init_recognizer(cfg, checkpoint=None, device='cuda:0')\n",
    "\n",
    "    # build the runner from config\n",
    "    runner = Runner.from_cfg(cfg)\n",
    "\n",
    "    # start training\n",
    "    runner.train()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "ryVoSfZVmogw"
   },
   "source": [
    "## Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import torch\n",
    "print(torch.__version__, torch.cuda.is_available())\n",
    "\n",
    "from multiprocessing import Process\n",
    "\n",
    "if __name__ == '__main__':    \n",
    "    # Check MMAction2 installaation\n",
    "    import mmaction\n",
    "    print(mmaction.__version__)\n",
    "\n",
    "    import mmcv\n",
    "    print(mmcv.__version__)\n",
    "\n",
    "    # Check MMCV installation\n",
    "    from mmcv.ops import get_compiling_cuda_version, get_compiler_version\n",
    "    print(get_compiling_cuda_version())\n",
    "    print(get_compiler_version())\n",
    "\n",
    "    # Check MMEngine installation\n",
    "    from mmengine.utils.dl_utils import collect_env\n",
    "    print(collect_env())\n",
    "\n",
    "    from mmaction.apis import inference_recognizer, init_recognizer\n",
    "    from mmengine import Config\n",
    "\n",
    "    from operator import itemgetter\n",
    "\n",
    "    import os.path as osp\n",
    "    import mmengine\n",
    "    from mmengine.runner import Runner\n",
    "\n",
    "from mmengine.runner import Runner\n",
    "checkpoint = #path to checkpoint \n",
    "\n",
    "\n",
    "\n",
    "cfg = #path to config file \n",
    "\n",
    "cfg = Config.fromfile(cfg)\n",
    "\n",
    "cfg.load_from = checkpoint\n",
    "\n",
    "cfg.work_dir = #path to work directory \n",
    "\n",
    "cfg.test_dataloader.dataset.ann_file = #path to annotation file \n",
    "\n",
    "cfg.test_dataloader.dataset.data_prefix.img = #path to image data root \n",
    "\n",
    "\n",
    "# build the runner from config\n",
    "\n",
    "if 'runner_type' not in cfg:\n",
    "\n",
    "   # build the default runner\n",
    "\n",
    "   runner_test = Runner.from_cfg(cfg)\n",
    "\n",
    "else:\n",
    "\n",
    "   # build customized runner from the registry\n",
    "\n",
    "   # if 'runner_type' is set in the cfg\n",
    "\n",
    "   runner_test = Runner.build(cfg)\n",
    "\n",
    "\n",
    "# start testing\n",
    "\n",
    "runner_test.test()"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": [],
   "toc_visible": true
  },
  "kernelspec": {
   "display_name": "openmmlab",
   "language": "python",
   "name": "python3"
  },
  "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
