{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9fdf6337-dbfa-4396-ab2f-dd1de8aefcf9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np; import torch\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5f34cfb7-f992-4e6a-bc9d-ec7e39fe333a",
   "metadata": {},
   "outputs": [],
   "source": [
    "w = np.array(\n",
    "    [\n",
    "        [1,0,-1],\n",
    "        [2,0,-2],\n",
    "        [1,0,-1]\n",
    "    ]).reshape(1,1,3,3).astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "794486d5-2cc5-4497-9220-6dc47f366335",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = np.array(\n",
    "    [\n",
    "        [1,1,1,2,3],\n",
    "        [1,1,1,2,3],\n",
    "        [1,1,1,2,3],\n",
    "        [2,2,2,2,3],\n",
    "        [3,3,3,3,3],\n",
    "        [4,4,4,4,4]\n",
    "    ]).reshape(1,1,6,5).astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "5addda0f-b128-4be6-9f46-9d945d13e36e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((1, 1, 3, 3), (1, 1, 6, 5))"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "w.shape, x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "290da676-23e8-4e95-93ab-261033537482",
   "metadata": {},
   "outputs": [],
   "source": [
    "conv = torch.nn.Conv2d(\n",
    "    in_channels=1,\n",
    "    out_channels=1,\n",
    "    kernel_size=3,\n",
    "    bias=False,\n",
    "    stride = 1,\n",
    "    padding_mode='zeros',\n",
    "    padding=0\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "72400a63-ca56-48c6-93e6-26e7f3657260",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_tensor = torch.from_numpy(x)\n",
    "x_tensor.requires_grad = True\n",
    "conv.weight = torch.nn.Parameter(torch.from_numpy(w))\n",
    "out = conv(x_tensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "023ce4fa-d496-4981-893f-9d42978c4257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[[[15., 18., 25.],\n",
      "          [21., 23., 28.],\n",
      "          [30., 31., 34.]]]])\n",
      "tensor([[[[ 1.,  1.,  0., -1., -1.],\n",
      "          [ 3.,  3.,  0., -3., -3.],\n",
      "          [ 4.,  4.,  0., -4., -4.],\n",
      "          [ 4.,  4.,  0., -4., -4.],\n",
      "          [ 3.,  3.,  0., -3., -3.],\n",
      "          [ 1.,  1.,  0., -1., -1.]]]])\n"
     ]
    }
   ],
   "source": [
    "loss = out.sum()\n",
    "loss.backward()\n",
    "\n",
    "print(conv.weight.grad)\n",
    "print(x_tensor.grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "de692e8d-cad3-492d-bff9-4ee08fb4d9fc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 1, 3, 3])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv.weight.grad.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eda4ef98-52a5-43e8-9489-7ea90c8b2a15",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
