{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c35e0541-0d12-4b7f-8ca8-8d5ef791232a",
   "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"
     ]
    }
   ],
   "source": [
    "\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",
    "\n",
    "# 生成噪声\n",
    "def make_noise(signal,strength):\n",
    "      \n",
    "    noise =  numpy.random.normal(0, strength, size=d)\n",
    "    \n",
    "    norm = np.linalg.norm(noise)\n",
    "    \n",
    "    return  noise * (36 / norm)\n",
    "   \n",
    "\n",
    "def get_test_loss(n, mu,M):\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(mu1,cp)).reshape(1, d)), 0)\n",
    "        \n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(mu1,0.2)).reshape(1, d)), 0)\n",
    "        \n",
    "        D.append(X)\n",
    "        D_Y.append([1.]) \n",
    "        # D_Y.append([1.]) if np.random.rand() >p else D_Y.append([-1.])\n",
    "        D_mu.append(mu1.reshape(1, d))\n",
    "        \n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(mu2,cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(mu2,0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        #标签反转\n",
    "        D_Y.append([-1.])\n",
    "        # D_Y.append([-1.]) if np.random.rand() > p 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(mu1,cp)).reshape(1, d)), 0)\n",
    "        \n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(mu1,0.2)).reshape(1, d)), 0)\n",
    "        \n",
    "        D_.append(X)\n",
    "        D_Y_.append([1.])\n",
    "        # D_Y_.append([1.])if np.random.rand() > p 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(mu2,cp)).reshape(1, d)), 0)\n",
    "        \n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(mu2,0.2)).reshape(1, d)), 0)\n",
    "        \n",
    "        D_.append(X)\n",
    "        D_Y_.append([-1.])\n",
    "        # D_Y_.append([-1.])if np.random.rand() > p 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",
    "    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",
    "n_scale = 2\n",
    "mu_scale = 1\n",
    "matrix = np.zeros((size, 17))\n",
    "for n in range(size):\n",
    "    print(n)\n",
    "    for mu in range(2,17):\n",
    "        matrix[n, mu] = get_test_loss(int((n + 10) / 10) * n_scale, 36 , mu)\n",
    "np.savetxt('matrix.npy', matrix)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b08d7bf6-2a15-4de7-912f-168c716ab1c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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KdjZ2VUaf9mJ42fOnBEE4b/Trf/8809lnf379wsAhAcPHgiCIAj+/v7C22+/rdKOn5+fSh/d3d2FH3/8UaXOwoULBX9/f+Xj48ePC/r6+sLcuXMFPT094ejRo5XGSUTq4wgQEalNeGxUpSoJCQlwdnaGs7Ozsszb2xtNmjRBQkLCM8XQvn175b/t7OwAAO3atStXlpaWpiwzNjaGu7u78rGDg4PK8zW5toODg8p1EhIS4Ofnp1Lf399f+e+CggJcu3YNb7zxBkxNTZVfixYtwrVr11Re895772HhwoX4v//7P/Ts2VPtOImoclwETURq8/T0hEgkqpWFzmKxuFyCJZPJytXT19dX/lskElVaplAoKnxNWZ3qJnNPu/bj16lKfn4+AGDt2rXlEiWJRKL8t0KhwN9//w2JRIKrV6+qHSMRVY0jQESkNisrKwQGBmLlypUoKCgo93x2djYAoHXr1rh9+zZu376tfC4+Ph7Z2dnw9vausO2mTZuqLEyWy+W4cOGCZjtQi1q3bo2TJ0+qlD2+KNzOzg6Ojo64fv06PDw8VL5cXV2V9T777DMkJibiyJEjiIiIwIYNG+qsD0SNARMgIqqRlStXQi6Xo2vXrti5cyeuXLmChIQErFixQjnlExAQgHbt2uH1119HXFwcYmNjMW7cOPTp0we+vr4Vtvv8889j//792L9/PxITEzF16lRlQtUQzJgxA+vXr8eGDRtw+fJlhIaG4uLFiyp1wsLCEB4ejhUrVuDy5cs4f/48NmzYgGXLlgEAzpw5g3nz5mHdunXo0aMHli1bhhkzZuD69eva6BKRTmICREQ14ubmhri4OPTt2xf/93//h7Zt26J///6IiorCqlWrAJROD/3222+wtLRE7969ERAQADc3N2zfvr3SdidNmoTx48crEyU3Nzf07du3rrr1zEaOHIm5c+di1qxZ6Ny5M27evImpU6eq1HnzzTexbt06bNiwAe3atUOfPn3www8/wNXVFUVFRRgzZgwmTJiAQYMGAQCmTJmCvn37YuzYsZDL5droFpHOEQk1mQAnIiIiasA4AkRERESNDhMgIiIianSYABEREVGjwwSIiIiIGh0mQERERNToMAEiIiKiRocJEBERETU6TICIiIio0WECRERERI0OEyAiIiJqdJgAERERUaPDBIiIiIganf8Hgi17P8nlaL4AAAAASUVORK5CYII=\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",
    "matrix = np.loadtxt('matrix.npy')\n",
    "\n",
    "# 计算每列的平均值\n",
    "column_means = np.mean(matrix, axis=0)\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(column_means, marker='o')\n",
    "plt.title('Average Values of Each Column')\n",
    "plt.xlabel('Column Index')\n",
    "plt.ylabel('Average Value')\n",
    "plt.grid(True)\n",
    "plt.show()\n",
    "plt.savefig('标准化m2到m16.png', dpi=1200, bbox_inches='tight')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76955740-b671-4771-a154-a2736568ed90",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48ba17ca-4093-431c-9c28-15a36e9accbc",
   "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
}
