{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "6fe1eede-e475-49a9-ad37-5bad3a5a4a21",
   "metadata": {},
   "source": [
    "本实验进行的是实验轮次对模型损失的影响\n",
    "\n",
    "重复实验20次，每次将1000个训练轮次的100个记录到矩阵中，并取平均值，最后画出实验结果\n",
    "\n",
    "参数\n",
    "m=16,学习率、动量保持不变。\n",
    "\n",
    "实验主要将数据量n、snr进行变动。并保存对应的数据集。其中每行代表一次训练的所有批次的损失值。行数就是实验的次数"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5bbc3c04-0845-4cdc-961d-9051f3725b9b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "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"
     ]
    }
   ],
   "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 /= M\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",
    "    # return numpy.random.normal(0, strength, size=d)\n",
    "    noise =  numpy.random.normal(0, strength, size=d)    \n",
    "    norm = np.linalg.norm(noise)\n",
    "    return  noise * (36 / norm)\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.])\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",
    "    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",
    "        if epoch%10 == 0:\n",
    "            test_losses.append(test_loss.item())\n",
    "\n",
    "    return test_losses   \n",
    "    \n",
    "size = 20\n",
    "matrix = np.zeros((size, 100))\n",
    "for n in range(size):\n",
    "    print(n)\n",
    "    test_losses = get_test_loss(10, 16)\n",
    "    matrix[n, :] = test_losses\n",
    "# t_n50_μ64    \n",
    "np.savetxt('t_n50_μ64.npy', matrix)\n",
    "# t_n100_μ64\n",
    "# np.savetxt('t_n100_μ64.npy', matrix)\n",
    "# t_n150_μ64\n",
    "# np.savetxt('t_n150_μ64.npy', matrix)\n",
    "# t_n100_μ36\n",
    "# np.savetxt('t_n100_μ36.npy', matrix)\n",
    "# t_n100_μ16\n",
    "# np.savetxt('t_n100_μ16.npy', matrix)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "166d1c73-91f6-4ccd-8fb3-d1b727d02c98",
   "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 matplotlib\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('t_n100_μ16.npy')\n",
    "matrix2 = np.loadtxt('t_n100_μ36.npy')\n",
    "matrix3 = np.loadtxt('t_n100_μ64.npy')\n",
    "matrix4 = np.loadtxt('t_n150_μ64.npy')\n",
    "matrix5 = np.loadtxt('t_n50_μ64.npy')\n",
    "\n",
    "matplotlib.rcParams['xtick.labelsize'] = 16\n",
    "matplotlib.rcParams['ytick.labelsize'] = 16\n",
    "\n",
    "# 计算每个矩阵列方向的平均值\n",
    "mean_matrix1 = np.mean(matrix1, axis=0)\n",
    "mean_matrix2 = np.mean(matrix2, axis=0)\n",
    "mean_matrix3 = np.mean(matrix3, axis=0)\n",
    "mean_matrix4 = np.mean(matrix4, axis=0)\n",
    "mean_matrix5 = np.mean(matrix5, axis=0)\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",
    "sampled_matrix4 = mean_matrix4[sample_indices]\n",
    "sampled_matrix5 = mean_matrix5[sample_indices]\n",
    "\n",
    "# 生成x轴数据\n",
    "x = np.arange(num_samples)\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(x, sampled_matrix1, label='n=100_SNR=1/8', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='n=100_SNR=9/32', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='n=100_SNR=1/2', color='green')\n",
    "plt.plot(x, sampled_matrix4, label='n=150_SNR=1/2', color='purple')\n",
    "plt.plot(x, sampled_matrix5, label='n=50_SNR=1/2', color='orange')\n",
    "\n",
    "# 添加图例\n",
    "plt.legend(fontsize=12)\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "plt.title('The impact of different SNR on test loss')\n",
    "plt.xlabel('epoch',size=20)\n",
    "plt.ylabel('test_loss',size=20)\n",
    "plt.xticks(x,[100,200,300,400,500,600,700,800,900,1000])\n",
    "# 显示折线图\n",
    "plt.show()\n",
    "\n",
    "# plt.savefig('轮次对损失的影响.png', dpi=1200, bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04c3dabd-c1be-488f-8097-0b080f8ab06e",
   "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
}
