{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3b48e850-8215-496f-8158-e3bcff45364c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_43/3472280446.py:84: UserWarning: Creating a tensor from a list of numpy.ndarrays is extremely slow. Please consider converting the list to a single numpy.ndarray with numpy.array() before converting to a tensor. (Triggered internally at /opt/pytorch/pytorch/torch/csrc/utils/tensor_new.cpp:230.)\n",
      "  D = torch.tensor(D, dtype=torch.float32).cuda()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n",
      "99\n"
     ]
    }
   ],
   "source": [
    "import math\n",
    "import numpy\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "\n",
    "M = 2\n",
    "d = 1024\n",
    "n_ = 100\n",
    "dh = 512\n",
    "dv = 512\n",
    "cp = 4\n",
    "class TF(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.q = nn.Linear(d, dh, bias=False)\n",
    "        self.k = nn.Linear(d, dh, bias=False)\n",
    "        self.v = nn.Linear(d, dv, bias=False)\n",
    "        self.fc = nn.Linear(dv, 1, bias=False)\n",
    "        self.fc.requires_grad_(False)\n",
    "        self.q.weight.data /= 16\n",
    "        self.k.weight.data /= 16\n",
    "        self.v.weight.data /= 16\n",
    "\n",
    "\n",
    "    def forward(self, x):\n",
    "        q = self.q(x)\n",
    "        k = self.k(x)\n",
    "        v = self.v(x)\n",
    "        qk = torch.matmul(q, k.transpose(1, 2))\n",
    "        attn = qk.softmax(dim=2)\n",
    "        attn = torch.sum(attn, dim=1).unsqueeze(1)\n",
    "        attn /= 16\n",
    "        z = torch.matmul(attn, v).squeeze(1)\n",
    "        return self.fc(z)\n",
    "\n",
    "def make_mu1(mu):\n",
    "    mu1 = numpy.zeros(d)\n",
    "    mu1[0] = mu\n",
    "    return mu1\n",
    "\n",
    "def make_mu2(mu):\n",
    "    mu2 = numpy.zeros(d)\n",
    "    mu2[1] = mu\n",
    "    return mu2\n",
    "\n",
    "def make_noise(strength):\n",
    "    noise =  numpy.random.normal(0, strength, size=d)\n",
    "    \n",
    "#     norm = np.linalg.norm(noise)\n",
    "    \n",
    "#     return  noise * (36 / norm)\n",
    "    return noise\n",
    "    \n",
    "def get_test_loss(n, mu):\n",
    "    D = []\n",
    "    D_Y = []\n",
    "    D_ = []\n",
    "    D_Y_ = []\n",
    "\n",
    "    mu1 = make_mu1(mu)\n",
    "    mu2 = make_mu2(mu)\n",
    "\n",
    "    D_mu = []\n",
    "    D_mu_ = []\n",
    "\n",
    "    for i in range(int(n / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        D_Y.append([1.]) if np.random.rand() > 0.1 else D_Y.append([-1.])\n",
    "        D_mu.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        #标签反转\n",
    "        D_Y.append([-1.]) if np.random.rand() > 0.1 else D_Y.append([1.])\n",
    "        D_mu.append(mu2.reshape(1, d))\n",
    "\n",
    "    D = torch.tensor(D, dtype=torch.float32).cuda()\n",
    "    D_Y = torch.tensor(D_Y).cuda()\n",
    "\n",
    "    for i in range(int(n_ / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([1.])\n",
    "        D_mu_.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([-1.])\n",
    "        D_mu_.append(mu2.reshape(1, d))\n",
    "\n",
    "    D_ = torch.tensor(D_, dtype=torch.float32).cuda()\n",
    "    D_Y_ = torch.tensor(D_Y_).cuda()\n",
    "\n",
    "    model = TF().cuda()\n",
    "\n",
    "    optimizer = optim.SGD(model.parameters(), lr=0.1, momentum=0)\n",
    "    loss_fn = nn.SoftMarginLoss().cuda()\n",
    "    EPOCHS = 1000\n",
    "\n",
    "    for epoch in range(1, EPOCHS + 1):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        output = model(D)\n",
    "\n",
    "        training_loss = loss_fn(output, D_Y)\n",
    "        training_loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        model.eval()\n",
    "        output = model(D_)\n",
    "        test_loss = loss_fn(output, D_Y_)\n",
    "\n",
    "        if training_loss < 0.01:\n",
    "            return test_loss\n",
    "\n",
    "size = 100\n",
    "Size = 10 \n",
    "n_scale = 2\n",
    "mu_scale = 1\n",
    "matrix = np.zeros((size, Size))\n",
    "for n in range(size):\n",
    "    print(n)\n",
    "    for mu in range(10):\n",
    "        matrix[n, mu] = get_test_loss(int((n + 10) / 10)  , 16)\n",
    "np.savetxt('0.1.npy', matrix)\n",
    "\n",
    "# matrix1 = np.zeros((size, Size))\n",
    "# for n in range(size):\n",
    "#     print(n)\n",
    "#     for mu in range(10):\n",
    "#         matrix1[n, mu] = get_test_loss(int((n + 10) / 10) * n_scale , 64)\n",
    "# np.savetxt('64.npy', matrix1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "557ecfd9-b3b5-4605-9c94-5e029c418239",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DGAJEVgAHZqbm4tLly6VngEsIQILIIPJycl48+ZN6RnAEiGwABapv78/BgYGIiJifn4+ms1m4UXAUiGwABapt7f3p18NPnz4MKampgouApYKgQXQgZMnT8amTZva51/9j0Lgv0lgAXRg+fLlMTY21j5PTU3FgwcPCi4ClgKBBdChgwcPxtDQUPvcbDZjfn6+4CKgNIEFkMH4+Hj79bdv38bExETBNUBpAgsgg127dsXevXvb51arFXNzcwUXASUJLIBMrl+/Hr/99seX1c+fP8eNGzcKLwJKEVgAmWzbti2OHDnSPo+Pj8eXL18KLgJKEVgAGV25ciXq9XpERHz9+jWuXr1aeBFQgsACyGjdunUxOjraPt++fTs+fvxYcBFQgsACyOzChQuxcuXKiIj48eNHXLx4sfAioGoCCyCzRqPx0zO637t3L2ZmZgouAqomsAC64PTp07FmzZqIiFhYWIhz584VXgRUSWABdEFfX1+0Wq32+dGjR/HixYtyg4BKCSyALjl27Fhs2bKlfT5z5kzBNUCVBBZAl/T09Pz0NA3T09Nx//79gouAqggsgC7at29f7Nixo30+f/58wTVAVQQWQJf9+UbQ79+/L7gEqIrAAuiynTt3xvDwcOkZQIUEFkAFrl27Fj09PaVnABURWAAV2Lp1axw9erT0DKAiy1JKqfQIAID/Ej/BAgDITGABAGQmsAAAMhNYAACZCSwAgMwEFgBAZgILACAzgQUAkJnAAgDITGABAGQmsAAAMhNYAACZCSwAgMwEFgBAZgILACCz3wFK0B1nTbMcqQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('16.npy')\n",
    "matrix2 = np.loadtxt('36.npy')\n",
    "matrix3 = np.loadtxt('64.npy')\n",
    "\n",
    "matplotlib.rcParams['xtick.labelsize'] = 16\n",
    "matplotlib.rcParams['ytick.labelsize'] = 16\n",
    "\n",
    "# 计算每个矩阵列方向的平均值\n",
    "mean_matrix1 = np.mean(matrix1, axis=1)\n",
    "mean_matrix2 = np.mean(matrix2, axis=1)\n",
    "mean_matrix3 = np.mean(matrix3, axis=1)\n",
    "\n",
    "\n",
    "# 假设要均匀抽出10条数据\n",
    "num_samples = 10\n",
    "sample_indices = np.linspace(0, len(mean_matrix1) - 1, num_samples, dtype=int)\n",
    "\n",
    "# 抽取数据\n",
    "sampled_matrix1 = mean_matrix1[sample_indices]\n",
    "sampled_matrix2 = mean_matrix2[sample_indices]\n",
    "sampled_matrix3 = mean_matrix3[sample_indices]\n",
    "\n",
    "\n",
    "# 生成x轴数据\n",
    "x = np.arange(num_samples)\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(x, sampled_matrix1, label='SNR=1/8', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='SNR=9/32', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='SNR=1/2', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend(fontsize=14)\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "# plt.title('The impact of data volume on testing loss')\n",
    "plt.xlabel('N',size=26)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n",
    "plt.ylabel('Test_Loss',size=26)\n",
    "plt.xticks(x,[2,4,6,8,10,12,14,16,18,20])\n",
    "# 显示折线图\n",
    "\n",
    "\n",
    "plt.savefig('SNR_N.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "11bd178f-2cb1-4590-9b2f-c9cf3fe1884a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "mat1 and mat2 shapes cannot be multiplied (1x0 and 1024x512)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[0;32mIn [12], line 140\u001b[0m\n\u001b[1;32m    138\u001b[0m     \u001b[38;5;28mprint\u001b[39m(n)\n\u001b[1;32m    139\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m mu \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m100\u001b[39m):\n\u001b[0;32m--> 140\u001b[0m         matrix[n, mu] \u001b[38;5;241m=\u001b[39m \u001b[43mGet_test_loss\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mint\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmu\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m10\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m/\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m10\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mn_scale\u001b[49m\u001b[43m \u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m16\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m0.1\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    141\u001b[0m np\u001b[38;5;241m.\u001b[39msavetxt(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m0.npy\u001b[39m\u001b[38;5;124m'\u001b[39m, matrix)\n\u001b[1;32m    143\u001b[0m \u001b[38;5;66;03m# matrix1 = np.zeros((20, 100))\u001b[39;00m\n\u001b[1;32m    144\u001b[0m \u001b[38;5;66;03m# for n in range(size):\u001b[39;00m\n\u001b[1;32m    145\u001b[0m \u001b[38;5;66;03m#     print(n)\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    154\u001b[0m \u001b[38;5;66;03m#         matrix2[n, mu] = Get_test_loss(int((mu + 10) / 10) * n_scale , 36, 0.001)\u001b[39;00m\n\u001b[1;32m    155\u001b[0m \u001b[38;5;66;03m# np.savetxt('0.001.npy', matrix2)\u001b[39;00m\n",
      "Cell \u001b[0;32mIn [12], line 118\u001b[0m, in \u001b[0;36mGet_test_loss\u001b[0;34m(n, mu, p)\u001b[0m\n\u001b[1;32m    116\u001b[0m model\u001b[38;5;241m.\u001b[39mtrain()\n\u001b[1;32m    117\u001b[0m optimizer\u001b[38;5;241m.\u001b[39mzero_grad()\n\u001b[0;32m--> 118\u001b[0m output \u001b[38;5;241m=\u001b[39m \u001b[43mmodel\u001b[49m\u001b[43m(\u001b[49m\u001b[43mD\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    120\u001b[0m training_loss \u001b[38;5;241m=\u001b[39m loss_fn(output, D_Y)\n\u001b[1;32m    121\u001b[0m training_loss\u001b[38;5;241m.\u001b[39mbackward()\n",
      "File \u001b[0;32m/usr/local/lib/python3.8/dist-packages/torch/nn/modules/module.py:1190\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1186\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1187\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1188\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1189\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1190\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1191\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1192\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "Cell \u001b[0;32mIn [12], line 28\u001b[0m, in \u001b[0;36mTF.forward\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m     27\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, x):\n\u001b[0;32m---> 28\u001b[0m     q \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mq\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     29\u001b[0m     k \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mk(x)\n\u001b[1;32m     30\u001b[0m     v \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mv(x)\n",
      "File \u001b[0;32m/usr/local/lib/python3.8/dist-packages/torch/nn/modules/module.py:1190\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1186\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1187\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1188\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1189\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1190\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1191\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1192\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m/usr/local/lib/python3.8/dist-packages/torch/nn/modules/linear.py:114\u001b[0m, in \u001b[0;36mLinear.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    113\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m: Tensor) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Tensor:\n\u001b[0;32m--> 114\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mF\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlinear\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mweight\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbias\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: mat1 and mat2 shapes cannot be multiplied (1x0 and 1024x512)"
     ]
    }
   ],
   "source": [
    "# n关于标签翻转\n",
    "import math\n",
    "import numpy\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "\n",
    "M = 2\n",
    "d = 1024\n",
    "n_ = 100\n",
    "dh = 512\n",
    "dv = 512\n",
    "cp = 4\n",
    "class TF(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.q = nn.Linear(d, dh, bias=False)\n",
    "        self.k = nn.Linear(d, dh, bias=False)\n",
    "        self.v = nn.Linear(d, dv, bias=False)\n",
    "        self.fc = nn.Linear(dv, 1, bias=False)\n",
    "        self.fc.requires_grad_(False)\n",
    "        self.q.weight.data /= 16\n",
    "        self.k.weight.data /= 16\n",
    "        self.v.weight.data /= 16\n",
    "\n",
    "\n",
    "    def forward(self, x):\n",
    "        q = self.q(x)\n",
    "        k = self.k(x)\n",
    "        v = self.v(x)\n",
    "        qk = torch.matmul(q, k.transpose(1, 2))\n",
    "        attn = qk.softmax(dim=2)\n",
    "        attn = torch.sum(attn, dim=1).unsqueeze(1)\n",
    "        attn /= 16\n",
    "        z = torch.matmul(attn, v).squeeze(1)\n",
    "        return self.fc(z)\n",
    "\n",
    "def make_mu1(mu):\n",
    "    mu1 = numpy.zeros(d)\n",
    "    mu1[0] = mu\n",
    "    return mu1\n",
    "\n",
    "def make_mu2(mu):\n",
    "    mu2 = numpy.zeros(d)\n",
    "    mu2[1] = mu\n",
    "    return mu2\n",
    "\n",
    "def make_noise(strength):\n",
    "    noise =  numpy.random.normal(0, strength, size=d)\n",
    "    \n",
    "    # norm = np.linalg.norm(noise)\n",
    "    \n",
    "    return  noise \n",
    "\n",
    "def Get_test_loss(n, mu,p):\n",
    "    D = []\n",
    "    D_Y = []\n",
    "    D_ = []\n",
    "    D_Y_ = []\n",
    "\n",
    "    mu1 = make_mu1(mu)\n",
    "    mu2 = make_mu2(mu)\n",
    "\n",
    "    D_mu = []\n",
    "    D_mu_ = []\n",
    "\n",
    "    for i in range(int(n / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        D_Y.append([1.])\n",
    "        # if np.random.rand() > 0.001 else D_Y.append([-1.])\n",
    "        D_mu.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        #标签反转\n",
    "        D_Y.append([-1.]) \n",
    "        # if np.random.rand() > 0.001 else D_Y.append([1.])\n",
    "        D_mu.append(mu2.reshape(1, d))\n",
    "\n",
    "    D = torch.tensor(D, dtype=torch.float32).cuda()\n",
    "    D_Y = torch.tensor(D_Y).cuda()\n",
    "\n",
    "    for i in range(int(n_ / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([1.])\n",
    "        D_mu_.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([-1.])\n",
    "        D_mu_.append(mu2.reshape(1, d))\n",
    "\n",
    "    D_ = torch.tensor(D_, dtype=torch.float32).cuda()\n",
    "    D_Y_ = torch.tensor(D_Y_).cuda()\n",
    "\n",
    "    model = TF().cuda()\n",
    "\n",
    "    optimizer = optim.SGD(model.parameters(), lr=0.1, momentum=0)\n",
    "    loss_fn = nn.SoftMarginLoss().cuda()\n",
    "    EPOCHS = 1000\n",
    "\n",
    "    test_losses = []\n",
    "    for epoch in range(1, EPOCHS + 1):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        output = model(D)\n",
    "\n",
    "        training_loss = loss_fn(output, D_Y)\n",
    "        training_loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        model.eval()\n",
    "        output = model(D_)\n",
    "        test_loss = loss_fn(output, D_Y_)\n",
    "        # return test_loss\n",
    "        \n",
    "    return test_loss \n",
    "        \n",
    "        \n",
    "size = 20\n",
    "n_scale = 1\n",
    "mu_scale = 1\n",
    "\n",
    "matrix = np.zeros((20, 100))\n",
    "for n in range(size):\n",
    "    print(n)\n",
    "    for mu in range(100):\n",
    "        matrix[n, mu] = Get_test_loss(int((mu + 10) / 10) * n_scale , 16, 0.1)\n",
    "np.savetxt('0.npy', matrix)\n",
    "\n",
    "# matrix1 = np.zeros((20, 100))\n",
    "# for n in range(size):\n",
    "#     print(n)\n",
    "#     for mu in range(10):\n",
    "#         matrix1[n, mu] = Get_test_loss(int((mu + 10) / 10) * n_scale , 36, 0.01)\n",
    "# np.savetxt('0.01.npy', matrix1)\n",
    "\n",
    "# matrix2 = np.zeros((20, 100))\n",
    "# for n in range(size):\n",
    "#     print(n)\n",
    "#     for mu in range(10):\n",
    "#         matrix2[n, mu] = Get_test_loss(int((mu + 10) / 10) * n_scale , 36, 0.001)\n",
    "# np.savetxt('0.001.npy', matrix2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "4ac31079-4420-4552-9a5e-50dd83b500cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('0.1.npy')\n",
    "matrix2 = np.loadtxt('0.01.npy')\n",
    "matrix3 = np.loadtxt('0.001.npy')\n",
    "\n",
    "\n",
    "# 计算每个矩阵列方向的平均值\n",
    "mean_matrix1 = np.mean(matrix1, axis=1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            )\n",
    "mean_matrix2 = np.mean(matrix2, axis=1)\n",
    "mean_matrix3 = np.mean(matrix3, axis=1)\n",
    "\n",
    "\n",
    "# 假设要均匀抽出10条数据\n",
    "num_samples = 10\n",
    "sample_indices = np.linspace(0, len(mean_matrix1) - 1, num_samples, dtype=int)\n",
    "\n",
    "# 抽取数据\n",
    "sampled_matrix1 = mean_matrix1[sample_indices]\n",
    "sampled_matrix2 = mean_matrix2[sample_indices]\n",
    "sampled_matrix3 = mean_matrix3[sample_indices]\n",
    "\n",
    "\n",
    "# 生成x轴数据\n",
    "x = np.arange(num_samples)\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(x, sampled_matrix1, label='p=0.1', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='p=0.01' ,color='red')\n",
    "plt.plot(x, sampled_matrix3, label='p=0.001', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend()\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "plt.title('The impact of data volume on testing loss')\n",
    "plt.xlabel('n')\n",
    "plt.ylabel('test_loss')\n",
    "plt.xticks(x,[10,20,30,40,50,60,70,80,90,100])\n",
    "# 显示折线图\n",
    "plt.show()\n",
    "\n",
    "# plt.savefig('不同n对损失的影响.png', dpi=1200, bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "880e3ef2-0bfc-4367-8a6e-0ae03c0e406f",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
