{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import hnswlib\n",
    "from numpy import linalg as LA\n",
    "\n",
    "def cosine_sim(x,y):\n",
    "    return np.dot(x,y)/LA.norm(x)/LA.norm(y)\n",
    "\n",
    "class mol:\n",
    "    def __init__(self,smiles0,smiles1,feat):\n",
    "        self.smiles0=smiles0\n",
    "        self.smiles1=smiles1\n",
    "        self.feat=feat\n",
    "\n",
    "class infogain:\n",
    "    def __init__(self, initial_points=None, n=3000000, keep_seed=False, submodular_k=4):\n",
    "        self.clusters = None\n",
    "        self.target_n = n\n",
    "        self.current_n = 0\n",
    "        self.keep_seed = keep_seed\n",
    "        self.dim = 2348*4\n",
    "        self.submodular_k = submodular_k\n",
    "\n",
    "        if initial_points: \n",
    "            self.data = initial_points.copy()\n",
    "            self.current_n = len(initial_points)\n",
    "            if keep_seed:\n",
    "                self.seeded_num = len(initial_points)\n",
    "            self.dim = len(initial_points[0].feat)\n",
    "        else:\n",
    "            self.data = []\n",
    "        self.submodular_gain = [(1)]*len(self.data)\n",
    "        # initialize HNSW index\n",
    "        self.knn_graph = hnswlib.Index(space='cosine', dim=self.dim)\n",
    "        self.knn_graph.init_index(max_elements=n, ef_construction=100, M=48, allow_replace_deleted = False)\n",
    "        self.precluster(initial_points)\n",
    "        self.knn_graph.set_ef(32)\n",
    "\n",
    "    def precluster(self, initial_points):\n",
    "    # Starting from some initial points (the cleaner the better) to do online selection\n",
    "        if initial_points is None or initial_points==[]: return\n",
    "        for idx,data in enumerate(self.data):\n",
    "            data.index = idx\n",
    "\n",
    "        for idx,data in enumerate(self.data):\n",
    "            self.submodular_gain[idx] = self.submodular_func(data, True)\n",
    "            self.knn_graph.add_items(data.feat, idx)\n",
    "\n",
    "    def submodular_func(self, data, skip_one=False):\n",
    "        if self.knn_graph.get_current_count()==0:\n",
    "            return (1.)\n",
    "        k = min(self.knn_graph.get_current_count(), self.submodular_k)\n",
    "        near_label,near_distances = self.knn_graph.knn_query(data.feat, k)\n",
    "        return np.mean(near_distances)\n",
    "\n",
    "    def add_item(self, data):\n",
    "        data.index = self.current_n\n",
    "        self.data.append(data)\n",
    "        self.knn_graph.add_items(data.feat, self.current_n)\n",
    "        self.current_n+=1\n",
    "\n",
    "    def replace_item(self, data, index):\n",
    "        # Not used in current work but provide for future extension on replacing samples\n",
    "        data_to_rep = self.data[index]\n",
    "        n_index = data_to_rep.index\n",
    "        data.index = self.current_n\n",
    "        self.knn_graph.mark_deleted(n_index)\n",
    "        self.knn_graph.add_items(data.I_feat, self.current_n, replace_deleted = True)\n",
    "        self.data[index] = data\n",
    "        self.current_n+=1\n",
    "\n",
    "    def process_item(self, data,):\n",
    "        # find near clusters\n",
    "        # go into nearest clusters to search near neighbour\n",
    "        # calculate corresponding threshold to decide if try to add or not\n",
    "        gain = self.submodular_func(data)\n",
    "        self.add_item(data)\n",
    "        self.submodular_gain.append(gain)\n",
    "\n",
    "    def final_gains(self):\n",
    "        return self.submodular_gain\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8780\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "data = torch.load('/home/1739678401/2024.9dataclean/MMGNN_0901/temp_data/combined_features_with_smiles.pt')\n",
    "# 提取 SMILES 列表和特征张量\n",
    "smiles = data['smiles']\n",
    "features = data['features']\n",
    "dic={}\n",
    "for i in range(len(smiles)):\n",
    "    dic[smiles[i]]=features[i]\n",
    "import pandas as pd\n",
    "feats=[]\n",
    "def file_to_mol(filepath):\n",
    "    df = pd.read_csv(filepath, usecols=[0, 1])\n",
    "    res=[]\n",
    "    for i, row in df.iterrows():\n",
    "        tensor1=dic[row[0]]\n",
    "        tensor2=dic[row[1]]\n",
    "        feat=torch.cat((tensor1,tensor1,tensor1, tensor2), dim=0).to(dtype=torch.float32).cpu().numpy()\n",
    "        feats.append(feat)\n",
    "        res.append(mol(row[0],row[1],feat))\n",
    "    return res\n",
    "filepath='/home/1739678401/2024.9dataclean/MMGNN_0901/data/exp_data.csv'\n",
    "res=file_to_mol(filepath)\n",
    "IG=infogain(res)\n",
    "mn_finalgains=IG.final_gains()\n",
    "print(len(mn_finalgains))\n",
    "import numpy as np\n",
    "gains = np.array([ (gain) for gain in mn_finalgains])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def count_aromatic_atoms(mol):\n",
    "    aromatic_atoms = 0\n",
    "    for atom in mol.GetAtoms():\n",
    "        if atom.GetIsAromatic():\n",
    "            aromatic_atoms += 1\n",
    "    return aromatic_atoms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit import Chem\n",
    "from rdkit.Chem import rdMolDescriptors\n",
    "\n",
    "def classify_molecule(smiles):\n",
    "    mol = Chem.MolFromSmiles(smiles)\n",
    "    if mol is None:\n",
    "        return \"Invalid SMILES\"\n",
    "\n",
    "    # 判断是否为水\n",
    "    if smiles == \"O\":\n",
    "        return \"Water\"\n",
    "\n",
    "    # 判断是否存在分子内氢键\n",
    "    h_bond_donors = rdMolDescriptors.CalcNumHBD(mol)\n",
    "    h_bond_acceptors = rdMolDescriptors.CalcNumHBA(mol)\n",
    "    if h_bond_donors > 0 and h_bond_acceptors > 0:\n",
    "        return \"Intra - molecular H - bonding\"\n",
    "\n",
    "    # 判断是否为醇或胺\n",
    "    atom_numbers = mol.GetAtoms()\n",
    "    for atom in atom_numbers:\n",
    "        if atom.GetAtomicNum() == 8 and atom.GetTotalNumHs() > 0:  # 氧原子且有氢连接，可能是醇\n",
    "            return \"Alcohols & Amines\"\n",
    "        elif atom.GetAtomicNum() == 7 and atom.GetTotalNumHs() > 0:  # 氮原子且有氢连接，可能是胺\n",
    "            return \"Alcohols & Amines\"\n",
    "\n",
    "    # 判断是否为含O和N的化合物\n",
    "    contains_o = any(atom.GetAtomicNum() == 8 for atom in atom_numbers)\n",
    "    contains_n = any(atom.GetAtomicNum() == 7 for atom in atom_numbers)\n",
    "    if contains_o and contains_n:\n",
    "        return \"O & N - containing\"\n",
    "\n",
    "    # 判断是否为卤代烃\n",
    "    contains_halogen = any(atom.GetAtomicNum() in [9, 17, 35, 53] for atom in atom_numbers)\n",
    "    if contains_halogen:\n",
    "        return \"Halogens\"\n",
    "\n",
    "    # 判断是否为芳香族化合物\n",
    "    if count_aromatic_atoms(mol) > 0:\n",
    "        return \"Aromatics\"\n",
    "\n",
    "    # 判断是否为烃类\n",
    "    contains_c = any(atom.GetAtomicNum() == 6 for atom in atom_numbers)\n",
    "    contains_h = any(atom.GetAtomicNum() == 1 for atom in atom_numbers)\n",
    "    if contains_c and contains_h and not contains_o and not contains_n and not contains_halogen:\n",
    "        return \"Hydrocarbons\"\n",
    "\n",
    "    return \"Others\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Aromatics 604\n",
      "Intra - molecular H - bonding 2590\n",
      "Others 3150\n",
      "Halogens 663\n",
      "O & N - containing 620\n",
      "Water 1153\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgYAAAGMCAYAAACh/GqDAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB0fElEQVR4nO3dd3hTZRsG8PtkNU2b7r1pC6WFMssepQzLEJmCKAqKk6E4WJ8oIiC4cKGiiAKKiCgoomwB2XtTSil00r3TkXm+PyqBShdtkjfj+V1XL0hyxp105Ml73sHxPM+DEEIIIQSAgHUAQgghhJgPKgwIIYQQokeFASGEEEL0qDAghBBCiB4VBoQQQgjRo8KAEEIIIXpUGBBCCCFEjwoDQgghhOhRYUAIIYQQPSoMCCHEAr311lvo0KGDSc/Zr18/zJw506TnNISUlBRwHIdz584xOT/Hcfjtt9/MIktjUGFACLEIkydPxsiRI+9rn7v/IBPzVtf3qinfd3MWGBiIrKwstG3blnWUOlFhQAixaSqVinUEm8HzPDQaDesYTAmFQvj4+EAkErGOUicqDAghFqlfv3548cUXMXv2bLi5ucHHxwdvvfWW/vGQkBAAwKhRo8BxnP727Sb4b775Bi1atIBUKgUA7NixA71794aLiwvc3d3x4IMPIjk5udk5b5/v22+/RVBQEBwdHTF16lRotVq899578PHxgZeXF5YsWVJjv7S0NIwYMQKOjo5wcnLCuHHjkJOTU++5vvnmG0RGRkIqlaJ169b44osvajyekZGBCRMmwM3NDQ4ODoiJicHx48cB1P7JfObMmejXr1+d5/v+++8RExMDuVwOHx8fPProo8jNzdU/vn//fnAch+3bt6Nz586ws7PDoUOHGvGqGcfVq1fRs2dPSKVStG3bFgcOHKjx+IEDB9C1a1fY2dnB19cXc+fOrVHINPQzBwBJSUno27cvpFIpoqKisHv37hqP//dSwu3XaO/evYiJiYFMJkPPnj2RmJhYY7/FixfDy8sLcrkcTz/9NObOnWu0S0lUGBBCLNbatWvh4OCA48eP47333sPbb7+t/0N88uRJAMB3332HrKws/W0AuH79On799Vds3rxZ/we6vLwcr7zyCk6dOoW9e/dCIBBg1KhR0Ol0zc6ZnJyM7du3Y8eOHdiwYQNWr16NYcOGISMjAwcOHMC7776L+fPn69+kdTodRowYgcLCQhw4cAC7d+/GjRs3MH78+DrPsX79erz55ptYsmQJEhIS8M477+CNN97A2rVrAQAKhQKxsbHIzMzE1q1bcf78ecyePbtZz0+tVmPRokU4f/48fvvtN6SkpGDy5Mn3bDd37lwsW7YMCQkJaNeuXZPP11yzZs3Cq6++irNnz6JHjx4YPnw4CgoKAACZmZkYOnQounTpgvPnz+PLL7/E6tWrsXjx4hrHqO9nTqfTYfTo0ZBIJDh+/DhWrlyJOXPmNCrb66+/jg8//BCnTp2CSCTCU089pX9s/fr1WLJkCd59912cPn0aQUFB+PLLLw30qtSCJ4QQCzBp0iR+xIgR+tuxsbF87969a2zTpUsXfs6cOfrbAPgtW7bU2GbBggW8WCzmc3Nz6z1fXl4eD4C/ePFis3IvWLCAl8lkfGlpqf6++Ph4PiQkhNdqtfr7IiIi+KVLl/I8z/O7du3ihUIhn5aWpn/88uXLPAD+xIkT+uO2b99e/3hYWBj/448/1jj3okWL+B49evA8z/NfffUVL5fL+YKCglpz/vf15Xmef+mll/jY2Fj97djYWP6ll16q87mePHmSB8CXlZXxPM/z+/bt4wHwv/32W5373AaAl0qlvIODQ40vkUh0T677dfPmTR4Av2zZMv19arWaDwgI4N99912e53n+f//7Hx8REcHrdDr9Np9//jnv6Oio/z419DO3c+dOXiQS8ZmZmfrHt2/fXuPn8HaWs2fP8jx/5zXas2ePfp8///yTB8BXVlbyPM/z3bp146dNm1bjvL169arx/TckajEghFis/3769PX1rdGUXZfg4GB4enrWuC8pKQkTJkxAaGgonJyc9Jce0tLSaj3G+vXr4ejoqP86ePBgnecLCQmBXC7X3/b29kZUVBQEAkGN+25nT0hIQGBgIAIDA/WPR0VFwcXFBQkJCfccv7y8HMnJyZgyZUqNTIsXL9ZfDjl37hw6duwINze3Bl6dxjt9+jSGDx+OoKAgyOVyxMbGArj3NYuJiWnU8T766COcO3euxtdDDz1U7z53P9/nn3++3m179Oih/79IJEJMTIz+9UxISECPHj3AcZx+m169ekGhUCAjI0N/X30/c7e/b35+frWesz53H9fX1xcA9MdNTExE165da2z/39uGZL69HwghpAFisbjGbY7jGtU07uDg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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import csv\n",
    "def process_csv(csv_file_path):\n",
    "    result_dict = {}\n",
    "    with open(csv_file_path, 'r', encoding='utf - 8') as csvfile:\n",
    "        reader = csv.reader(csvfile)\n",
    "        next(reader)\n",
    "        np.random.seed(0)\n",
    "        for idx, row in enumerate(reader):\n",
    "            if len(row) > 0:\n",
    "                smiles = row[0]\n",
    "                category = classify_molecule(smiles)\n",
    "                if category not in result_dict:\n",
    "                    result_dict[category] = []\n",
    "                result_dict[category].append(idx)\n",
    "    return result_dict\n",
    "res_dic=process_csv(filepath)\n",
    "categories=[]\n",
    "counts=[]\n",
    "for category, indices in res_dic.items():\n",
    "    print(category, len(indices))\n",
    "    categories.append(category)\n",
    "    counts.append(len(indices))\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.pie(counts, labels=categories, autopct='%1.1f%%')\n",
    "plt.axis('equal')  \n",
    "plt.savefig('no screen.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "def process_csv(csv_file_path):\n",
    "    result_dict = {}\n",
    "    with open(csv_file_path, 'r', encoding='utf - 8') as csvfile:\n",
    "        reader = csv.reader(csvfile)\n",
    "        next(reader)\n",
    "        for idx, row in enumerate(reader):\n",
    "            if len(row) > 0:\n",
    "                smiles = row[0]\n",
    "                if gains[idx]>=0.3:\n",
    "                    category = classify_molecule(smiles)\n",
    "                    if category not in result_dict:\n",
    "                        result_dict[category] = []\n",
    "                    result_dict[category].append(idx)\n",
    "    return result_dict\n",
    "res_dic=process_csv(filepath)\n",
    "categories=[]\n",
    "counts=[]\n",
    "for category, indices in res_dic.items():\n",
    "    print(category, len(indices))\n",
    "    categories.append(category)\n",
    "    counts.append(len(indices))\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "# 绘制饼状图\n",
    "plt.pie(counts, labels=categories, autopct='%1.1f%%')\n",
    "plt.axis('equal')  # 保证饼图是圆形\n",
    "plt.savefig('screen.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import umap\n",
    "import matplotlib.pyplot as plt\n",
    "color_dict = {\n",
    "    'Water': 'lightblue',\n",
    "    'O & N - containing':  'lightgreen',\n",
    "    'Intra - molecular H - bonding': 'lightgreen',\n",
    "    'Aromatics': 'pink',\n",
    "    'Others': 'lavender',\n",
    "    'Halogens': 'tan'\n",
    "}\n",
    "darker_color_dict = {\n",
    "    'Water': 'darkblue',\n",
    "    'O & N - containing': 'darkgreen',\n",
    "    'Intra - molecular H - bonding': 'darkgreen',\n",
    "    'Aromatics': 'darkred',\n",
    "    'Others': 'darkpurple',\n",
    "    'Halogens': 'darkgoldenrod'\n",
    "}\n",
    "\n",
    "def plot_umap(csv_file_path,result, feats, num):\n",
    "    # 读取CSV文件数据\n",
    "    df = pd.read_csv(csv_file_path)\n",
    "    smiles_list = df.iloc[:, 1].tolist()  # 获取第二列（分子SMILES表示）的数据列表\n",
    "\n",
    "    # 用于记录已经出现过的分子的字典\n",
    "    seen_molecules = {}\n",
    "    all_feats = []\n",
    "    labels = []\n",
    "    count_per_category = {category: 0 for category in result.keys()}  # 记录每个类别已添加的数量\n",
    "    for category, indices in result.items():\n",
    "        if category!='Others' and category!= 'Intra - molecular H - bonding':\n",
    "            for idx in indices:\n",
    "                molecule_smiles = smiles_list[idx]\n",
    "                if molecule_smiles not in seen_molecules and count_per_category[category] < num:\n",
    "                    seen_molecules[molecule_smiles] = True\n",
    "                    all_feats.append(feats[idx])\n",
    "                    labels.append(category)\n",
    "                    count_per_category[category] += 1\n",
    "\n",
    "    # 将特征转换为numpy数组\n",
    "    all_feats = np.array(all_feats)\n",
    "    print(len(all_feats))\n",
    "    # 使用UMAP进行降维\n",
    "    reducer = umap.UMAP(n_neighbors = 30,min_dist = 1)\n",
    "    embedding = reducer.fit_transform(all_feats)\n",
    "    # 绘制降维图\n",
    "    plt.figure(figsize=(10, 8))\n",
    "    unique_categories = set(labels)\n",
    "    for category in unique_categories:\n",
    "        idx = [j for j, label in enumerate(labels) if label == category]\n",
    "        np.random.shuffle(idx)\n",
    "        idx_20 = idx[:20]\n",
    "        idx_remain = [i for i in idx if i not in idx_20]\n",
    "        if len(idx_20) > 0:\n",
    "            # 使用深色绘制随机选择的20个点\n",
    "            plt.scatter(embedding[idx_20, 0], embedding[idx_20, 1], c=darker_color_dict[category], label=category + \" sample\")\n",
    "        if len(idx_remain) > 0:\n",
    "            # 使用普通颜色绘制剩下的点\n",
    "            plt.scatter(embedding[idx_remain, 0], embedding[idx_remain, 1], c=color_dict[category], label=category)\n",
    "\n",
    "    plt.legend()\n",
    "    plt.title(\"Clustering of Sovlents\")\n",
    "    # 隐藏坐标轴\n",
    "\n",
    "    ax = plt.gca()\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    plt.savefig('Clustering_of_Sovlents.pdf', bbox_inches='tight')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_umap(filepath, res_dic, feats, num=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import umap\n",
    "import matplotlib.pyplot as plt\n",
    "color_dict = {\n",
    "    'Water': 'lightblue',\n",
    "    'O & N - containing':  'lightgreen',\n",
    "    'Intra - molecular H - bonding': 'lightgreen',\n",
    "    'Aromatics': 'pink',\n",
    "    'Others': 'lavender',\n",
    "    'Halogens': 'tan'\n",
    "}\n",
    "darker_color_dict = {\n",
    "    'Water': 'darkblue',\n",
    "    'O & N - containing': 'darkgreen',\n",
    "    'Intra - molecular H - bonding': 'darkgreen',\n",
    "    'Aromatics': 'darkred',\n",
    "    'Others': 'darkpurple',\n",
    "    'Halogens': 'darkgoldenrod'\n",
    "}\n",
    "def map_to_circle(x, y):\n",
    "    \"\"\"\n",
    "    将二维坐标(x, y)均匀地映射到单位圆的边界上。\n",
    "    \"\"\"\n",
    "    theta = np.arctan2(y, x)\n",
    "    new_x = np.cos(theta)\n",
    "    new_y = np.sin(theta)\n",
    "    return new_x, new_y\n",
    "\n",
    "def plot_circle(csv_file_path,result, feats, num):\n",
    "    # 读取CSV文件数据\n",
    "    df = pd.read_csv(csv_file_path)\n",
    "    smiles_list = df.iloc[:, 1].tolist()  # 获取第二列（分子SMILES表示）的数据列表\n",
    "\n",
    "    # 用于记录已经出现过的分子的字典\n",
    "    seen_molecules = {}\n",
    "    all_feats = []\n",
    "    labels = []\n",
    "    count_per_category = {category: 0 for category in result.keys()}  # 记录每个类别已添加的数量\n",
    "    for category, indices in result.items():\n",
    "        if category!='Others' and category!= 'Intra - molecular H - bonding':\n",
    "            for idx in indices:\n",
    "                molecule_smiles = smiles_list[idx]\n",
    "                if molecule_smiles not in seen_molecules and count_per_category[category] < num:\n",
    "                    seen_molecules[molecule_smiles] = True\n",
    "                    all_feats.append(feats[idx])\n",
    "                    labels.append(category)\n",
    "                    count_per_category[category] += 1\n",
    "\n",
    "    # 将特征转换为numpy数组\n",
    "    all_feats = np.array(all_feats)\n",
    "    print(len(all_feats))\n",
    "    # 使用UMAP进行降维\n",
    "    reducer = umap.UMAP(n_neighbors = 30,min_dist = 1)\n",
    "    embedding = reducer.fit_transform(all_feats)\n",
    "    # 绘制降维图\n",
    "    plt.figure(figsize=(10, 8))\n",
    "    #unique_categories = set(labels)\n",
    "    unique_categories=['O & N - containing', 'Water','Halogens','Aromatics']\n",
    "    print(unique_categories)\n",
    "    for category in unique_categories:\n",
    "        idx = [j for j, label in enumerate(labels) if label == category]\n",
    "        print(len(idx))\n",
    "        np.random.shuffle(idx)\n",
    "        idx_20 = idx[:20]\n",
    "        idx_remain = [i for i in idx if i not in idx_20]\n",
    "        if len(idx_remain) > 0:\n",
    "            # 对剩下的点的坐标进行转换并绘制\n",
    "            x_remain = embedding[idx_remain, 0]\n",
    "            y_remain = embedding[idx_remain, 1]\n",
    "            new_x_remain, new_y_remain = map_to_circle(x_remain, y_remain)\n",
    "            plt.scatter(new_x_remain, new_y_remain, c=color_dict[category], label=category)\n",
    "        if len(idx_20) > 0:\n",
    "            # 对深色绘制的20个点的坐标进行转换并绘制\n",
    "            x_20 = embedding[idx_20, 0]\n",
    "            y_20 = embedding[idx_20, 1]\n",
    "            new_x_20, new_y_20 = map_to_circle(x_20, y_20)\n",
    "            plt.scatter(new_x_20, new_y_20, c=darker_color_dict[category], label=category + \" sample\")\n",
    "\n",
    "    plt.legend()\n",
    "    plt.title(\"Clustering of Sovlents\")\n",
    "    # 隐藏坐标轴\n",
    "\n",
    "    ax = plt.gca()\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    plt.savefig('Clustering_of_Sovlents.pdf', bbox_inches='tight')\n",
    "    plt.show()\n",
    "plot_circle(filepath, res_dic, feats, num=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "400\n",
      "['O & N - containing', 'Water', 'Halogens', 'Aromatics']\n",
      "100\n",
      "100\n",
      "100\n",
      "100\n"
     ]
    },
    {
     "data": {
      "image/png": "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QHH06NHi+vXr9TE1121oSl9jU+3+4x//qBdbdypZURTFEydOiAMHDhSdnZ3FoKAgcdGiReKyZctEAOL169cb+YRFcceOHWL//v1FuVwuqtVq8Z577hETExMNYpoy1e7+/fvFZ555Ruzevbvo6uoqOjo6iiEhIeKUKVPES5cu1Yv/+OOPxS5duoiOjo6ir6+vOH36dDEvL6/Bc7/yyisiADE8PLzB/Q19PhUVFeI777wjduvWTXR2dhbd3d3FPn36iAsWLBALCgr0cQDEZ555pt45G/rZWrhwoRgYGChKJBL9927nzp3i2LFjxYCAANHJyUkMCAgQH3zwQfH8+fOmPzAiIhshiKINjTokIiKrmT17Nj777DNoNBoOdCYiIovgmA8iIkJpaanB65ycHKxZswYDBgxg4UFERBbDMR9ERIR+/fohJiYGXbt2xY0bN/DVV1+hsLAQr776amunRkREdoTFBxERYdSoUVi/fj0+//xzCIKA3r1746uvvsKgQYNaOzUiIrIjHPNBRERERERWwTEfRERERERkFSw+iIiIiIjIKpo95kOn0yE9PR0qlarRBaiIiIiIiMh+iaKIoqIiBAQEQCIx3r7R7OIjPT0dwcHBzT2ciIiIiIjsTGpqKoKCgozub3bxoVKp9BdQq9XNPQ0REREREdm4wsJCBAcH62sEY5pdfNR0tVKr1Sw+iIiIiIio0eEYHHBORERERERWweKDiIiIiIisgsUHERERERFZBYsPIiIiIiKyChYfRERERERkFSw+iIiIiIjIKlh8EBERERGRVbD4ICIiIiIiq2DxQUREREREVsHig4iIiIiIrILFBxERERERWQWLDyIiIiIisgoWH0REREREZBUsPoiIiIiIyCpYfBARERERkVWw+CAiIiIiIqtg8UFERERERFbB4oOIiIiIiKyCxQcREREREVkFiw8iIiIiIrIKh9ZOgIiIrEsURWSXVqCsSgeZgwRecicIgtDgfkcBSDqahevXi+Hnp0DXvt6oFNHgceacW6vVIT7+Gq5naNDF3wnRXdwgkTkBriqgzrmIiMj+sPggIrJ3oggxvwhFmlJkVupwtgqoEP/eLXeQINpHjUCVHGlFpTiVWYjSKh0ObU/B128fQ871En2sp58Lpv5fH9xxd4jBcQAMjm3o3Bs2nMesWXG4tYMMS58NR7AgA87lV6fo5IjC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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import umap\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "color_dict = {\n",
    "    'Water': 'lightblue',\n",
    "    'O & N - containing':  'lightgreen',\n",
    "    'Intra - molecular H - bonding': 'lightgreen',\n",
    "    'Aromatics': 'pink',\n",
    "    'Others': 'lavender',\n",
    "    'Halogens': 'tan'\n",
    "}\n",
    "darker_color_dict = {\n",
    "    'Water': 'darkblue',\n",
    "    'O & N - containing': 'darkgreen',\n",
    "    'Intra - molecular H - bonding': 'darkgreen',\n",
    "    'Aromatics': 'darkred',\n",
    "    'Others': 'darkpurple',\n",
    "    'Halogens': 'darkgoldenrod'\n",
    "}\n",
    "\n",
    "def map_to_circle(x, y):\n",
    "    \"\"\"\n",
    "    将二维坐标(x, y)均匀地映射到单位圆的边界上。\n",
    "    \"\"\"\n",
    "    theta = np.arctan2(y, x)\n",
    "    new_x = np.cos(theta)\n",
    "    new_y = np.sin(theta)\n",
    "    return new_x, new_y\n",
    "\n",
    "def plot_circle(csv_file_path, result, feats, num):\n",
    "\n",
    "    df = pd.read_csv(csv_file_path)\n",
    "    smiles_list = df.iloc[:, 1].tolist()\n",
    "\n",
    "\n",
    "    seen_molecules = {}\n",
    "    all_feats = []\n",
    "    labels = []\n",
    "    count_per_category = {category: 0 for category in result.keys()}\n",
    "    for category, indices in result.items():\n",
    "        if category != 'Others' and category != 'Intra - molecular H - bonding':\n",
    "            for idx in indices:\n",
    "                molecule_smiles = smiles_list[idx]\n",
    "                if molecule_smiles not in seen_molecules and count_per_category[category] < num:\n",
    "                    seen_molecules[molecule_smiles] = True\n",
    "                    all_feats.append(feats[idx])\n",
    "                    labels.append(category)\n",
    "                    count_per_category[category] += 1\n",
    "\n",
    "    all_feats = np.array(all_feats)\n",
    "    print(len(all_feats))\n",
    "\n",
    "    reducer = umap.UMAP(n_neighbors=30, min_dist=1)\n",
    "    embedding = reducer.fit_transform(all_feats)\n",
    "\n",
    "    plt.figure(figsize=(10, 8))\n",
    "\n",
    "    unique_categories = ['O & N - containing', 'Water', 'Halogens', 'Aromatics']\n",
    "    print(unique_categories)\n",
    "\n",
    "    all_labels = []\n",
    "    all_x = []\n",
    "    all_y = []\n",
    "\n",
    "    for category in unique_categories:\n",
    "        idx = [j for j, label in enumerate(labels) if label == category]\n",
    "        print(len(idx))\n",
    "        np.random.shuffle(idx)\n",
    "        idx_20 = idx[:20]\n",
    "        idx_remain = [i for i in idx if i not in idx_20]\n",
    "        if len(idx_remain) > 0:\n",
    "            # 对剩下的点的坐标进行转换并绘制\n",
    "            x_remain = embedding[idx_remain, 0]\n",
    "            y_remain = embedding[idx_remain, 1]\n",
    "            new_x_remain, new_y_remain = map_to_circle(x_remain, y_remain)\n",
    "            plt.scatter(new_x_remain, new_y_remain, c=color_dict[category], label=category)\n",
    "            all_labels.extend([category] * len(idx_remain))\n",
    "            all_x.extend(new_x_remain)\n",
    "            all_y.extend(new_y_remain)\n",
    "        if len(idx_20) > 0:\n",
    "            # 对深色绘制的20个点的坐标进行转换并绘制\n",
    "            x_20 = embedding[idx_20, 0]\n",
    "            y_20 = embedding[idx_20, 1]\n",
    "            new_x_20, new_y_20 = map_to_circle(x_20, y_20)\n",
    "            plt.scatter(new_x_20, new_y_20, c=darker_color_dict[category], label=category + \" sample\")\n",
    "            all_labels.extend([category + \" sample\"] * len(idx_20))\n",
    "            all_x.extend(new_x_20)\n",
    "            all_y.extend(new_y_20)\n",
    "\n",
    "    plt.legend()\n",
    "    plt.title(\"Clustering of Sovlents\")\n",
    "    # 隐藏坐标轴\n",
    "    ax = plt.gca()\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    plt.savefig('Clustering_of_Sovlents.pdf', bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "    # 导出点的标签和坐标到CSV文件\n",
    "    data = {\n",
    "        'Label': all_labels,\n",
    "        'X': all_x,\n",
    "        'Y': all_y\n",
    "    }\n",
    "    df_export = pd.DataFrame(data)\n",
    "    df_export.to_csv('points_coordinates.csv', index=False)\n",
    "\n",
    "\n",
    "plot_circle(filepath, res_dic, feats, num=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "Molca_MAE=[1.554660466,0.622027202,0.494190699,0.640542146]\n",
    "GNN_MAE=[1.8653433,1.053423,0.66325532,0.675632443]\n",
    "One_hot_MAE=[2.642413433,1.65344234,0.8634823,0.71323451]\n",
    "Random_MAE=[2.97321342,1.6765201,1.158324323,0.721354351]\n",
    "labels=['Molca','GNN','One-hot','Random']\n",
    "Training_set_utilization_rate=['20%','40%','60%','80%']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "bar_width = 0.2\n",
    "\n",
    "\n",
    "\n",
    "x = range(len(Training_set_utilization_rate))\n",
    "\n",
    "\n",
    "\n",
    "colors = ['#D3D3D3', '#98FB98', '#ADD8E6', '#F4A477']\n",
    "\n",
    "\n",
    "\n",
    "plt.bar([i + bar_width * 1.5 for i in x], Random_MAE, width=bar_width, label=labels[3], color=colors[3])\n",
    "plt.bar([i + bar_width / 2 for i in x], One_hot_MAE, width=bar_width, label=labels[2], color=colors[2])\n",
    "plt.bar([i - bar_width / 2 for i in x], GNN_MAE, width=bar_width, label=labels[1], color=colors[1])\n",
    "plt.bar([i - bar_width * 1.5 for i in x], Molca_MAE, width=bar_width, label=labels[0], color=colors[0])\n",
    "\n",
    "\n",
    "\n",
    "plt.xticks(x, Training_set_utilization_rate)\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('Training_set_utilization_rate')\n",
    "plt.ylabel('MAE')\n",
    "\n",
    "\n",
    "\n",
    "plt.legend()\n",
    "plt.savefig('Ablation experiment.pdf', bbox_inches='tight')\n",
    "\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mape",
   "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.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
