{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3b48e850-8215-496f-8158-e3bcff45364c",
   "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",
      "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",
      "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",
      "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 = 16\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.])\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",
    "    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) * n_scale , 36)\n",
    "np.savetxt('强度36.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 , 1)\n",
    "np.savetxt('强度1.npy', matrix1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "557ecfd9-b3b5-4605-9c94-5e029c418239",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('强度1.npy')\n",
    "matrix2 = np.loadtxt('强度16.npy')\n",
    "matrix3 = np.loadtxt('强度36.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='1', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='16', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='36', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend()\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "plt.title('Column Mean Values of Matrices')\n",
    "plt.xlabel('n')\n",
    "plt.ylabel('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": "11bd178f-2cb1-4590-9b2f-c9cf3fe1884a",
   "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
}
