{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 💣 gRNAde 101\n",
    "\n",
    "Computational RNA design tasks are often posed as inverse problems, where sequences are designed based on adopting a single desired secondary structure without considering 3D geometry and conformational diversity.\n",
    "In this tutorial, we present **gRNAde**, a **g**eometric **RNA** **de**sign pipeline operating on sets of 3D RNA backbone structures to design sequences that explicitly account for RNA 3D structure and dynamics.\n",
    "gRNAde is a Graph Neural Network that uses an SE(3) equivariant encoder-decoder framework for generating RNA sequences conditioned on backbone structures where the identities of the bases are unknown.\n",
    "We demonstrate the utility of gRNAde for fixed backbone re-design of existing RNA structures of interest from the PDB, including riboswitches, aptamers, and ribozymes.\n",
    "\n",
    "![](https://anonymous.4open.science/r/geometric-rna-design/tutorial/fig/grnade_pipeline.png)\n",
    "\n",
    "---\n",
    "\n",
    "## Introduction\n",
    "\n",
    "<details>\n",
    "<summary><b>Why RNA design?</b></summary>\n",
    "\n",
    "Historical efforts in computational drug discovery have focussed on designing small molecule or protein-based medicines that either treat symptoms or counter the end stages of disease processes. In recent years, there is a growing interest in designing new RNA-based therapeutics that intervene earlier in disease processes to cut off disease-causing information flow in the cell [1]. Notable examples of RNA molecules at the forefront of biotechnology today include mRNA vaccines [2], CRISPR-based genomic medicine [3], and riboswitch biosensors [4].\n",
    "\n",
    "</details>\n",
    "\n",
    "<details>\n",
    "<summary><b>Challenges of RNA modelling</b></summary>\n",
    "\n",
    "Despite the promises of RNA, proteins have instead been the primary focus in the artificial intelligence and 3D biomolecular modelling community. \n",
    "Availability of a large amount protein structural data from the PDB combined with advances in geometric deep learning for structured data [5] have revolutionized protein 3D structure prediction [6] and design [7, 8].\n",
    "Applications of deep learning for computational RNA design are underexplored compared to proteins due to paucity of 3D structural data [9, 10].\n",
    "Most tools for RNA design primarily focus on secondary structure without considering 3D geometry [11] or use non-learnt algorithms for aligning 3D RNA motifs [12].\n",
    "In addition to limited 3D data for training deep learning models, the key technical challenge is that RNA is more dynamic than proteins.\n",
    "The same RNA can adopt multiple distinct conformational states to create and regulate complex biological functions [13, 14, 15].\n",
    "Computational RNA design pipelines must account for both the 3D geometric structure and conformational flexibility of RNA to engineer new biological functions.\n",
    "\n",
    "</details>\n",
    "\n",
    "**What is gRNAde?**\n",
    "\n",
    "gRNAde aims to be a modern, deep learning-based toolkit for RNA sequence design conditioned on 3D structure, analogous to [ProteinMPNN](https://github.com/dauparas/ProteinMPNN) for protein design.\n",
    "gRNAde generates candidate RNA sequences conditioned on one or more backbone 3D conformations, enabling both single- and multi-state fixed-backbone sequence design.\n",
    "The model is trained on all RNA structures from the PDB at 4.0A or better resolution (12K 3D structures from 4.2K unique RNAs) [16], ranging from short RNAs such as riboswitches, aptamers and ribozymes to larger ribosomal RNAs.\n",
    "\n",
    "We will show how to use gRNAde for two RNA inverse design tasks:\n",
    "1. Fixed backbone redesign of an RNA backbone, ie. single-state design.\n",
    "2. Fixed backbone redesign of an ensemble of RNA backbones, ie. multi-state design.\n",
    "\n",
    "We will also compare gRNAde to Rosetta [17], an existing physics-based tools for 3D RNA inverse design, for single-state fixed backbone design of 14 RNA structures of interest from the PDB identified by Das et al. [18].\n",
    "We obtain higher native sequence recovery rates with gRNAde (56% on average) compared to Rosetta (45% on average), while expecting gRNAde to be significantly faster (order of seconds compared to order of hours for Rosetta).\n",
    "\n",
    "---\n",
    "\n",
    "## Background and Methodology\n",
    "\n",
    "<details>\n",
    "<summary><b>Installation</b></summary>\n",
    "\n",
    "### Installation\n",
    "\n",
    "gRNAde is available as a free and open-source software at `https://anonymous.4open.science/r/geometric-rna-design`, along with detailed setup and usage instructions.\n",
    "We have tested gRNAde on Linux with Python 3.10.12 and CUDA 11.8 on NVIDIA A100 80GB GPUs and Intel XPUs, as well as on MacOS (CPU).\n",
    "\n",
    "1. Clone or download files from the GitHub repository:\n",
    "```\n",
    "git clone https://anonymous.4open.science/r/geometric-rna-design.git; cd geometric-rna-design\n",
    "```\n",
    "\n",
    "2. Follow the installation instructions in the README file to set up your python environment and install all dependencies (PyTorch, PyTorch Geometric) and external tools (EternaFold, X3DNA).\n",
    "\n",
    "3. Set up your `.env` file with the appropriate environment variables; see `.env.example` for reference. Alternatively, export environment variables pointing to EternaFold and X3DNA directories; for example:\n",
    "```\n",
    "export PROJECT_PATH='/path/to/geometric-rna-design/'\n",
    "export ETERNAFOLD='/path/to/geometric-rna-design/tools/EternaFold'\n",
    "export X3DNA='/path/to/geometric-rna-design/tools/x3dna-v2.4'\n",
    "export PATH=\"/path/to/geometric-rna-design/tools/x3dna-v2.4/bin:$PATH\"\n",
    "```\n",
    "\n",
    "4. Ensure that your new python environment for gRNAde is active.\n",
    "\n",
    "</details>\n",
    "\n",
    "<details>\n",
    "<summary><b>Input Data Format and Preparation</b></summary>\n",
    "\n",
    "### Input Data Format and Preparation\n",
    "\n",
    "The input format for gRNAde is via PDB files of RNA structures. Internally, gRNAde builds a 3-bead coarse-grained representation of the RNA backbone, retaining the coordinates for P, C4', N1 (pyrimidine) or N9 (purine) for each nucleotide [19]. This 3-bead pseudotorsional representation can describe RNA backbone conformations completely in most cases while reducing the size of the backbone torsional space to prevent overfitting [20].\n",
    "\n",
    "The `RNAGraphFeaturizer` module in `src/data/featurizer.py` can be used to process a PDB file containing a single RNA chain into a featurized geometric graph in PyTorch Geometric's `torch_geometric.data.Data` format:\n",
    "1. Each nucleotide is assigned a node in the geometric graph with the 3D coordinate corresponding to the centroid of the 3 bead atoms.\n",
    "2. Each node is connected by edges to its 32 nearest neighbours as measured by the distance between them.\n",
    "3. Node features include unit vectors, distances, angles, and torsions along the backbone from the 5' end to the 3' end, as well as unit vectors, distances, angles, and torsions from each C4' to the corresponding P and N1/N9.\n",
    "4. Edge features include unit vectors from the source to destination node, the distance encoded by 32 radial basis functions, and the distance along the backbone encoded by 32 sinusoidal positional encodings.\n",
    "\n",
    "![](https://anonymous.4open.science/r/geometric-rna-design/tutorial/fig/backbone_featurizer.png)\n",
    "\n",
    "</details>\n",
    "\n",
    "<details>\n",
    "<summary><b>gRNAde Model Architecture</b></summary>\n",
    "\n",
    "### gRNAde Model Architecture\n",
    "\n",
    "The `gRNAde` module in `gRNAde.py` takes as input one or more PDB files corresponding to an RNA structure and featurizes them into a geometric graph as described in the previous section, with the identities of the nucleotide bases kept unknown.\n",
    "An instance of `RNAGraphFeaturizer` is internally instantiated within a gRNAde to do so.\n",
    "\n",
    "gRNAde then processes the featurized geometric graph using the `AutoregressiveMultiGNNv1` module from `src/models.py` as follows:\n",
    "1. The geometric graph is encoded via an SE(3) equivariant and conformer order equivariant Graph Neural Network [21, 22] to build latent representations of the local 3D geometric neighbourhood of each nucleotide.\n",
    "2. Latent representations from multiple states at each nucleotide position are then pooled together via Deep Sets [23] to account for conformational variability, and decoded to predict a probability distribution over the four possible base identities (A, G, C, U).\n",
    "4. The probability distribution can then be sampled to design a set of candidate sequences for a single structure (single-state design) or a conformational ensemble (multi-state design).\n",
    "\n",
    "During training, the entire model is trained end-to-end by minimising a cross-entropy loss between the predicted probability distribution and the true sequence identity, as detailed in the `train()` function in `src/trainer.py`.\n",
    "\n",
    "![](https://anonymous.4open.science/r/geometric-rna-design/tutorial/fig/grnade_model.png)\n",
    "\n",
    "</details>\n",
    "\n",
    "<details>\n",
    "<summary><b>Evaluation</b></summary>\n",
    "\n",
    "### Evaluation Metrics\n",
    "\n",
    "Once we have obtained a set of designed sequences, how do we determine which sequences are useful and which ones to prioritise? Short of wet lab experimentation, the following in-silico metrics can be used to evaluate gRNAde's designs:\n",
    "\n",
    "1. **Native sequence recovery**, which is the average percentage of native (groundtruth) nucleotides correctly recovered in 16 sampled sequences. This is the most widely used metric for biomolecule inverse design [7].\n",
    "\n",
    "2. **Secondary structure self-consistency score**, where we 'forward fold' 16 sampled sequences using a secondary structure prediction tool (we used EternaFold) and measure the average Mathew's Correlation Coefficient (MCC) to the groundtruth secondary structure. MCC values range between -1 and +1, with +1 represents a perfect prediction, 0 an average random prediction and -1 an inverse prediction. Similar forward folding metrics, sometimes termed 'designability', have been found to correlate with experimental success in 3D protein design [8]. Beyond this tutorial, our codebase also provides methods to use 3D structural self-consistency scores with RhoFold as the structure prediction model.\n",
    "\n",
    "3. **Perplexity**, which is the average exponential of the negative log-likelihood of 16 predicted sequences and can be thought of as the average number of bases that the model is selecting from for each nucleotide. A perfect model would have perplexity of 1, while a perplexity of 4 means that the model is making random predictions (the model outputs a probability over 4 possible bases). Perplexity does not require a groundtruth structure to calculate, and can also be used for ranking sequences based on the model's estimate of their compatibility with the structure to be designed.\n",
    "\n",
    "The evaluation metrics are computed every time we use the `design()` function for the `gRNAde` module (described in detail subsequently), or via the `evaluate()` function in `src/trainer.py`.\n",
    "\n",
    "![](https://anonymous.4open.science/r/geometric-rna-design/tutorial/fig/evaluation.png)\n",
    "\n",
    "</details>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import libraries and set up the environment\n",
    "\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "\n",
    "import dotenv\n",
    "dotenv.load_dotenv(\"../.env\")\n",
    "\n",
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "from src.constants import PROJECT_PATH"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example Usage\n",
    "\n",
    "### Instantiating the gRNAde module\n",
    "\n",
    "The `gRNAde` module in `grnade.py` provides a simple interface for fixed-backbone re-design of 3D RNA structures for both the single and multi-state setting.\n",
    "An instance of the gRNAde module can be created as follows by providing:\n",
    "1. `split`, the training dataset split used for training gRNAde (for now, we will use the `das` split which we will describe subsequently).\n",
    "2. `max_num_conformers`, the maximum number of conformational states that one wishes to consider as input for the design task at hand (by default `1`, at most `5`); \n",
    "3. `gpu_id`, the GPU ID on which the model will be run (defaults to CPU if no GPUs are available).\n",
    "\n",
    "Under the hood, gRNAde automatically loads the model checkpoint corresponding to the number of conformational states selected."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instantiating gRNAde v0.3\n",
      "    Using device: cuda:0\n",
      "    Creating RNA graph featurizer for max_num_conformers=1\n",
      "    Initialising GNN encoder-decoder model\n",
      "    Loading model checkpoint: /checkpoints/gRNAde_ARv1_1state_das.h5\n",
      "Finished initialising gRNAde v0.3\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Import the gRNAde module\n",
    "from gRNAde import gRNAde\n",
    "\n",
    "# Create an instance of gRNAde\n",
    "gRNAde_module = gRNAde(split='das', max_num_conformers=1, gpu_id=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "---\n",
    "\n",
    "### Single-state inverse folding\n",
    "\n",
    "The `design_from_pdb_file()` function in the gRNAde module performs fixed-backbone re-design of a single RNA structure from a PDB file and optionally saves the designed sequences to a fasta file.\n",
    "The workflow is as follows:\n",
    "\n",
    "1. Prepare a PDB file for fixed-backbone re-design. For instance, we will use a [guanine riboswitch](https://proteopedia.org/wiki/index.php/Guanine_riboswitch) aptamer domain (PDB ID: [4FE5](https://www.rcsb.org/structure/4FE5)) for which the filepath is `/tutorial/demo_data/4FE5_1_B.pdb`. Note that the PDB file must contain only one chain and all RNA backbone atoms.\n",
    "\n",
    "2. Specify an output filepath pointing to a fasta file where the designed sequences, corresponding evaluation metrics, and additional metadata will be saved. We will set this to `/tutorial/demo_output.fasta`.\n",
    "\n",
    "3. Set the following configurations for the model's sampling process:\n",
    "    - `n_samples`, the number of samples which are designed by gRNAde for the input RNA structure.\n",
    "    - `temperature`, which is used to modulate the smoothness or sharpness of the probability distribution produced by the model. At lower temperatures, for instance <= 1, we expect to have higher native sequence recovery and lower diversity in the model's designs. At higher temperatures, the model produces more diverse designs by sampling from a smoothed probability distribution.\n",
    "    We recommend sampling at temperatures in the range 0.1 - 0.5 for the best results.\n",
    "    - `seed`, the random seed for obtaining reproducible results. \n",
    "\n",
    "4. Call the `design_from_pdb_file()` function from the `grnade_module` instance using the specified input and output filepaths as well as sampling configurations.\n",
    "\n",
    "5. Within seconds, the designed sequences will be saved to the fasta file `/tutorial/demo_output.fasta`.\n",
    "\n",
    "<details>\n",
    "<summary><b>Understanding the output</b></summary>\n",
    "\n",
    "The contents of the output fasta file can be understood as follows:\n",
    "\n",
    "1. The first entry is the native sequence from the input PDB file. The description contains metadata about the gRNAde model, such as the version, model type, maximum number of conformers, checkpoint filepath, and random seed used for the design.\n",
    "\n",
    "2. Each subsequent entry contains a designed sequence. The description includes the sample number, the temperature of sampling, and evaluation metrics such as perplexity, native sequence recovery, and secondary structure self-consistency score.\n",
    "\n",
    "3. We see that gRNAde produces designs within a range of approximately 0.4 - 0.6 native sequence recovery rate, with self-consistency scores between 0.3 - 0.9. It is interesting to note that a lower sequence recovery does not automatically imply a lower self-consistency score, and vice-versa.\n",
    "\n",
    "</details>\n",
    "\n",
    "<details>\n",
    "<summary><b>Running via the command line</b></summary>\n",
    "\n",
    "Alternatively to the workflow described above, we can also use the `gRNAde.py` script via command line arguments to achieve the same outcome, as follows:\n",
    "```sh\n",
    "python gRNAde.py \\\n",
    "    --pdb_filepath tutorial/demo_data/4FE5_1_B.pdb \\\n",
    "    --output_filepath tutorial/demo_output.fasta \\\n",
    "    --split das \\\n",
    "    --max_num_conformers 1 \\\n",
    "    --n_samples 16 \\\n",
    "    --temperature 0.5\n",
    "```\n",
    "\n",
    "</details>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ">input_sequence, gRNAde_version=0.3, model=AutoregressiveMultiGNNv1, max_num_conformers=1, checkpoint=/checkpoints/gRNAde_ARv1_1state_das.h5, seed=0\n",
      "GGACAUAUAAUCGCGUGGAUAUGGCACGCAAGUUUCUACCGGGCACCGUAAAUGUCCGAC\n",
      "UAUGUCC\n",
      "\n",
      ">sample=0, seed=0, temperature=1.0, perplexity=1.9213, recovery=0.5606, edit_dist=29, sc_score=0.6665\n",
      "GACAAGUAAUCCCCGCGCUAGGGGCGGGGACUUACAAGUUUGCCCGUUAAAGGUAAAGCU\n",
      "CUGUCC\n",
      "\n",
      ">sample=1, seed=0, temperature=1.0, perplexity=1.5930, recovery=0.5000, edit_dist=26, sc_score=0.8497\n",
      "ACAUAGUAAUCCCCUCGCUAGGGGAGGGGAGGUCCAGCUGUGUCCCGUAAAGAUACGACC\n",
      "UAUGUU\n",
      "\n",
      ">sample=2, seed=0, temperature=1.0, perplexity=1.7012, recovery=0.4242, edit_dist=36, sc_score=0.9227\n",
      "GGGAUGUAAGUCCAACGUUAAGGGUUGGACAUCCCAUUAUUGUCCCUUUAAGAUAAUACC\n",
      "AUCCCG\n",
      "\n",
      ">sample=3, seed=0, temperature=1.0, perplexity=2.2303, recovery=0.3939, edit_dist=33, sc_score=0.8080\n",
      "GGGAUGUAACUCUUCUGCUACGCAGAAGAGGUUACGGCACAGUCGAGUGAAGAUUGUCCC\n",
      "AUCCCU\n",
      "\n",
      ">sample=4, seed=0, temperature=1.0, perplexity=2.0344, recovery=0.3030, edit_dist=36, sc_score=0.2434\n",
      "AAACAGUAAUGUCAACACUAUGUGUUGAUGGUAACAACAAUAUCACCCUAAGACAUUCGC\n",
      "UGUUUU\n",
      "\n",
      ">sample=5, seed=0, temperature=1.0, perplexity=1.6453, recovery=0.4545, edit_dist=28, sc_score=0.8114\n",
      "ACGUAGGAAUGCCUUCGAUAUGGGAAGGUAGUUCCACCAGUGGCCCUUUAAGCUACUAGC\n",
      "UACGUU\n",
      "\n",
      ">sample=6, seed=0, temperature=1.0, perplexity=1.9877, recovery=0.4394, edit_dist=31, sc_score=0.2641\n",
      "GGCUAGUAACCCCAACGGUAUGGAUUGGAGUUCUCAGGUUUCACCCAUAAAGCUAAACCC\n",
      "UAGCCC\n",
      "\n",
      ">sample=7, seed=0, temperature=1.0, perplexity=1.8392, recovery=0.3939, edit_dist=38, sc_score=0.5221\n",
      "AUCCAGUAAUUCCUACACUAUGGGUAGGGACCUUCAGGUUUGAUCUUCAAAAUUAAAACC\n",
      "UGGAUC\n",
      "\n",
      ">sample=8, seed=0, temperature=1.0, perplexity=1.8429, recovery=0.4091, edit_dist=34, sc_score=0.9227\n",
      "GGCGGGCAAUCCCAACGAUAUGGGUUGGGAUCCCUGGGAGUGACCUUUAAAGUUACUGAC\n",
      "CCGCCG\n",
      "\n",
      ">sample=9, seed=0, temperature=1.0, perplexity=1.4493, recovery=0.4545, edit_dist=33, sc_score=0.9227\n",
      "GAUCAGUAACCCCAACGCUAUGGGUUGGGGGCCCUAGCAAUGUCCCGUAAAGAUAUUACC\n",
      "UGAUCC\n",
      "\n",
      ">sample=10, seed=0, temperature=1.0, perplexity=1.8039, recovery=0.5152, edit_dist=31, sc_score=0.8095\n",
      "GCGAAGUAAUUCUAUCACUAAGGGAUAGAAGUUGCAACCUUGACCCAUAAAGUUAUGAAC\n",
      "UUCGCC\n",
      "\n",
      ">sample=11, seed=0, temperature=1.0, perplexity=2.0789, recovery=0.3788, edit_dist=35, sc_score=0.7876\n",
      "ACGUAGUAACCCCCUCGCUUCGGGAGGUGGGCCCCUGCUCUGUUCUUUAAAAAUAGACCC\n",
      "UACGUC\n",
      "\n",
      ">sample=12, seed=0, temperature=1.0, perplexity=1.4608, recovery=0.5303, edit_dist=29, sc_score=0.9002\n",
      "GGCUAGUAAUCCCAUCGCUAUGGGAUGGGAGUGUCAGCAUAGUCCCGUUAAGAUUAUACC\n",
      "UAGCCU\n",
      "\n",
      ">sample=13, seed=0, temperature=1.0, perplexity=1.6659, recovery=0.5000, edit_dist=31, sc_score=0.8497\n",
      "GCCUUGUAAUCCCCACGCUAUGGGUGGGGAUUCUCAGGUCAGACCUAUAAAAUUUGAACC\n",
      "AAGGCC\n",
      "\n",
      ">sample=14, seed=0, temperature=1.0, perplexity=1.4939, recovery=0.5303, edit_dist=32, sc_score=0.5604\n",
      "GUCAAGUAAUGCCAACGCUAUGGGGUGGUAGCGCCAGCAGUGUCCCGUUAAGAUACUACC\n",
      "UUGACC\n",
      "\n",
      ">sample=15, seed=0, temperature=1.0, perplexity=1.5724, recovery=0.5000, edit_dist=32, sc_score=0.8793\n",
      "GCCAUGUAAGCCCUCCGCUAGGCGGAGGGCGUCUCAGCAGUGUCGCGCUAAGAUACUCCC\n",
      "AUGGCC\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Single-state design example usage\n",
    "sequences, samples, perplexity, recovery_sample, sc_score = gRNAde_module.design_from_pdb_file(\n",
    "    pdb_filepath = os.path.join(PROJECT_PATH, \"tutorial/demo_data/4FE5_1_B.pdb\"),\n",
    "    output_filepath = os.path.join(PROJECT_PATH, \"tutorial/outputs/demo_output.fasta\"),\n",
    "    n_samples = 16,\n",
    "    temperature = 1.0,\n",
    "    seed = 0\n",
    ")\n",
    "for seq in sequences:\n",
    "    print(seq.format('fasta'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "---\n",
    "\n",
    "### Comparing gRNAde to physics-based RNA inverse folding\n",
    "\n",
    "Rosetta is a state-of-the-art physics-based toolkit for biomolecular modelling and design [17].\n",
    "We can use gRNAde's `design_from_pdb_file` function to compare it to Rosetta's [fixed backbone RNA sequence design](https://www.rosettacommons.org/docs/latest/application_documentation/rna/rna-design) workflow.\n",
    "We use gRNAde to re-design 14 RNA structures of interest from the PDB identified by Das et al. [18], which mainly includes riboswitches, aptamers, and ribozymes.\n",
    "These structures are available at the directory `/tutorial/demo_data/`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                       idx  mean_recovery\n",
      "model_name                               \n",
      "FARNA                 20.5       0.321429\n",
      "Rosetta               34.5       0.450000\n",
      "ViennaRNA\\n(2D only)   6.5       0.268641\n",
      "gRNAde                48.5       0.568228\n"
     ]
    }
   ],
   "source": [
    "# Metadata and recoveries from Das et al.\n",
    "\n",
    "demo_data_id = [\"1CSL\",\"1ET4\",\"1F27\",\"1L2X\",\"1LNT\",\"1Q9A\",\"4FE5\",\"1X9C\",\"1XPE\",\"2GCS\",\"2GDI\",\"2OEU\",\"2R8S\",\"354D\",]\n",
    "\n",
    "demo_data_info = [\n",
    "    \"RRE high affinity site\",\n",
    "    \"Vitamin B12 binding RNA aptamer\",\n",
    "    \"Biotin-binding RNA pseudoknot\",\n",
    "    \"Viral RNA pseudoknot\",\n",
    "    \"RNA internal loop of SRP\",\n",
    "    \"Sarcin/ricin domain from E.coli 23S rRNA\",\n",
    "    \"Guanine riboswitch aptamer\",\n",
    "    \"All-RNA hairpin ribozyme\",\n",
    "    \"HIV-1 B RNA dimerization initiation site\",\n",
    "    \"Pre-cleavage state of glmS ribozyme\",\n",
    "    \"Thiamine pyrophosphate-specific riboswitch\",\n",
    "    \"Junctionless hairpin ribozyme\",\n",
    "    \"Tetrahymena ribozyme P4-P6 domain\",\n",
    "    \"Loop E from E. coli 5S rRNA\",\n",
    "]\n",
    "\n",
    "vienna_recovery = [0.2566288,0.25852272,0.2951389,0.2448347,0.325,0.27455357,0.2916667,0.26201922,0.2709652,0.24888393,0.25,0.23317307,0.26923078,0.28035715]\n",
    "\n",
    "farna_recovery = [0.20,0.34,0.36,0.45,0.27,0.40,0.28,0.31,0.24,0.26,0.38,0.30,0.36,0.35,]\n",
    "\n",
    "rosetta_recovery = [0.44,0.44,0.37,0.48,0.53,0.41,0.36,0.50,0.40,0.44,0.48,0.37,0.53,0.55,]\n",
    "\n",
    "# Evaluate gRNAde on the Das et al. data\n",
    "grnade_recovery = []\n",
    "grnade_perplexity = []\n",
    "grnade_sc_score = []\n",
    "for pdb_filepath in os.listdir(os.path.join(PROJECT_PATH, \"tutorial/demo_data/\")):\n",
    "    if pdb_filepath.endswith(\".pdb\"):\n",
    "        sequences, samples, perplexity, recovery_sample, sc_score = gRNAde_module.design_from_pdb_file(\n",
    "            pdb_filepath=os.path.join(PROJECT_PATH, f\"tutorial/demo_data/{pdb_filepath}\"),\n",
    "            n_samples=16,\n",
    "            temperature=0.1,\n",
    "            seed=0\n",
    "        )\n",
    "        grnade_recovery.append(np.mean(recovery_sample))\n",
    "        grnade_perplexity.append(np.mean(perplexity))\n",
    "        grnade_sc_score.append(np.mean(sc_score))\n",
    "\n",
    "# Collate results as dataframes for plotting\n",
    "df = pd.DataFrame.from_dict({\n",
    "    \"idx\": list(range(len(farna_recovery))),\n",
    "    \"pdb_id\": demo_data_id,\n",
    "    \"description\": demo_data_info,\n",
    "    \"vienna_recovery\": np.array(vienna_recovery),\n",
    "    \"farna_recovery\": np.array(farna_recovery),\n",
    "    \"rosetta_recovery\": np.array(rosetta_recovery),\n",
    "    \"grnade_recovery\": np.array(grnade_recovery),\n",
    "    \"grnade_perplexity\": np.array(grnade_perplexity),\n",
    "    \"grnade_sc_score\": np.array(grnade_sc_score),\n",
    "})\n",
    "df_sample = pd.DataFrame.from_dict({\n",
    "    \"idx\": list(range(len(farna_recovery) * 4)),\n",
    "    \"mean_recovery\": np.array(vienna_recovery + farna_recovery + rosetta_recovery + grnade_recovery),\n",
    "    \"model_name\": [\"ViennaRNA\\n(2D only)\"] * len(vienna_recovery) + [\"FARNA\"] * len(farna_recovery) + [\"Rosetta\"] * len(rosetta_recovery) + [\"gRNAde\"] * len(grnade_recovery),\n",
    "})\n",
    "df.to_csv(os.path.join(PROJECT_PATH, \"tutorial/outputs/benchmark.csv\"))\n",
    "\n",
    "# Print mean recovery model\n",
    "print(df_sample.groupby(\"model_name\").mean())\n",
    "# print(df_sample.groupby(\"model_name\").median())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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I0eOkJSU5JC+bds2PvzwQzw9PRk4cOA1Px4hhBBClB+XgyOdTofFYilW3tzcXJKTk/H393e1ukLp9Xpmz56NxWKha9euPPHEE7z88su0aNGCP//8k4kTJ9KgQQNb/hkzZtCoUSOnx50A7N27lwMHDtC6dWu7TSWvtnTpUsLDw+nXrx/PPvssL7/8MnfddRfdunUjNzeXGTNmlMu+T0IIIYRwncur1WrWrMlff/3F2bNnqVmzZqF5N27ciMlkKnDFlzv07NmTbdu2MWHCBJYuXUpOTg5NmjRh8uTJDB8+/JrKsvYaFTURu2fPnhw9epR9+/axefNmsrKyqFq1KoMHD+aFF16gffv2Lj8eIYQQQpQPl4OjXr168ddffzFz5kymTJlSYL7MzEzGjh2LpmncddddrlZXLO3bt2fNmjVF5ps4cWKhZ6F99tlnfPbZZ0WW071792ueyySEEEKIis3lYbUXXngBvV7P+++/z/z5853m2bFjB926dWP//v34+Pjw9NNPu9xQIYQQQoiy4HJwFBkZyYwZM8jJyWH06NGEh4eTmJgIQJ8+fahVqxZdu3Zl7969aJrGrFmzqFq1qtsaLoQQQoiSM6Wlk/bXcUxp6eXdlAqjRGd5PP7446xYsYKwsDBiY2PJyclBKcWaNWs4d+4cSinCwsJYsWIFQ4cOdVebhRBCCFFCSilOvfse25q2YleXnmxr2opT775nO/HiZlbis9X69+9Pnz59WLNmDdu2bePChQuYzWaqVatG586d6devH56enu5oqxBCCCHc5OzM2UR/ON32uzk9negPp2OoVIlaT17byRA3GpeDoy1btgDQvHlzgoKCuPfee7n33nvd1jAhhBBClJ5zc53PFz731TwJjly9sUePHuh0OuLi4tzZHiGEEEKUgZxLl68p/Wbi8pyjwMBAgoKCCjxsVgghhBAVV9CtHZynd3SefjNxOTiqV68eqampZGdnu7M9QgghhCgDka+/goevr12ah68vkWNfKacWVRwuB0dDhgwhNzeXpUuXurM9QgghhCgDAS2a0379Gqo/8jBBnTtS/ZGHab9+DQEtmpd308qdy3OOnnvuOVasWMH//d//ERISwj333OPOdgkhhBCilPnUrUvD994p72ZUOC4HR++88w7dunXj0KFD9OvXjyZNmtC5c2eqVKmCh4dHgfeNHz/e1SqFEEII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/bEu2y8v1sf6/vvv8/zzz9OoUSN8fX1tPVuufDts1aoV//vf/9DpdHz22Wf89ttvxb7X09OTt956C8jbybewb675l8X/8MMPTo8EmDp1KoDtG1h5sS7XNZlMVK1a1aGdDRs2dMhbHPJcu1e1atVYtmwZ1atX548//uDDDz+0XbP2JFy6dKnA+2NjY+3yWt15551s2rSJxMRE1qxZw6uvvkqtWrXYtm0bt99+u223cfjnPWT37t1Fvn+4uj9WYb7++msAXnrpJSZOnEjz5s3x9/dHp8v7OCvvHiMr6/PkrDfcKjU1tdjlaZrG4MGDeffddwF45plnSElJKfb9zZo1Y8iQIZjNZsaPH19o3vw7zL/00ktO/5527twJ5O15lL8XyPq4L1++7LRss9ns9DWy3tenT59ifTY569V0JwmOriPWPTF2797NsWPH+Prrr1FK0apVK5o3b16sMqzdo6dOnSIzM7M0m+sWp0+fBqBr165Or+/YscOlctu2bWvbcPC11167pnsfeeQR6tevz5kzZwocVoB/9tsxGAxUr169wB/r8S7ltQ9P/sCiSpUqBbazcuXKgOObYVHkuXavgIAAJk+eDMC7775r27/mlltuASg08LPuQ5Y/2M3P39+fu+66i2nTpnH8+HFatGhBamoqCxcutOWxvoeUV4BZWu8J7tagQQOAQjcfdWVj0meffZa6desSFxfH+++/f033/vvf/0av17N06dJC67YGtX5+foX+PXl4eHDp0iW7/Yes/7eOHDnitOzjx487ff+w/r8q7GzFsiTB0XWkTp06tjeEefPm2eaIPPzww8Uuo27durRq1YqsrCw+++yzUmmnO1k/zC5cuOBw7ciRIyU6YHfcuHHodDq2bt16TRsO6vV6Jk2aBMA777xDRkaG03zWN5hRo0Zx7ty5An/+85//ALBw4UKXN1osCWtgERAQQHR0dIHt/Ouvv/D09HR4MywOea7da8SIEURERJCSkmLb/dg653DhwoUOmzACrF69mmPHjqHT6Yp1mLWnpydt27YF4OLFi7b0QYMGAbh0+K23tzdAoV/MispT2HvC5cuXK0zge9dddwF5z7uz3rz169e7dCq9wWBg7NixAHzyySfXdAZd3bp1GT16NEqpAs8wvHqH+cL+ngYOHAjY9yZbH/fnn3+OxWJxKP/TTz91Wm+XLl2oVq0aMTEx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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the results\n",
    "sns.set_context(\"talk\")\n",
    "plt.figure(figsize=(6, 4))\n",
    "\n",
    "sns.swarmplot(\n",
    "    data = df_sample,\n",
    "    x=\"model_name\", y=\"mean_recovery\",\n",
    "    hue=\"model_name\", palette=\"Reds\",\n",
    ")\n",
    "\n",
    "ax = sns.barplot(\n",
    "    data = df_sample,\n",
    "    x=\"model_name\", y=\"mean_recovery\",\n",
    "    hue=\"model_name\", saturation=0.5, palette=\"Reds\",\n",
    ")\n",
    "# Add labels to each bar\n",
    "for p in ax.patches:\n",
    "    ax.annotate(format(p.get_height(), '.3f'), \n",
    "                 (p.get_x() + p.get_width() / 2., p.get_height()), \n",
    "                 ha = 'right', va = 'center', \n",
    "                 xytext = (-4, 8), \n",
    "                 textcoords = 'offset points',\n",
    "                 fontsize=12)\n",
    "\n",
    "# ax.grid(True, which='both', linestyle='--', linewidth=0.5, color='gray')\n",
    "# ax.bar_label(ax.containers[0], fontsize=10)\n",
    "plt.xlabel(\"\")\n",
    "plt.ylabel(\"Native sequence recovery\", labelpad=10)\n",
    "# plt.ylim(0, 1)\n",
    "plt.yticks(np.arange(0, 1.01, 0.25), fontsize=14)\n",
    "plt.savefig(os.path.join(PROJECT_PATH, \"tutorial/outputs/singlestate-barplot.pdf\"), dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "When comparing gRNAde to the native sequence recovery rates for Rosetta and the older FARNA technique (we took the numbers from Das et al. [18]), gRNAde has higher recovery of 54% on average compared to 45% for Rosetta and 32% for FARNA.\n",
    "Perhaps more importantly, we expect gRNAde to be significantly faster than Rosetta: gRNAde can design sequences for backbones with hundreds of nucleotides in under 1 second with GPU acceleration, while Rosetta make take an order of hours. While we have not run Rosetta ourselves, we note that its documentation states that \"runs on RNA backbones longer than ~ten nucleotides take many minutes or hours\".\n",
    "\n",
    "Below, we plot native sequence recovery per sample for Rosetta vs. gRNAde, shaded by gRNAde’s average perplexity for each sample. Perplexity is an indicator of the model's confidence in its own prediction and appears to be correlated with native sequence recovery.\n",
    "Perplexity values from gRNAde's predictions are an indicator of the model's confidence in its own prediction and appear to be well correlated with native sequence recovery.\n",
    "\n",
    "Note that the training and validation data for the gRNAde model explicitly excluded the 14 RNA structures as well as any structurally similar RNAs with TM-score threshold of 0.45 (we used US-align for clustering).\n",
    "Thus, we tried to ensure that gRNAde has not memorized the evaluation dataset for fair comparison."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot native sequence recovery per sample for Rosetta vs. gRNAde, shaded by gRNAde’s average perplexity for each sample\n",
    "plt.figure(figsize=(5, 4))\n",
    "\n",
    "plt.plot([0, 1], [0, 1], transform=plt.gca().transAxes, ls=\"-\", c=\"black\", alpha=0.3)\n",
    "\n",
    "stat = df_sample.groupby(\"model_name\").mean()\n",
    "rosetta_stat = stat.loc[\"Rosetta\"][\"mean_recovery\"]\n",
    "grnade_stat = stat.loc[\"gRNAde\"][\"mean_recovery\"]\n",
    "plt.plot([rosetta_stat, rosetta_stat], [0, 1], transform=plt.gca().transAxes, ls=\"--\", c=\"black\", alpha=0.1)\n",
    "plt.plot([0, 1], [grnade_stat, grnade_stat], transform=plt.gca().transAxes, ls=\"--\", c=\"black\", alpha=0.1)\n",
    "\n",
    "ax = sns.scatterplot(\n",
    "    data = df,\n",
    "    x = \"rosetta_recovery\", y = \"grnade_recovery\",\n",
    "    hue = \"grnade_perplexity\", palette=\"flare\",\n",
    "    alpha=1.0,\n",
    ")\n",
    "# set model names as x and y axis labels\n",
    "plt.xlabel(\"Rosetta seq. recovery\", labelpad=10)\n",
    "plt.ylabel(\"gRNAde seq. recovery\", labelpad=10)\n",
    "# set x and y axis range to 0-1\n",
    "plt.xticks(np.arange(0, 1.01, 0.25), fontsize=14) # plt.xlim(0, 1)\n",
    "plt.yticks(np.arange(0, 1.01, 0.25), fontsize=14) # plt.ylim(0, 1)\n",
    "# Add perplexity colorbar\n",
    "norm = plt.Normalize(df['grnade_perplexity'].min(), df['grnade_perplexity'].max())\n",
    "sm = plt.cm.ScalarMappable(cmap=\"flare\", norm=norm)\n",
    "sm.set_array([])\n",
    "# Remove the legend and add a colorbar\n",
    "ax.get_legend().remove()\n",
    "cbar = plt.colorbar(sm, ax=ax)\n",
    "cbar.ax.tick_params(labelsize=14)\n",
    "ax2 = ax.twinx()\n",
    "ax2.set_ylabel(\"gRNAde perplexity\", labelpad=70)\n",
    "ax2.set_yticks([])\n",
    "plt.savefig(os.path.join(PROJECT_PATH, \"tutorial/outputs/singlestate-scatterplot.pdf\"), dpi=300, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "---\n",
    "\n",
    "### Multi-state inverse folding\n",
    "\n",
    "[Riboswitches](https://pdb101.rcsb.org/motm/130) are flexible RNA molecules that adopt more than one distinct functional conformation, for instance a ligand bound (holo) and unbound (apo) state, which helps them regulate and control gene expression.\n",
    "Structural studies of an adenine riboswitch have found distinct structures for two unbound apo structures, one ligand-bound intermediate, and a final ligand-bound conformation [24].\n",
    "\n",
    "If we were to attempt single-state inverse design for the adenine riboswitch, each structure may lead to a different set of sampled sequences for which recovery and self-consistency may vary widely.\n",
    "Thus, it is interesting to consider a design setting where we perform fixed-backbone re-design from multiple adenine riboswitch conformations.\n",
    "\n",
    "![](https://anonymous.4open.science/r/geometric-rna-design/tutorial/fig/adenine_riboswitch.png)\n",
    "\n",
    "The `design_from_directory()` function in the gRNAde module performs fixed-backbone re-design from a set of PDB files/RNA structures corresponding to the same RNA molecule, and optionally saves the designed sequences to a fasta file.\n",
    "The workflow is as follows:\n",
    "\n",
    "1. Instantiate a new multi-state variant of the gRNAde module by setting an appropriate `max_num_conformers` (in this example, we set it to 3 states).\n",
    "\n",
    "2. Prepare a directory containing PDB files for multi-state fixed-backbone re-design. For instance, we will use multiple conformations of the adenine riboswitch (PDB IDs: [5E54](https://www.rcsb.org/structure/5E54), [5SWD](https://www.rcsb.org/structure/5SWD) and [5SWE](https://www.rcsb.org/structure/5SWE)) which are stored in the directory `/tutorial/demo_data/adenine_riboswitch/`. Note that each PDB file must contain only one chain and all RNA backbone atoms, corresponding to the same native RNA sequence.\n",
    "\n",
    "3. Specify an output filepath pointing to a fasta file where the designed sequences, corresponding evaluation metrics, and additional metadata will be saved. We will set this to `/tutorial/demo_output_multistate.fasta`.\n",
    "\n",
    "4. Set the configurations for the model's sampling process: `n_samples`, `temperature` and `seed`. \n",
    "\n",
    "5. Call the `design_from_directory()` function from the `grnade_module` instance using the specified input and output filepaths as well as sampling configurations.\n",
    "\n",
    "6. Within seconds, the designed sequences will be saved to the fasta file `/tutorial/demo_output_multistate.fasta`.\n",
    "\n",
    "<details>\n",
    "<summary><b>Running via the command line</b></summary>\n",
    "\n",
    "Alternatively to the workflow described above, we can also use the `gRNAde.py` script via command line arguments to achieve the same outcome, as follows:\n",
    "```sh\n",
    "python gRNAde.py \\\n",
    "    --directory_filepath tutorial/demo_data/adenine_riboswitch/ \\\n",
    "    --output_filepath tutorial/demo_output.fasta \\\n",
    "    --split das \\\n",
    "    --max_num_conformers 3 \\\n",
    "    --n_samples 16 \\\n",
    "    --temperature 0.5\n",
    "```\n",
    "\n",
    "</details>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instantiating gRNAde v0.3\n",
      "    Using device: cuda:0\n",
      "    Creating RNA graph featurizer for max_num_conformers=3\n",
      "    Initialising GNN encoder-decoder model\n",
      "    Loading model checkpoint: /checkpoints/gRNAde_ARv1_3state_das.h5\n",
      "Finished initialising gRNAde v0.3\n",
      "\n",
      ">input_sequence, gRNAde_version=0.3, model=AutoregressiveMultiGNNv1, max_num_conformers=3, checkpoint=/checkpoints/gRNAde_ARv1_3state_das.h5, seed=0\n",
      "GGGAAGAUAUAAUCCUAAUGAUAUGGUUUGGGAGUUUCUACCAAGAGCCUUAAACUCUUG\n",
      "AUUAUCUU\n",
      "\n",
      ">sample=0, seed=0, temperature=1.0, perplexity=1.7506, recovery=0.4706, edit_dist=32, sc_score=0.8490\n",
      "UACAGGAGGUAAGCGUCCUAUUAUGGUGGGCGCAUCUUAGUGGACGCCCUUAAAGCGUCU\n",
      "CUCCUCCU\n",
      "\n",
      ">sample=1, seed=0, temperature=1.0, perplexity=1.3297, recovery=0.5441, edit_dist=31, sc_score=0.7772\n",
      "AGAGACAGCUAAGCCUCUUGUUAUGGUAGGGGCGUUUAAGCGGACUCCCUUAAAGAGUCC\n",
      "GUGCUGUC\n",
      "\n",
      ">sample=2, seed=0, temperature=1.0, perplexity=1.5792, recovery=0.5294, edit_dist=31, sc_score=0.8430\n",
      "GGGGUGAGUGUGGCGUCUUGUUAUGGUAGGCGCGUUUAAGCGAACUCCCUUAAAAAGUUC\n",
      "GUACUCAC\n",
      "\n",
      ">sample=3, seed=0, temperature=1.0, perplexity=1.5617, recovery=0.5441, edit_dist=31, sc_score=0.7935\n",
      "GGGGGGGCGCAAGCCUCUUAUUAUGGUAGGGGCAUGUCAGUGGACAGCCUUAAACUGUCC\n",
      "GUCGCCCC\n",
      "\n",
      ">sample=4, seed=0, temperature=1.0, perplexity=2.3896, recovery=0.4118, edit_dist=36, sc_score=0.3193\n",
      "AAAGCGAGGUAAGCAUUUUAUUUUGGUAAGUAAACUUCAAUACCAUCCCUUAAAGAUGGU\n",
      "GUCUUUAC\n",
      "\n",
      ">sample=5, seed=0, temperature=1.0, perplexity=1.2781, recovery=0.5294, edit_dist=32, sc_score=0.8293\n",
      "AGGGCGGGCUAAGCGUCAUAUUAUGGUUGGCGCGUUUAAGCGGACUCCCUUAAAGAGUCC\n",
      "AUGCCCGC\n",
      "\n",
      ">sample=6, seed=0, temperature=1.0, perplexity=1.5634, recovery=0.5441, edit_dist=31, sc_score=0.7060\n",
      "GGCGCGAGACAAGGGUCUUAUUAAGGUAAGCCCGUUUAUGCCGACUCCCUUAAAGAGUCG\n",
      "AUUCUCGC\n",
      "\n",
      ">sample=7, seed=0, temperature=1.0, perplexity=1.4542, recovery=0.5000, edit_dist=32, sc_score=0.8293\n",
      "AUCGACACGUAAGCCUCUUGUUAUGGUAGGGGCUUUUAAGAGGAUUCCCUUAAAGAAUCC\n",
      "UUCGUGUC\n",
      "\n",
      ">sample=8, seed=0, temperature=1.0, perplexity=1.4524, recovery=0.5000, edit_dist=33, sc_score=0.8014\n",
      "GGCGGGCGCCAAGCCUCUUAUUAUGGUAGGGGCGUUUAAGCGAACUCCCUUAAAGAGUUC\n",
      "GGGCGGCC\n",
      "\n",
      ">sample=9, seed=0, temperature=1.0, perplexity=1.6902, recovery=0.5000, edit_dist=30, sc_score=0.2701\n",
      "GAUCUGAGGCAACCGUCUUGUUAUGGUAGGCAGGUUUAAGCACACUGCCUUAAACAGUGU\n",
      "UACCUCAG\n",
      "\n",
      ">sample=10, seed=0, temperature=1.0, perplexity=1.8145, recovery=0.5441, edit_dist=31, sc_score=0.4199\n",
      "GCUGGGAACUUAUCUUUUUAUUAUGGUAAGAGAGUUUACGUGAAUUCCCUUAAAGUAUUC\n",
      "ACGUUCCC\n",
      "\n",
      ">sample=11, seed=0, temperature=1.0, perplexity=1.8033, recovery=0.4412, edit_dist=38, sc_score=0.8703\n",
      "ACUGCGCGCCAAGCGUCUUUUUAUGGUAGGCGCGUUUCAGCGGUGUCCCUUAAAGGCACC\n",
      "GGGCGCGC\n",
      "\n",
      ">sample=12, seed=0, temperature=1.0, perplexity=1.3303, recovery=0.4853, edit_dist=34, sc_score=0.5373\n",
      "GGCGCGAGGUAAGCGUCUUAUUAUGGUAGGCUCGUUUAAGCGGACUCCCUUGAAGAGUCC\n",
      "UUCCUCGC\n",
      "\n",
      ">sample=13, seed=0, temperature=1.0, perplexity=1.4169, recovery=0.5735, edit_dist=29, sc_score=0.2919\n",
      "GCCCCGAGCUAAGCCUCUUGUUAUGGUAGGUGCGUUUAAGCGAACUACCUUAAAUAGUUC\n",
      "AUGCUCGG\n",
      "\n",
      ">sample=14, seed=0, temperature=1.0, perplexity=1.3270, recovery=0.5588, edit_dist=30, sc_score=0.7772\n",
      "GUUGCGAGCUAAGCCUCUUAUUAUGGUAGGGGCGUUUAAGUGGAAUGCCUUAAACAUUCC\n",
      "AUGCUCGC\n",
      "\n",
      ">sample=15, seed=0, temperature=1.0, perplexity=1.4533, recovery=0.5294, edit_dist=28, sc_score=0.7335\n",
      "GGCGUGAGGCAAACCUCUUAUUAUGGUAGGGGUUUGUAAGAGGACUGCCUUAAACAGUCC\n",
      "AUCCUCAC\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Create an instance of multi-state gRNAde\n",
    "gRNAde_module = gRNAde(split='das', max_num_conformers=3, gpu_id=0)\n",
    "\n",
    "# Multi-state design example usage\n",
    "sequences, samples, perplexity, recovery_sample, sc_score = gRNAde_module.design_from_directory(\n",
    "    directory_filepath = os.path.join(PROJECT_PATH, \"tutorial/demo_data/adenine_riboswitch/\"),\n",
    "    output_filepath = os.path.join(PROJECT_PATH, \"tutorial/outputs/demo_output_multistate.fasta\"),\n",
    "    n_samples = 16,\n",
    "    temperature = 1.0,\n",
    "    seed = 0\n",
    ")\n",
    "for seq in sequences:\n",
    "    print(seq.format('fasta'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "---\n",
    "\n",
    "## Notes on methodology\n",
    "\n",
    "1. How to chose the number of states to provide as input to gRNAde? In general, this would depend on the design objective. For instance, designing a riboswitch may neccessitate multi-state design, while a single-state pipeline may be more sensible for locking an aptamer into its bound conformation [12]. Note that it may be possible to benefit from multi-state gRNAde models even when performing single-state design by using slightly noised variations of the same backbone structure as an input conformational ensemble.\n",
    "\n",
    "2. How to prioritise or chose amongst designed sequences? We have currently provided 3 evaluation metrics: native sequence recovery, secondary structure self-consistency score and perplexity, towards this end. We suspect that recovery may not be the ideal choice, except for design scenarios where we require certain regions of the RNA to be conserved or native-like. Self-consistency score may be a more holistic evaluation metric as it accounts for alternative base pairings leading to similar structures, but may inherit the limitations of the secondary structure prediction method used as part of its computation. In realistic design scenarios, we can pair gRNAde with another machine learning model (an 'oracles') for ranking or predicting the suitability of designed sequences for the objective (for instance, binding affinity). We hope to conduct further experimental validation of gRANde designs in the wet lab in order to better understand these tradeoffs. \n",
    "\n",
    "3. Key limitation of gRNAde and avenues for future development include the lack of support for multiple interacting RNA chains, or accounting for biomolecular interactions of RNAs with proteins, small molecules, and other ligands. More advanced user configurations, such as only partial re-design of only prespecified nucleotides and negative design against undesired conformations are also not possible at the moment.\n",
    "\n",
    "---\n",
    "\n",
    "## References\n",
    "\n",
    "[1] Zhu, Y., Zhu, L., Wang, X., & Jin, H. (2022). RNA-based therapeutics: an overview and prospectus. Cell death & disease, 13(7), 644.\n",
    "\n",
    "[2] Metkar, M., Pepin, C. S., & Moore, M. J. (2023). Tailor made: the art of therapeutic mRNA design. Nature Reviews Drug Discovery, 1-17.\n",
    "\n",
    "[3] Doudna, J. A., & Charpentier, E. (2014). The new frontier of genome engineering with CRISPR-Cas9. Science, 346(6213), 1258096.\n",
    "\n",
    "[4] Guo, P. (2010). The emerging field of RNA nanotechnology. Nature nanotechnology, 5(12), 833-842.\n",
    "\n",
    "[5] Bronstein, M. M., Bruna, J., Cohen, T., & Veličković, P. (2021). Geometric deep learning: Grids, groups, graphs, geodesics, and gauges. arXiv preprint arXiv:2104.13478.\n",
    "\n",
    "[6] Jumper, J., Evans, R., Pritzel, A., Green, T., Figurnov, M., Ronneberger, O., ... & Hassabis, D. (2021). Highly accurate protein structure prediction with AlphaFold. Nature, 596(7873), 583-589.\n",
    "\n",
    "[7] Dauparas, J., Anishchenko, I., Bennett, N., Bai, H., Ragotte, R. J., Milles, L. F., ... & Baker, D. (2022). Robust deep learning–based protein sequence design using ProteinMPNN. Science, 378(6615), 49-56.\n",
    "\n",
    "[8] Watson, J. L., Juergens, D., Bennett, N. R., Trippe, B. L., Yim, J., Eisenach, H. E., ... & Baker, D. (2023). De novo design of protein structure and function with RFdiffusion. Nature, 620(7976), 1089-1100.\n",
    "\n",
    "[9] Das, R. (2021). RNA structure: a renaissance begins?. Nature Methods, 18(5), 439-439.\n",
    "\n",
    "[10] Townshend, R. J., Eismann, S., Watkins, A. M., Rangan, R., Karelina, M., Das, R., & Dror, R. O. (2021). Geometric deep learning of RNA structure. Science, 373(6558), 1047-1051.\n",
    "\n",
    "[11] Churkin, A., Retwitzer, M. D., Reinharz, V., Ponty, Y., Waldispühl, J., & Barash, D. (2018). Design of RNAs: comparing programs for inverse RNA folding. Briefings in bioinformatics, 19(2), 350-358.\n",
    "\n",
    "[12] Yesselman, J. D., Eiler, D., Carlson, E. D., Gotrik, M. R., d’Aquino, A. E., Ooms, A. N., ... & Das, R. (2019). Computational design of three-dimensional RNA structure and function. Nature nanotechnology, 14(9), 866-873.\n",
    "\n",
    "[13] Ganser, L. R., Kelly, M. L., Herschlag, D., & Al-Hashimi, H. M. (2019). The roles of structural dynamics in the cellular functions of RNAs. Nature reviews Molecular cell biology, 20(8), 474-489.\n",
    "\n",
    "[14] Hoetzel, J., & Suess, B. (2022). Structural changes in aptamers are essential for synthetic riboswitch engineering. Journal of Molecular Biology, 167631.\n",
    "\n",
    "[15] Ken, M. L., Roy, R., Geng, A., Ganser, L. R., Manghrani, A., Cullen, B. R., ... & Al-Hashimi, H. M. (2023). RNA conformational propensities determine cellular activity. Nature, 1-7.\n",
    "\n",
    "[16] Adamczyk, B., Antczak, M., & Szachniuk, M. (2022). RNAsolo: a repository of cleaned PDB-derived RNA 3D structures. Bioinformatics, 38(14), 3668-3670.\n",
    "\n",
    "[17] Leman, J. K., Weitzner, B. D., Lewis, S. M., Adolf-Bryfogle, J., Alam, N., Alford, R. F., ... & Bonneau, R. (2020). Macromolecular modeling and design in Rosetta: recent methods and frameworks. Nature methods, 17(7), 665-680.\n",
    "\n",
    "[18] Das, R., Karanicolas, J., & Baker, D. (2010). Atomic accuracy in predicting and designing noncanonical RNA structure. Nature methods, 7(4), 291-294.\n",
    "\n",
    "[19] Dawson, W. K., Maciejczyk, M., Jankowska, E. J., & Bujnicki, J. M. (2016). Coarse-grained modeling of RNA 3D structure. Methods, 103, 138-156.\n",
    "\n",
    "[20] Wadley, L. M., Keating, K. S., Duarte, C. M., & Pyle, A. M. (2007). Evaluating and learning from RNA pseudotorsional space: quantitative validation of a reduced representation for RNA structure. Journal of molecular biology, 372(4), 942-957.\n",
    "\n",
    "[21] Ingraham, J., Garg, V., Barzilay, R., & Jaakkola, T. (2019). Generative models for graph-based protein design. Advances in neural information processing systems, 32.\n",
    "\n",
    "[22] Jing, B., Eismann, S., Suriana, P., Townshend, R. J. L., & Dror, R. (2020, October). Learning from Protein Structure with Geometric Vector Perceptrons. In International Conference on Learning Representations.\n",
    "\n",
    "[23] Zaheer, M., Kottur, S., Ravanbakhsh, S., Poczos, B., Salakhutdinov, R. R., & Smola, A. J. (2017). Deep sets. Advances in neural information processing systems, 30.\n",
    "\n",
    "[24] Stagno, J. R., Liu, Y., Bhandari, Y. R., Conrad, C. E., Panja, S., Swain, M., ... & Wang, Y. X. (2017). Structures of riboswitch RNA reaction states by mix-and-inject XFEL serial crystallography. Nature, 541(7636), 242-246."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rna",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
