{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3b644151-a207-4e50-b2e8-f4232fe52a57",
   "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",
      "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",
    "def make_noise(strength):\n",
    "    return numpy.random.normal(0, strength, size=d)\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.2 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.2 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",
    "      \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",
    "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(size):\n",
    "        matrix[n, mu] = get_test_loss(int((n + 10) / 10) * n_scale, (mu + 1) * mu_scale)\n",
    "np.savetxt('_0.2.npy', matrix)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7eb30d45-75bd-4834-a69e-596607037f35",
   "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",
      "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",
    "def make_noise(strength):\n",
    "    return numpy.random.normal(0, strength, size=d)\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",
    "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(size):\n",
    "        matrix[n, mu] = get_test_loss(int((n + 10) / 10) * n_scale, (mu + 1) * mu_scale)\n",
    "np.savetxt('matrix.npy', matrix)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1f192ed1-635f-4014-9afb-eb3b12eb71a1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "data": {
      "image/png": "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112Hp556qtNsuvXWW3HxxRdjyJAh8Hq9GD58OG644YYuVTdlV9ndbEvy7k6CwSBuueUWXHLJJZ1aRGn27NnweDy47rrrOs2GXWzevBnNzc24++67MWHCBPzrX//Cueeei/POOw9vvfVWp9n14IMP4pBDDkHfvn3h8/kwYcIEPPzwwzj++OP3yPXb+36sqamBz+dLmIB2pTEuZIbIXmfAtddei08//RTvvvtup9mwfv16XH/99Xj99df3eLW4ZJimiZEjR2LWrFkAgOHDh+PTTz/FI488gkmTJnWKTX/961/xpz/9CX/+859x6KGHYsWKFbjhhhtQXV3daTZ1NyKRCC688EJYloW5c+d2mh3Lli3DAw88gOXLlyeUR+4MTNMEAJx99tm48cYbAQDDhg3D+++/j0ceeQQnnHBCp9j14IMPYsmSJXjhhRcwYMAAvP3227j22mtRXV29R1Ysu8L3o7DnkJWINJkyZQpeeuklLFy4EH379u00O5YtW4bNmzfjyCOPhMfjgcfjwVtvvYXf/e538Hg8iMVie9ym3r1745BDDtHeO/jgg3drpHoqbrrppvhqxOGHH47LLrsMN954Y5dZvQEQL7ubbUne3cGuCcS3336L119/vVNXId555x1s3rwZ/fv3j4/5b7/9Fj/96U8xcODAPW5PZWUlPB5PlxrzbW1t+PnPf477778fEydOxBFHHIEpU6bEqyPvbpJ9P/bq1QvhcBj19fXa/l1hjAvZIZOIDmJZFqZMmYLnnnsOb775JgYNGtSp9pxyyin45JNPsGLFivjfyJEjcemll2LFihVwu9173KaxY8cmpHWtXLkSAwYM2OO27KK1tVUrOAMAbrc7/iuyKzBo0CD06tVLK8nb2NiIDz74IK2SvLlm1wTi66+/xhtvvIGKiopOswUALrvsMnz88cfamK+ursZNN92E1157bY/b4/P5cNRRR3WpMR+JRBCJRPb4mE/1/ThixAh4vV5tjH/11VdYt25dp45xIXvEndFBrr32Wvz5z3/GP//5TxQVFcX9eCUlJcjLy9vj9hQVFSXEYxQUFKCioqLT4jRuvPFGHHPMMZg1axYuvPBCfPjhh3j00UfTKiubayZOnIhf//rX6N+/Pw499FD8+9//xv33348rr7xyj9rR3NyMVatWxdtr1qzBihUrUF5ejv79++OGG27Ar371KwwePBiDBg3CtGnTUF1djXPOOadTbOrduzfOP/98LF++HC+99BJisVh8zJeXl8Pn8+1xm/r3758wkfF6vejVqxcOOuigTrHnpptuwkUXXYTjjz8eJ510EubPn48XX3wRixYt2i32dMSmE044ATfddBPy8vIwYMAAvPXWW3j66adx//337zabUn0/lpSU4KqrrsLUqVNRXl6O4uJi/L//9/8wZswYHH300bvNLmEP0LnJId0HAO3+PfHEE51tWpzOTvG0LMt68cUXrcMOO8zy+/3WkCFDrEcffbRT7WlsbLSuv/56q3///lYgELD2228/6xe/+IUVCoX2qB0LFy5sd/xMmjTJsqwdaZ7Tpk2zqqqqLL/fb51yyinWV1991Wk2rVmzJumYX7hwYafY1B67O8WzI/Y8/vjj1gEHHGAFAgFr6NCh1vPPP7/b7OmITZs2bbKuuOIKq7q62goEAtZBBx1k3XfffZZpmrvNpo58P7a1tVn//d//bZWVlVn5+fnWueeea23atGm32STsGaQUuCAIgiAIGSExEYIgCIIgZIRMIgRBEARByAiZRAiCIAiCkBEyiRAEQRAEISNkEiEIgiAIQkbIJEIQBEEQhIyQSYQgCIIgCBkhkwhB2Iu54oorYBgG1q5d26l2nHjiiV2iaJYgCLlFJhHCPk9LSwtmzZqFI488EoWFhfD7/ejbty+OO+443HbbbVi9enVnmyjkiF2TKsMwsHjx4nb3mTBhQpeYeAlCd0BqZwj7NE1NTTj22GPx8ccf44ADDsAPf/hDVFRUYOvWrfjwww9x9913Y//998f+++/f2aZ2a55++mm0trZ2thkat9xyC95+++3ONkMQujUyiRD2aebMmYOPP/4YV199NR599NGEJfc1a9YgFAp1knV7D/379+9sEzT2339/vPPOO3jxxRcxceLEzjZHELot4s4Q9ml2LWlfe+217frsBw0ahCFDhmjvLVy4EFdeeSUOOuggFBYWorCwECNHjkxardQwDJx44onYsGEDfvCDH6CyshJFRUU488wz8c033wAAvvjiC5xzzjkoLy9HUVERzj//fNTW1mrnWbt2LQzDwBVXXIHPPvsMZ555JkpLS1FYWIjTTjsNy5YtS+ve3377bUycOBGVlZXw+/0YPHgwbr/99rRWDJYvX47zzz8f/fv3h9/vR48ePXDUUUfh17/+tbZfezERu9wKyf6efPJJbf81a9bg6quvjl+rd+/euOKKK/Dtt9+mdd8AMGPGDHg8Hvz85z/vUmXhBaG7ISsRwj7NrtLSK1euxLBhwzp0zOzZs7Fq1SocffTROPfcc1FfX4/58+fjv/7rv/DVV1/hvvvuSzimrq4Oxx57LHr16oVJkyZh5cqVeOmll/Dll1/in//8J4477jiMGDECV155JZYtW4a///3v2L59O958882Ec33zzTcYO3YsjjzySPzkJz/Bt99+i7/97W84/vjj8eabb2L06NEp72Hu3Lm49tprUVpaiokTJ6Jnz55YunQpfv3rX2PhwoVYuHBhynLfK1aswDHHHAO3242zzz4bAwYMQH19PT7//HM8+uij+MUvfuF4/IwZM5LatnnzZuTn58ff++CDDzB+/Hi0tLTge9/7HgYPHoy1a9fiT3/6E1599VUsXrwY++23X8r73sXgwYNxzTXXYO7cuXjqqacwefLkDh8rCIJCZ5cRFYTO5J///KcFwCoqKrJ++tOfWq+99pq1detWx2O++eabhPcikYh16qmnWm632/r222+1bdhZFvnGG2/U3v/JT35iAbBKS0utOXPmxN83TdM644wzLADWsmXL4u+r5blvvfVW7Vzz58+3AFiHH3649v6kSZMsANaaNWvi73322WeWx+Oxhg4dmnCvd911lwXAuvfeex37wLIsa+rUqRaAdktf83lPOOEEqyNfN3fffbcFwDr77LOtWCxmWZZlhcNha+DAgVZRUZG1fPlybf933nnHcrvd1ve+972U57Ysuz8WL15s1dTUWIWFhVbfvn2ttra2+D7jx49P6DNBENpHJhHCPs99991nFRYWxv9BA7D2339/69prr7VWrlzZ4fP8/e9/twBYTz75pPY+AKuwsNBqaWnR3n/77bfj1zJNU9v29NNPWwCsefPmxd/bNYkoLS21mpqaEq5/yimnWACspUuXxt9rbxJx3XXXWQCst99+O+EcsVjM6tGjhzVixIiU97trEvHaa6+l3Lcjk4i///3vlmEY1pFHHmk1NzfH3//HP/5hAbDuvPPOdo8777zzLJfLZTU0NKS0Q51EWJZlTZ8+3QJgzZ49O76PTCIEoeOIO0PY55k6dSquueYazJ8/H++//z6WLl2KDz74AA8//DAef/xxPPvsszjrrLPi+zc1NeHee+/F888/j9WrV6OlpUU738aNGxOuMXjwYG15HgB69+4NADjiiCMS4gV2bWvvXMOHD0dhYWHC+8cddxwWLFiAf//73xgxYkTS+12yZAkA4LXXXsOCBQsStnu9Xnz55ZdJj9/FhRdeiDlz5uDcc8/FRRddhFNPPRXHH388+vTpk/JYZunSpbjssstQXV2NF198EQUFBQn2fvXVV5g5c2bCsTU1NTBNEytXrsTIkSPTuu7PfvYzzJ07F3fffff/b+f+Qprq4ziOvxerOchWSAgK81/QRQuUkAIxV1RUJOqFVBexQAwNjBTqYlB0IeWUusm2oiAK9CYvioVCUjpXhAUbZhB1USuJIKIyCyURn4vnWTy6P87TU8Gzzwt2c875fc/3sIt9d37f34/6+npWrVq16NxF0pmKCBEgMzOT2tpaamtrARgfH8ftduP1eqmrq+Pt27csW7aM79+/43Q6CYVClJSUcODAAbKysjCbzUQiEa5duxZ3NceKFStijpnN5gXPTU9Px5zLzs6O+wzR4+Pj40mf9ePHjwAxzY+LtXHjRgYHBzl9+jTd3d1cvXoVgNLSUjweD1u2bEkpztjYGJWVlZhMJvx+Pzk5OXHz7erqShpnfjGXiszMTE6cOMGRI0c4c+YM7e3ti44hks60OkMkDpvNRmdnJ3l5eXz48IHR0VEAbt26RSgUoq6ujlAohM/no7W1lVOnTrFz587fktv8VRvzj9tstqTjo0XLly9fmP17SjPuJxXl5eX09fXx6dMnBgYGaGlpYXR0dM7Kk2QmJibYs2cP79+/p7u7m5KSkoT5+v3+pPlWVFSklPN8DQ0NFBUVcf78ecbGxgzFEElXKiJEEjCZTHNeqwM/dq+sqqqKuT4YDP6WvMLhMF+/fk14/3g/xP8WXb0RnSb4L1itVpxOJ2fPnsXtdjM5OUl/f3/SMTMzM+zbt48nT57Q0dExZ8ooXr6Jdpj8WUuXLqW1tZWpqSlOnjz5S+4h8n+lIkLS2qVLl3j8+HHcczdv3uTZs2esXLkSh8MBQF5eHgD379+fc20gEODy5cu/Ntl/fP78OWYqItrf4HA4kvZDABw+fBiz2UxTUxNv3ryJGz8cDi+Yx8OHD5mamoo5Hn0jkpGRkXT80aNH6e3t5dChQ7S0tCS8rqqqCrvdzrlz5+LuMDk9PR3zfSzW3r172bBhA9evX+fFixc/FUsknagnQtJaX18fDQ0NrFmzhrKyMnJycvj27RvhcJhgMMiSJUvwer1YLBYAKisryc/Pp729nadPn+JwOHj+/Dm3b9+mpqaGnp6eX55zeXk5Pp+P4eFhNm3aRCQS4caNG1itVq5cubLgeIfDgdfrpbGxkbVr17J7926KioqYmJjg5cuXBAIBDh48yMWLF5PG8Xg8DAwMsHnzZgoKCsjIyCAUCnH37l0KCwupqalJOPbRo0d0dnZitVpZvXp13IbJ6upqiouLsVgs9PT0sGvXLioqKti6dSvr16/HZDLx+vVrgsEgWVlZKTWDJmIymWhra2P79u28evXKcByRdKMiQtKax+OhrKyM/v5+hoaGePfuHQC5ubm4XC6amprm/LNfvnw59+7d49ixYwwNDTE4OMi6devo6uoiOzv7txQRhYWF+Hw+jh8/zoULF5iZmcHpdNLW1rbgW4io+vp6iouLf/y79/v92Gw27HY7zc3NuFyuBWM0NjZis9kYHh4mEAgwOzuL3W7H7XbT3Nwct2E0Kror5uTkZMIGz/z8/B8bgJWWljIyMkJHRwe9vb08ePAAi8VCbm4u1dXV7N+/P6XnTmbbtm3s2LGDO3fu/HQskXRhmk21g0pE/qhIJEJBQQEulytmS2gRkT9BPREiIiJiiIoIERERMURFhIiIiBiinggRERExRG8iRERExBAVESIiImKIiggRERExREWEiIiIGKIiQkRERAxRESEiIiKGqIgQERERQ1REiIiIiCEqIkRERMSQvwCYbbr0skJ2QgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.ndimage import convolve\n",
    "\n",
    "# 禁用LaTeX渲染\n",
    "matplotlib.rcParams['text.usetex'] = False\n",
    "\n",
    "size = 100\n",
    "matrix = np.loadtxt('_0.2.npy')\n",
    "matrix[np.isnan(matrix)] = 0\n",
    "\n",
    "# 对矩阵进行处理，计算每一个矩阵周围的平均值\n",
    "kernel = np.array([[1, 1, 1],\n",
    "                   [1, 1, 1],\n",
    "                   [1, 1, 1]]) / 9\n",
    "\n",
    "# 使用卷积计算每个元素及其周围元素的平均值\n",
    "matrix = convolve(matrix, kernel, mode='constant', cval=0.0)\n",
    "\n",
    "matrix = matrix.T\n",
    "\n",
    "\n",
    "# matrix[matrix > 0.85] = 1.2\n",
    "# matrix[matrix < 0.5] = 0\n",
    "\n",
    "# matrix[(matrix > 0.5)&(matrix < 0.6)] = 0.8\n",
    "# x = []\n",
    "# y = []\n",
    "# 自己生成拟合的曲线\n",
    "# for i in range(size):\n",
    "#     x.append(i + 1)\n",
    "#     y.append(60480 / (i + 10)**0.5 +30)\n",
    "# plt.plot(x, y, color='red', linewidth=5, label=r'$N \\cdot \\mathrm{SNR}^2 = 1000$')\n",
    "\n",
    "# 根据理论拟合的曲线\n",
    "x = np.linspace(0.1, 100, 400)  # 从0.1开始以避免除以0的错误\n",
    "\n",
    "# 计算y的值\n",
    "y = 520 / np.sqrt(x)\n",
    "\n",
    "# 创建图形\n",
    "plt.figure()\n",
    "\n",
    "# 绘制曲线\n",
    "# plt.plot(x, y, color='red', linewidth=5 ,label=r'$N \\cdot \\mathrm{SNR}^2 = Ω(1)$' )\n",
    "\n",
    "# matrix[matrix < 0.2] = 0\n",
    "# matrix[matrix >= 0.2] = 1\n",
    "vmin = 0\n",
    "vmax = 1\n",
    "\n",
    "#将矩阵中对应位置上的值转换为颜色\n",
    "# cmap 参数指定颜色映射（colormap），用于将矩阵中的数值映射为颜色。\n",
    "# 'viridis' 是一种常用的颜色映射，从紫色到黄色渐变\n",
    "# 'nearest' 表示使用最近邻插值，即每个像素直接使用矩阵中对应位置的值\n",
    "# origin 参数指定矩阵的起始位置'lower' 表示矩阵的第一行对应图像的下方，最后一行对应图像的上方。\n",
    "# plt.imshow(matrix, cmap='viridis', interpolation='nearest', origin='lower')\n",
    "plt.imshow(matrix, cmap='viridis', interpolation='nearest', origin='lower', vmin=vmin, vmax=vmax)\n",
    "#添加一个颜色条，由最大值和最小值决定，出现白色的点说明出现了异常值\n",
    "plt.colorbar()\n",
    "\n",
    "\n",
    "plt.ylabel('Signal-to-Noise Ratio SNR', size=14)\n",
    "plt.xlabel('Sample size N', size=14)\n",
    "\n",
    "y_label = np.array((0.16, 5, 10, 15))\n",
    "x_label = np.arange(2, 22, 2)\n",
    "y_ticks = np.array((0, 31, 63, 95))\n",
    "x_ticks = np.arange(0, size, 10)\n",
    "\n",
    "plt.xticks(x_ticks, x_label)\n",
    "plt.yticks(y_ticks, y_label)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='best')\n",
    "\n",
    "plt.savefig('heatmap-0.2.png', dpi=300, bbox_inches='tight')\n",
    "\n",
    "plt.show()\n",
    "\n",
    "#随着映射范围的变化而发生改变\n",
    "#M=2,标签反转0.1\n",
    "# matrix[matrix < 0.5] = 0\n",
    "# matrix[matrix >= 0.5] = 1\n",
    "#M=2,标签反转0.01\n",
    "# matrix[matrix < 0.25] = 0\n",
    "# matrix[matrix >= 0.25] = 1\n",
    "#M=2,标签反转0.001\n",
    "# matrix[matrix < 0.1] = 0\n",
    "# matrix[matrix >= 0.1] = 1\n",
    "# plt.cla()\n",
    "# plt.clf()\n",
    "\n",
    "# plt.figure(1)\n",
    "# plt.plot(x, y, color='red', linewidth=5, label=r'$N \\cdot \\mathrm{SNR}^2 = 1000$')\n",
    "# plt.imshow(matrix, cmap='viridis', interpolation='nearest', origin='lower')\n",
    "# plt.colorbar()\n",
    "# plt.xlabel('Signal-to-Noise Ratio SNR', size=14)\n",
    "# plt.ylabel('Sample size N', size=14)\n",
    "# plt.xticks(x_ticks, x_label)\n",
    "# plt.yticks(y_ticks, y_label)\n",
    "# plt.legend(loc='best')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4f46cb9-55f6-4da8-8802-d8fa62f8e2ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# 禁用LaTeX渲染\n",
    "matplotlib.rcParams['text.usetex'] = False\n",
    "\n",
    "size = 100\n",
    "matrix = np.loadtxt('0.npy')\n",
    "\n",
    "x = []\n",
    "y = []\n",
    "# 生成拟合的曲线\n",
    "for i in range(size):\n",
    "    x.append(i + 1)\n",
    "    y.append(204800 / (i + 1)**2 - 20)\n",
    "plt.plot(x, y, color='red', linewidth=5, label=r'$N \\cdot \\mathrm{SNR}^2 = 1000$')\n",
    "\n",
    "\n",
    "#将矩阵中对应位置上的值转换为颜色\n",
    "# cmap 参数指定颜色映射（colormap），用于将矩阵中的数值映射为颜色。\n",
    "# 'viridis' 是一种常用的颜色映射，从紫色到黄色渐变\n",
    "# 'nearest' 表示使用最近邻插值，即每个像素直接使用矩阵中对应位置的值\n",
    "# origin 参数指定矩阵的起始位置'lower' 表示矩阵的第一行对应图像的下方，最后一行对应图像的上方。\n",
    "# plt.imshow(matrix, cmap='viridis', interpolation='nearest', origin='lower')\n",
    "# #添加一个颜色条，由最大值和最小值决定，出现白色的点说明出现了异常值\n",
    "# plt.colorbar()\n",
    "\n",
    "\n",
    "# plt.xlabel('Signal-to-Noise Ratio SNR', size=14)\n",
    "# plt.ylabel('Sample size N', size=14)\n",
    "\n",
    "# x_label = np.array((0.16, 5, 10, 15))\n",
    "# y_label = np.arange(2, 22, 2)\n",
    "# x_ticks = np.array((0, 31, 63, 95))\n",
    "# y_ticks = np.arange(0, size, 10)\n",
    "\n",
    "# plt.xticks(x_ticks, x_label)\n",
    "# plt.yticks(y_ticks, y_label)\n",
    "# plt.legend(loc='best')\n",
    "# # plt.savefig('0.1heatmap.png', dpi=1200, bbox_inches='tight')\n",
    "#随着映射范围的变化而发生改变\n",
    "#M=2,标签反转0.1\n",
    "# matrix[matrix < 0.5] = 0\n",
    "# matrix[matrix >= 0.5] = 1\n",
    "#M=2,标签反转0.01\n",
    "# matrix[matrix < 0.2] = 0\n",
    "# matrix[matrix >= 0.2] = 1\n",
    "#M=2,标签反转0.001\n",
    "matrix[matrix < 0.1] = 0\n",
    "matrix[matrix >= 0.1] = 1\n",
    "# plt.cla()\n",
    "# plt.clf()\n",
    "\n",
    "plt.figure(1)\n",
    "plt.plot(x, y, color='red', linewidth=5, label=r'$N \\cdot \\mathrm{SNR}^2 = 1000$')\n",
    "plt.imshow(matrix, cmap='viridis', interpolation='nearest', origin='lower')\n",
    "plt.colorbar()\n",
    "plt.xlabel('Signal-to-Noise Ratio SNR', size=14)\n",
    "plt.ylabel('Sample size N', size=14)\n",
    "plt.xticks(x_ticks, x_label)\n",
    "plt.yticks(y_ticks, y_label)\n",
    "plt.legend(loc='best')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2ed8d39-e52e-4459-abd4-b04d8c4c562c",
   "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
}
