{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "Bw1RvA-QujSq"
      },
      "outputs": [],
      "source": [
        "import random\n",
        "\n",
        "import torch\n",
        "\n",
        "\n",
        "class basedOnLibrary:\n",
        "    all_objects = {}\n",
        "\n",
        "    @staticmethod\n",
        "    def get_instance(name=\"main\"):\n",
        "        if name not in basedOnLibrary.all_objects:\n",
        "            basedOnLibrary.all_objects[name] = basedOnLibrary(name)\n",
        "        return basedOnLibrary.all_objects[name]\n",
        "\n",
        "    def __init__(self, name):\n",
        "        self.name = name\n",
        "        self.dict = {}\n",
        "        self.eval_mode = False\n",
        "\n",
        "    def __enter__(self):\n",
        "        self.log_prob = torch.tensor(0).float()\n",
        "        return self\n",
        "\n",
        "    def __exit__(self, exc_type, exc_val, exc_tb):\n",
        "        optim = torch.optim.SGD(self.dict.values(), lr=0.0001)\n",
        "        optim.step()\n",
        "        optim.zero_grad()\n",
        "\n",
        "    def eval(self):\n",
        "        self.eval_mode = True\n",
        "\n",
        "    def train(self):\n",
        "        self.eval_mode = False\n",
        "\n",
        "    def get_tensor(self, tensor_name, size=1):\n",
        "        if tensor_name not in self.dict:\n",
        "            self.dict[tensor_name] = torch.zeros(size, requires_grad=True).float()\n",
        "        return self.dict[tensor_name]\n",
        "\n",
        "    def get_learable_variable(self, tensor_name, size=1):\n",
        "        return self.get_tensor(tensor_name, size)\n",
        "\n",
        "\n",
        "    @staticmethod\n",
        "    def list_to_tensor(list):\n",
        "        a = []\n",
        "        for x in list:\n",
        "            if torch.is_tensor(x):\n",
        "                a.append(x.float())\n",
        "            else:\n",
        "                a.append(torch.tensor(x).float())\n",
        "            if len(a[-1].shape)==0:\n",
        "                a[-1]=a[-1].unsqueeze(0)\n",
        "        return a\n",
        "\n",
        "    def based_on(self, unique_id, *input):  # we could attach a module on top of more than one argument\n",
        "        inputs=basedOnLibrary.list_to_tensor(input)\n",
        "        x = torch.cat(inputs, dim=0) if len(inputs)>1 else inputs[0]\n",
        "        W = self.get_tensor(\"$W\" + str(unique_id), size=x.shape)\n",
        "        B = self.get_tensor(\"$b\" + str(unique_id), size=(1,))\n",
        "        value = torch.dot(x, W) + B\n",
        "        p = torch.nn.Sigmoid()(value)\n",
        "        if (not self.eval_mode and random.random() < p) or (self.eval_mode and 0.5 <= p):\n",
        "            decision = True\n",
        "            probability_of_decision = p\n",
        "        else:\n",
        "            decision = False\n",
        "            probability_of_decision = 1 - p\n",
        "        self.log_prob += torch.log(probability_of_decision)[0]\n",
        "        return decision\n",
        "\n",
        "    def recored_loss(self, loss):\n",
        "        total_loss: torch.tensor = loss + loss.detach() * self.log_prob\n",
        "        total_loss.backward()\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import math\n",
        "import random\n",
        "import numpy as np\n",
        "import torch.nn\n",
        "\n",
        "def build_test(n):\n",
        "    x = np.zeros((n, 2))\n",
        "    y = np.zeros(n)\n",
        "    mx = 15\n",
        "    for i in range(n):\n",
        "        x1 = (random.random() * mx - (mx / 2))\n",
        "        x2 = (random.random() * mx - (mx / 2))\n",
        "        x[i, 0] = x1\n",
        "        x[i, 1] = x2\n",
        "        y[i] = f_hat(x1, x2)\n",
        "    return torch.tensor(x).float(), torch.tensor(y).float()\n",
        "\n",
        "\n",
        "def loss_function(y, y_hat):\n",
        "    return torch.nn.MSELoss()(y, y_hat[0])\n",
        "\n",
        "\n",
        "\n",
        "def train(n):\n",
        "    x, y = build_test(n)\n",
        "    sum = 0\n",
        "    step = 0\n",
        "    for epoch in range(100000):\n",
        "        i = epoch % n\n",
        "        if epoch == 100000 // 2:\n",
        "            print(\"EVAL MODE\")\n",
        "            basedOnLibrary.get_instance(\"my_func\").eval()\n",
        "\n",
        "        with basedOnLibrary.get_instance(\"my_func\") as f:\n",
        "            output = learnable_function(x[i, 0], x[i, 1], f)\n",
        "            total_loss = loss_function(y[i], output)\n",
        "            f.recored_loss(total_loss)\n",
        "        sum += total_loss.detach()\n",
        "        step += 1\n",
        "        if epoch % 10000 == 0:\n",
        "            print(sum / step)\n",
        "            step = 0\n",
        "            sum = 0\n",
        "\n",
        "    print(basedOnLibrary.get_instance(\"my_func\").dict)"
      ],
      "metadata": {
        "id": "Nzl0MALJulWA"
      },
      "execution_count": 2,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def f_hat(x1, x2):\n",
        "    if x1 * math.pi - 1 > 5:\n",
        "        return x1 * 4.569\n",
        "    else:\n",
        "        return x2 * 8.598\n",
        "\n",
        "\n",
        "def learnable_function(x1, x2, f):\n",
        "    if f.based_on(\"d1\", x1):\n",
        "        w3 = f.get_learable_variable(\"w3\")\n",
        "        return x1 * w3\n",
        "    else:\n",
        "        w4 = f.get_learable_variable(\"w4\")\n",
        "        return x2 * w4"
      ],
      "metadata": {
        "id": "mYmUvP0Wu2P-"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "train(10000)\n",
        "while True:\n",
        "    mx = 20\n",
        "    for x1 in range(-mx // 2, mx // 2):\n",
        "        for x2 in range(-mx // 2, mx // 2):\n",
        "            with basedOnLibrary.get_instance(\"my_func\") as f:\n",
        "                output = learnable_function(x1, x2, f)\n",
        "            print(x1, x2, f_hat(x1, x2), output.item())\n",
        "    break"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "nbfkQxjnuxHI",
        "outputId": "83f2d7d2-19d6-484a-beab-743e3475d83e"
      },
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(4.2433e-08)\n",
            "tensor(0.0341)\n",
            "tensor(3.4845)\n",
            "tensor(2.8505)\n",
            "tensor(2.8100)\n",
            "EVAL MODE\n",
            "tensor(3.4731)\n",
            "tensor(1.9345)\n",
            "tensor(3.4645)\n",
            "tensor(1.6045)\n",
            "tensor(2.3727)\n",
            "{'$Wd1': tensor([8.0584], requires_grad=True), '$bd1': tensor([-15.2819], requires_grad=True), 'w3': tensor([4.5602], requires_grad=True), 'w4': tensor([8.5824], requires_grad=True)}\n",
            "-10 -10 -85.98 -85.82408905029297\n",
            "-10 -9 -77.382 -77.24168395996094\n",
            "-10 -8 -68.784 -68.65927124023438\n",
            "-10 -7 -60.18600000000001 -60.07686233520508\n",
            "-10 -6 -51.58800000000001 -51.49445343017578\n",
            "-10 -5 -42.99 -42.912044525146484\n",
            "-10 -4 -34.392 -34.32963562011719\n",
            "-10 -3 -25.794000000000004 -25.74722671508789\n",
            "-10 -2 -17.196 -17.164817810058594\n",
            "-10 -1 -8.598 -8.582408905029297\n",
            "-10 0 0.0 0.0\n",
            "-10 1 8.598 8.582408905029297\n",
            "-10 2 17.196 17.164817810058594\n",
            "-10 3 25.794000000000004 25.74722671508789\n",
            "-10 4 34.392 34.32963562011719\n",
            "-10 5 42.99 42.912044525146484\n",
            "-10 6 51.58800000000001 51.49445343017578\n",
            "-10 7 60.18600000000001 60.07686233520508\n",
            "-10 8 68.784 68.65927124023438\n",
            "-10 9 77.382 77.24168395996094\n",
            "-9 -10 -85.98 -85.82408905029297\n",
            "-9 -9 -77.382 -77.24168395996094\n",
            "-9 -8 -68.784 -68.65927124023438\n",
            "-9 -7 -60.18600000000001 -60.07686233520508\n",
            "-9 -6 -51.58800000000001 -51.49445343017578\n",
            "-9 -5 -42.99 -42.912044525146484\n",
            "-9 -4 -34.392 -34.32963562011719\n",
            "-9 -3 -25.794000000000004 -25.74722671508789\n",
            "-9 -2 -17.196 -17.164817810058594\n",
            "-9 -1 -8.598 -8.582408905029297\n",
            "-9 0 0.0 0.0\n",
            "-9 1 8.598 8.582408905029297\n",
            "-9 2 17.196 17.164817810058594\n",
            "-9 3 25.794000000000004 25.74722671508789\n",
            "-9 4 34.392 34.32963562011719\n",
            "-9 5 42.99 42.912044525146484\n",
            "-9 6 51.58800000000001 51.49445343017578\n",
            "-9 7 60.18600000000001 60.07686233520508\n",
            "-9 8 68.784 68.65927124023438\n",
            "-9 9 77.382 77.24168395996094\n",
            "-8 -10 -85.98 -85.82408905029297\n",
            "-8 -9 -77.382 -77.24168395996094\n",
            "-8 -8 -68.784 -68.65927124023438\n",
            "-8 -7 -60.18600000000001 -60.07686233520508\n",
            "-8 -6 -51.58800000000001 -51.49445343017578\n",
            "-8 -5 -42.99 -42.912044525146484\n",
            "-8 -4 -34.392 -34.32963562011719\n",
            "-8 -3 -25.794000000000004 -25.74722671508789\n",
            "-8 -2 -17.196 -17.164817810058594\n",
            "-8 -1 -8.598 -8.582408905029297\n",
            "-8 0 0.0 0.0\n",
            "-8 1 8.598 8.582408905029297\n",
            "-8 2 17.196 17.164817810058594\n",
            "-8 3 25.794000000000004 25.74722671508789\n",
            "-8 4 34.392 34.32963562011719\n",
            "-8 5 42.99 42.912044525146484\n",
            "-8 6 51.58800000000001 51.49445343017578\n",
            "-8 7 60.18600000000001 60.07686233520508\n",
            "-8 8 68.784 68.65927124023438\n",
            "-8 9 77.382 77.24168395996094\n",
            "-7 -10 -85.98 -85.82408905029297\n",
            "-7 -9 -77.382 -77.24168395996094\n",
            "-7 -8 -68.784 -68.65927124023438\n",
            "-7 -7 -60.18600000000001 -60.07686233520508\n",
            "-7 -6 -51.58800000000001 -51.49445343017578\n",
            "-7 -5 -42.99 -42.912044525146484\n",
            "-7 -4 -34.392 -34.32963562011719\n",
            "-7 -3 -25.794000000000004 -25.74722671508789\n",
            "-7 -2 -17.196 -17.164817810058594\n",
            "-7 -1 -8.598 -8.582408905029297\n",
            "-7 0 0.0 0.0\n",
            "-7 1 8.598 8.582408905029297\n",
            "-7 2 17.196 17.164817810058594\n",
            "-7 3 25.794000000000004 25.74722671508789\n",
            "-7 4 34.392 34.32963562011719\n",
            "-7 5 42.99 42.912044525146484\n",
            "-7 6 51.58800000000001 51.49445343017578\n",
            "-7 7 60.18600000000001 60.07686233520508\n",
            "-7 8 68.784 68.65927124023438\n",
            "-7 9 77.382 77.24168395996094\n",
            "-6 -10 -85.98 -85.82408905029297\n",
            "-6 -9 -77.382 -77.24168395996094\n",
            "-6 -8 -68.784 -68.65927124023438\n",
            "-6 -7 -60.18600000000001 -60.07686233520508\n",
            "-6 -6 -51.58800000000001 -51.49445343017578\n",
            "-6 -5 -42.99 -42.912044525146484\n",
            "-6 -4 -34.392 -34.32963562011719\n",
            "-6 -3 -25.794000000000004 -25.74722671508789\n",
            "-6 -2 -17.196 -17.164817810058594\n",
            "-6 -1 -8.598 -8.582408905029297\n",
            "-6 0 0.0 0.0\n",
            "-6 1 8.598 8.582408905029297\n",
            "-6 2 17.196 17.164817810058594\n",
            "-6 3 25.794000000000004 25.74722671508789\n",
            "-6 4 34.392 34.32963562011719\n",
            "-6 5 42.99 42.912044525146484\n",
            "-6 6 51.58800000000001 51.49445343017578\n",
            "-6 7 60.18600000000001 60.07686233520508\n",
            "-6 8 68.784 68.65927124023438\n",
            "-6 9 77.382 77.24168395996094\n",
            "-5 -10 -85.98 -85.82408905029297\n",
            "-5 -9 -77.382 -77.24168395996094\n",
            "-5 -8 -68.784 -68.65927124023438\n",
            "-5 -7 -60.18600000000001 -60.07686233520508\n",
            "-5 -6 -51.58800000000001 -51.49445343017578\n",
            "-5 -5 -42.99 -42.912044525146484\n",
            "-5 -4 -34.392 -34.32963562011719\n",
            "-5 -3 -25.794000000000004 -25.74722671508789\n",
            "-5 -2 -17.196 -17.164817810058594\n",
            "-5 -1 -8.598 -8.582408905029297\n",
            "-5 0 0.0 0.0\n",
            "-5 1 8.598 8.582408905029297\n",
            "-5 2 17.196 17.164817810058594\n",
            "-5 3 25.794000000000004 25.74722671508789\n",
            "-5 4 34.392 34.32963562011719\n",
            "-5 5 42.99 42.912044525146484\n",
            "-5 6 51.58800000000001 51.49445343017578\n",
            "-5 7 60.18600000000001 60.07686233520508\n",
            "-5 8 68.784 68.65927124023438\n",
            "-5 9 77.382 77.24168395996094\n",
            "-4 -10 -85.98 -85.82408905029297\n",
            "-4 -9 -77.382 -77.24168395996094\n",
            "-4 -8 -68.784 -68.65927124023438\n",
            "-4 -7 -60.18600000000001 -60.07686233520508\n",
            "-4 -6 -51.58800000000001 -51.49445343017578\n",
            "-4 -5 -42.99 -42.912044525146484\n",
            "-4 -4 -34.392 -34.32963562011719\n",
            "-4 -3 -25.794000000000004 -25.74722671508789\n",
            "-4 -2 -17.196 -17.164817810058594\n",
            "-4 -1 -8.598 -8.582408905029297\n",
            "-4 0 0.0 0.0\n",
            "-4 1 8.598 8.582408905029297\n",
            "-4 2 17.196 17.164817810058594\n",
            "-4 3 25.794000000000004 25.74722671508789\n",
            "-4 4 34.392 34.32963562011719\n",
            "-4 5 42.99 42.912044525146484\n",
            "-4 6 51.58800000000001 51.49445343017578\n",
            "-4 7 60.18600000000001 60.07686233520508\n",
            "-4 8 68.784 68.65927124023438\n",
            "-4 9 77.382 77.24168395996094\n",
            "-3 -10 -85.98 -85.82408905029297\n",
            "-3 -9 -77.382 -77.24168395996094\n",
            "-3 -8 -68.784 -68.65927124023438\n",
            "-3 -7 -60.18600000000001 -60.07686233520508\n",
            "-3 -6 -51.58800000000001 -51.49445343017578\n",
            "-3 -5 -42.99 -42.912044525146484\n",
            "-3 -4 -34.392 -34.32963562011719\n",
            "-3 -3 -25.794000000000004 -25.74722671508789\n",
            "-3 -2 -17.196 -17.164817810058594\n",
            "-3 -1 -8.598 -8.582408905029297\n",
            "-3 0 0.0 0.0\n",
            "-3 1 8.598 8.582408905029297\n",
            "-3 2 17.196 17.164817810058594\n",
            "-3 3 25.794000000000004 25.74722671508789\n",
            "-3 4 34.392 34.32963562011719\n",
            "-3 5 42.99 42.912044525146484\n",
            "-3 6 51.58800000000001 51.49445343017578\n",
            "-3 7 60.18600000000001 60.07686233520508\n",
            "-3 8 68.784 68.65927124023438\n",
            "-3 9 77.382 77.24168395996094\n",
            "-2 -10 -85.98 -85.82408905029297\n",
            "-2 -9 -77.382 -77.24168395996094\n",
            "-2 -8 -68.784 -68.65927124023438\n",
            "-2 -7 -60.18600000000001 -60.07686233520508\n",
            "-2 -6 -51.58800000000001 -51.49445343017578\n",
            "-2 -5 -42.99 -42.912044525146484\n",
            "-2 -4 -34.392 -34.32963562011719\n",
            "-2 -3 -25.794000000000004 -25.74722671508789\n",
            "-2 -2 -17.196 -17.164817810058594\n",
            "-2 -1 -8.598 -8.582408905029297\n",
            "-2 0 0.0 0.0\n",
            "-2 1 8.598 8.582408905029297\n",
            "-2 2 17.196 17.164817810058594\n",
            "-2 3 25.794000000000004 25.74722671508789\n",
            "-2 4 34.392 34.32963562011719\n",
            "-2 5 42.99 42.912044525146484\n",
            "-2 6 51.58800000000001 51.49445343017578\n",
            "-2 7 60.18600000000001 60.07686233520508\n",
            "-2 8 68.784 68.65927124023438\n",
            "-2 9 77.382 77.24168395996094\n",
            "-1 -10 -85.98 -85.82408905029297\n",
            "-1 -9 -77.382 -77.24168395996094\n",
            "-1 -8 -68.784 -68.65927124023438\n",
            "-1 -7 -60.18600000000001 -60.07686233520508\n",
            "-1 -6 -51.58800000000001 -51.49445343017578\n",
            "-1 -5 -42.99 -42.912044525146484\n",
            "-1 -4 -34.392 -34.32963562011719\n",
            "-1 -3 -25.794000000000004 -25.74722671508789\n",
            "-1 -2 -17.196 -17.164817810058594\n",
            "-1 -1 -8.598 -8.582408905029297\n",
            "-1 0 0.0 0.0\n",
            "-1 1 8.598 8.582408905029297\n",
            "-1 2 17.196 17.164817810058594\n",
            "-1 3 25.794000000000004 25.74722671508789\n",
            "-1 4 34.392 34.32963562011719\n",
            "-1 5 42.99 42.912044525146484\n",
            "-1 6 51.58800000000001 51.49445343017578\n",
            "-1 7 60.18600000000001 60.07686233520508\n",
            "-1 8 68.784 68.65927124023438\n",
            "-1 9 77.382 77.24168395996094\n",
            "0 -10 -85.98 -85.82408905029297\n",
            "0 -9 -77.382 -77.24168395996094\n",
            "0 -8 -68.784 -68.65927124023438\n",
            "0 -7 -60.18600000000001 -60.07686233520508\n",
            "0 -6 -51.58800000000001 -51.49445343017578\n",
            "0 -5 -42.99 -42.912044525146484\n",
            "0 -4 -34.392 -34.32963562011719\n",
            "0 -3 -25.794000000000004 -25.74722671508789\n",
            "0 -2 -17.196 -17.164817810058594\n",
            "0 -1 -8.598 -8.582408905029297\n",
            "0 0 0.0 0.0\n",
            "0 1 8.598 8.582408905029297\n",
            "0 2 17.196 17.164817810058594\n",
            "0 3 25.794000000000004 25.74722671508789\n",
            "0 4 34.392 34.32963562011719\n",
            "0 5 42.99 42.912044525146484\n",
            "0 6 51.58800000000001 51.49445343017578\n",
            "0 7 60.18600000000001 60.07686233520508\n",
            "0 8 68.784 68.65927124023438\n",
            "0 9 77.382 77.24168395996094\n",
            "1 -10 -85.98 -85.82408905029297\n",
            "1 -9 -77.382 -77.24168395996094\n",
            "1 -8 -68.784 -68.65927124023438\n",
            "1 -7 -60.18600000000001 -60.07686233520508\n",
            "1 -6 -51.58800000000001 -51.49445343017578\n",
            "1 -5 -42.99 -42.912044525146484\n",
            "1 -4 -34.392 -34.32963562011719\n",
            "1 -3 -25.794000000000004 -25.74722671508789\n",
            "1 -2 -17.196 -17.164817810058594\n",
            "1 -1 -8.598 -8.582408905029297\n",
            "1 0 0.0 0.0\n",
            "1 1 8.598 8.582408905029297\n",
            "1 2 17.196 17.164817810058594\n",
            "1 3 25.794000000000004 25.74722671508789\n",
            "1 4 34.392 34.32963562011719\n",
            "1 5 42.99 42.912044525146484\n",
            "1 6 51.58800000000001 51.49445343017578\n",
            "1 7 60.18600000000001 60.07686233520508\n",
            "1 8 68.784 68.65927124023438\n",
            "1 9 77.382 77.24168395996094\n",
            "2 -10 9.138 9.120322227478027\n",
            "2 -9 9.138 9.120322227478027\n",
            "2 -8 9.138 9.120322227478027\n",
            "2 -7 9.138 9.120322227478027\n",
            "2 -6 9.138 9.120322227478027\n",
            "2 -5 9.138 9.120322227478027\n",
            "2 -4 9.138 9.120322227478027\n",
            "2 -3 9.138 9.120322227478027\n",
            "2 -2 9.138 9.120322227478027\n",
            "2 -1 9.138 9.120322227478027\n",
            "2 0 9.138 9.120322227478027\n",
            "2 1 9.138 9.120322227478027\n",
            "2 2 9.138 9.120322227478027\n",
            "2 3 9.138 9.120322227478027\n",
            "2 4 9.138 9.120322227478027\n",
            "2 5 9.138 9.120322227478027\n",
            "2 6 9.138 9.120322227478027\n",
            "2 7 9.138 9.120322227478027\n",
            "2 8 9.138 9.120322227478027\n",
            "2 9 9.138 9.120322227478027\n",
            "3 -10 13.707 13.680482864379883\n",
            "3 -9 13.707 13.680482864379883\n",
            "3 -8 13.707 13.680482864379883\n",
            "3 -7 13.707 13.680482864379883\n",
            "3 -6 13.707 13.680482864379883\n",
            "3 -5 13.707 13.680482864379883\n",
            "3 -4 13.707 13.680482864379883\n",
            "3 -3 13.707 13.680482864379883\n",
            "3 -2 13.707 13.680482864379883\n",
            "3 -1 13.707 13.680482864379883\n",
            "3 0 13.707 13.680482864379883\n",
            "3 1 13.707 13.680482864379883\n",
            "3 2 13.707 13.680482864379883\n",
            "3 3 13.707 13.680482864379883\n",
            "3 4 13.707 13.680482864379883\n",
            "3 5 13.707 13.680482864379883\n",
            "3 6 13.707 13.680482864379883\n",
            "3 7 13.707 13.680482864379883\n",
            "3 8 13.707 13.680482864379883\n",
            "3 9 13.707 13.680482864379883\n",
            "4 -10 18.276 18.240644454956055\n",
            "4 -9 18.276 18.240644454956055\n",
            "4 -8 18.276 18.240644454956055\n",
            "4 -7 18.276 18.240644454956055\n",
            "4 -6 18.276 18.240644454956055\n",
            "4 -5 18.276 18.240644454956055\n",
            "4 -4 18.276 18.240644454956055\n",
            "4 -3 18.276 18.240644454956055\n",
            "4 -2 18.276 18.240644454956055\n",
            "4 -1 18.276 18.240644454956055\n",
            "4 0 18.276 18.240644454956055\n",
            "4 1 18.276 18.240644454956055\n",
            "4 2 18.276 18.240644454956055\n",
            "4 3 18.276 18.240644454956055\n",
            "4 4 18.276 18.240644454956055\n",
            "4 5 18.276 18.240644454956055\n",
            "4 6 18.276 18.240644454956055\n",
            "4 7 18.276 18.240644454956055\n",
            "4 8 18.276 18.240644454956055\n",
            "4 9 18.276 18.240644454956055\n",
            "5 -10 22.845 22.800806045532227\n",
            "5 -9 22.845 22.800806045532227\n",
            "5 -8 22.845 22.800806045532227\n",
            "5 -7 22.845 22.800806045532227\n",
            "5 -6 22.845 22.800806045532227\n",
            "5 -5 22.845 22.800806045532227\n",
            "5 -4 22.845 22.800806045532227\n",
            "5 -3 22.845 22.800806045532227\n",
            "5 -2 22.845 22.800806045532227\n",
            "5 -1 22.845 22.800806045532227\n",
            "5 0 22.845 22.800806045532227\n",
            "5 1 22.845 22.800806045532227\n",
            "5 2 22.845 22.800806045532227\n",
            "5 3 22.845 22.800806045532227\n",
            "5 4 22.845 22.800806045532227\n",
            "5 5 22.845 22.800806045532227\n",
            "5 6 22.845 22.800806045532227\n",
            "5 7 22.845 22.800806045532227\n",
            "5 8 22.845 22.800806045532227\n",
            "5 9 22.845 22.800806045532227\n",
            "6 -10 27.414 27.360965728759766\n",
            "6 -9 27.414 27.360965728759766\n",
            "6 -8 27.414 27.360965728759766\n",
            "6 -7 27.414 27.360965728759766\n",
            "6 -6 27.414 27.360965728759766\n",
            "6 -5 27.414 27.360965728759766\n",
            "6 -4 27.414 27.360965728759766\n",
            "6 -3 27.414 27.360965728759766\n",
            "6 -2 27.414 27.360965728759766\n",
            "6 -1 27.414 27.360965728759766\n",
            "6 0 27.414 27.360965728759766\n",
            "6 1 27.414 27.360965728759766\n",
            "6 2 27.414 27.360965728759766\n",
            "6 3 27.414 27.360965728759766\n",
            "6 4 27.414 27.360965728759766\n",
            "6 5 27.414 27.360965728759766\n",
            "6 6 27.414 27.360965728759766\n",
            "6 7 27.414 27.360965728759766\n",
            "6 8 27.414 27.360965728759766\n",
            "6 9 27.414 27.360965728759766\n",
            "7 -10 31.983 31.921127319335938\n",
            "7 -9 31.983 31.921127319335938\n",
            "7 -8 31.983 31.921127319335938\n",
            "7 -7 31.983 31.921127319335938\n",
            "7 -6 31.983 31.921127319335938\n",
            "7 -5 31.983 31.921127319335938\n",
            "7 -4 31.983 31.921127319335938\n",
            "7 -3 31.983 31.921127319335938\n",
            "7 -2 31.983 31.921127319335938\n",
            "7 -1 31.983 31.921127319335938\n",
            "7 0 31.983 31.921127319335938\n",
            "7 1 31.983 31.921127319335938\n",
            "7 2 31.983 31.921127319335938\n",
            "7 3 31.983 31.921127319335938\n",
            "7 4 31.983 31.921127319335938\n",
            "7 5 31.983 31.921127319335938\n",
            "7 6 31.983 31.921127319335938\n",
            "7 7 31.983 31.921127319335938\n",
            "7 8 31.983 31.921127319335938\n",
            "7 9 31.983 31.921127319335938\n",
            "8 -10 36.552 36.48128890991211\n",
            "8 -9 36.552 36.48128890991211\n",
            "8 -8 36.552 36.48128890991211\n",
            "8 -7 36.552 36.48128890991211\n",
            "8 -6 36.552 36.48128890991211\n",
            "8 -5 36.552 36.48128890991211\n",
            "8 -4 36.552 36.48128890991211\n",
            "8 -3 36.552 36.48128890991211\n",
            "8 -2 36.552 36.48128890991211\n",
            "8 -1 36.552 36.48128890991211\n",
            "8 0 36.552 36.48128890991211\n",
            "8 1 36.552 36.48128890991211\n",
            "8 2 36.552 36.48128890991211\n",
            "8 3 36.552 36.48128890991211\n",
            "8 4 36.552 36.48128890991211\n",
            "8 5 36.552 36.48128890991211\n",
            "8 6 36.552 36.48128890991211\n",
            "8 7 36.552 36.48128890991211\n",
            "8 8 36.552 36.48128890991211\n",
            "8 9 36.552 36.48128890991211\n",
            "9 -10 41.121 41.04145050048828\n",
            "9 -9 41.121 41.04145050048828\n",
            "9 -8 41.121 41.04145050048828\n",
            "9 -7 41.121 41.04145050048828\n",
            "9 -6 41.121 41.04145050048828\n",
            "9 -5 41.121 41.04145050048828\n",
            "9 -4 41.121 41.04145050048828\n",
            "9 -3 41.121 41.04145050048828\n",
            "9 -2 41.121 41.04145050048828\n",
            "9 -1 41.121 41.04145050048828\n",
            "9 0 41.121 41.04145050048828\n",
            "9 1 41.121 41.04145050048828\n",
            "9 2 41.121 41.04145050048828\n",
            "9 3 41.121 41.04145050048828\n",
            "9 4 41.121 41.04145050048828\n",
            "9 5 41.121 41.04145050048828\n",
            "9 6 41.121 41.04145050048828\n",
            "9 7 41.121 41.04145050048828\n",
            "9 8 41.121 41.04145050048828\n",
            "9 9 41.121 41.04145050048828\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "BOhnb7k2u5of"
      },
      "execution_count": null,
      "outputs": []
    }
  ]
}