SYSTEMS AND METHODS FOR LANGUAGE MODELING OF PROTEIN ENGINEERING
The present disclosure provides systems and methods for controllable protein generation. According to some embodiments, the systems and methods leverage neural network models and techniques that have been developed for other fields, in particular, natural language processing (NLP). In some embodiments, the systems and methods use or employ models implemented with transformer architectures developed for language modeling and apply the same to generative modeling for protein engineering.
This application is a nonprovisional application of and claims priority under 35 U.S.C. 119 to co-pending and commonly-owned U.S. provisional application No. 62/971,199, filed Feb. 6, 2020.
This application is related to co-pending and commonly-owned U.S. nonprovisional application Ser. Nos. ______ (attorney docket number A4741US2170689.112U502) and ______ (attorney docket number A4741US3170689.112U503), both filed on the same day.
All of the aforementioned applications are hereby expressly incorporated herein by reference in their entirety.
TECHNICAL FIELDThe present disclosure relates generally to machine learning models and neural networks, and more specifically, to conditional language modeling for protein generation.
BACKGROUNDGenerating proteins with desired properties is one of the most complex and impactful problems in biology. A protein is encoded by a specific raw amino acid sequence, and during synthesis, this chain of amino acids folds in ways that exhibit a local (e.g., secondary) and a global (e.g., tertiary) structure. These structural properties then directly determine a unique function of the synthesized protein, e.g., to serve as part of a vaccine to certain virus, a catalyst, etc. Synthesizing proteins that are actually functional is one of the goals for protein engineering. Unfortunately, obtaining three-dimensional structural information for proteins is expensive and time consuming.
Traditionally, protein engineering, such as directed evolution, largely relies on heuristics and random mutations to select initial sequences for rounds of evolution in order to generate new proteins. However, as the protein sequence data grows exponentially as compared to its structural data, heuristics-based protein engineering renders very limited success in the past.
Therefore, there is a need for efficient protein engineering.
In the figures, elements having the same designations have the same or similar functions.
DETAILED DESCRIPTIONArtificial intelligence, implemented with neural networks and deep learning models, has demonstrated great promise as a technique for automatically analyzing real-world information with human-like accuracy. In general, such neural network and deep learning models receive input information and make predictions based on the same. Whereas other approaches to analyzing real-world information may involve hard-coded processes, statistical analysis, and/or the like, neural networks learn to make predictions gradually, by a process of trial and error, using a machine learning process. A given neural network model may be trained using a large number of training examples, proceeding iteratively until the neural network model begins to consistently make similar inferences from the training examples that a human might make. Neural network models have been shown to outperform and/or have the potential to outperform other computing techniques in a number of applications.
A potential application for artificial intelligence is in the field of protein engineering. Generating proteins with desired properties is one of the most complex yet impactful problems in biology and science. Proteins are the workhorse for almost any fundamental process in life—from oxygen transport to immune system response. Protein engineering research has grown over the past 50 years and yielded remarkable outcomes including the development of new enzymes, therapies, and sensors. However, leading experimental techniques for protein engineering rely on structural annotations that accompany a small subset of sequenced protein. Unfortunately, obtaining structural annotations for raw sequences of amino acids that form a functional protein is expensive and time consuming.
Recent research has begun to capitalize on the much larger set of raw protein sequences by adapting state-of-the-art representation learning techniques from natural language processing to classification of protein properties. However, these methods have yet to capitalize on the large amount of non-structural annotations available for these sequences such as host organism, biological process, cellular component, and molecular function. In particular, there has been no attempt to adapt learning techniques from natural language processing to generate new proteins. In this regard, protein synthesis largely relies on the traditional heuristics-based or random mutation methods, which yields limited success in producing a functional protein.
According to some embodiments described herein, in view of limited success on traditional protein engineering methods, the present disclosure provides systems and methods for controllable protein generation. According to some embodiments, the systems and methods leverage neural network models and techniques that have been developed for other fields, in particular, natural language processing (NLP). In some embodiments, the systems and methods use or employ models implemented with transformer architectures developed for language modeling and apply the same to generative modeling for protein engineering.
As used herein, the term “protein generation” refers to generating a data sequence of amino acids that may be potentially used for protein synthesis in a laboratory.
The inferred results 115 from the generated protein sequence 123 may then be analyzed, e.g., whether the generated protein sequence 123 achieve the target structure 125 and the target functions 126.
According to some embodiments, the systems of the present disclosure—including the protein generation model protein generation model 120—can be implemented in one or more computing devices.
Memory 220 may be used to store software executed by computing device 200 and/or one or more data structures used during operation of computing device 200. Memory 220 may include one or more types of machine readable media. Some common forms of machine readable media may include floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, and/or any other medium from which a processor or computer is adapted to read.
Processor 210 and/or memory 220 may be arranged in any suitable physical arrangement. In some embodiments, processor 210 and/or memory 220 may be implemented on a same board, in a same package (e.g., system-in-package), on a same chip (e.g., system-on-chip), and/or the like. In some embodiments, processor 210 and/or memory 220 may include distributed, virtualized, and/or containerized computing resources. Consistent with such embodiments, processor 210 and/or memory 220 may be located in one or more data centers and/or cloud computing facilities.
As shown, memory 220 includes a protein generation module 230 that may be used, in some examples, for generative modeling for protein engineering. In some examples, protein generation module 230 may be implemented using hardware, software, and/or a combination of hardware and software. In some examples, memory 220 may include non-transitory, tangible, machine readable media that includes executable code that when run by one or more processors (e.g., processor 210) may cause the one or more processors to perform the methods described in further detail herein.
As shown, computing device 200 receives an input via a communication interface 250, which is provided to protein generation module 230. This input may comprise data for one or more sequences of amino acids 251 for generating proteins, and a set of target protein properties 252, such as but not limited to properties 105a-d shown in
According to some embodiments, protein generation module 230 may implement and/or emulate one or more neural network systems and models, and corresponding methods, for generative modeling for protein engineering. In some embodiments, protein generation module 230 may comprise, incorporate, or employ a neural network model that has been developed for natural language processing (NLP). For example, this neural network language model can be a transformer-based architecture, such as the Open AI GPT-2. Large transformer architectures represent the state-of-the-art in unconditional language modeling and demonstrate impressive text generation capabilities after training on vast amounts of unsupervised text. Large transformer architectures have been trained for language generation by conditioning on “control codes” that represent specific properties of the text readily extracted at scale, e.g. domain, style, and even associated URL. This is described in more detail in Keskar et al., “A conditional transformer language model for controllable generation,” arXiv preprint arXiv:1909.05858, 2019, which is incorporated by reference herein. In some embodiments, the systems and methods adapt the perspective and techniques of Keskar et al. (2019) to protein engineering by training a conditional transformer language model for proteins (amino acid sequences) conditioned on a set of protein properties cast as control codes. Protein engineering may require a finer-grained, larger, and more complex set of control codes. Rather than having only a few control codes associated with a document (in language modeling), in protein engineering a single protein is paired with dozens of control codes and the protein itself contains relatively few unique tokens that are not control codes.
Memory 220 further includes a protein language training module 232. According to some embodiments, protein engineering can be posed as an unsupervised sequence generation problem in order to leverage the exponentially growing set of proteins that lack costly, structural annotations. One challenge to obtain training data for protein generation is the vast volume of protein sequences that lack structural annotations. The protein language training module 232 provides a training mechanism for using protein language (as opposed to human languages) to train a language model for protein engineering. The protein language training module 232 obtains protein sequences and associated tags available, and creates training protein data samples that are suitable for a language model. For example, protein sequence data along with taxonomic and keyword tags can be used to train protein generation module 230. In this way, the protein generation module 230 can trained by as a language model in a similar manner that the language model can be trained with human language samples using the protein language training samples provided by the protein language training module 232.
For example, protein generation module 230 can be a 1.2B-parameter neural network language model is trained on a dataset of ˜270M protein sequences together with conditioning tags from the protein generation module 230. The protein generation module 230 encodes a variety of different kinds of annotation such as taxonomic, functional, and structural information into the conditional tags. By conditioning on these tags, protein generation module 230 provides a new method for protein generation that can be tailored for desired properties. In some embodiments, protein generation module 230 can be a powerful language model, achieving comparable performance to similarly sized models for human languages. This performance improves in settings with larger amino acid contexts and when protein generation model is provided a larger number of conditioning tags, which highlights its potential for applications such as hot-spot generation. The protein generation model also performs well when used to model unseen protein families. Furthermore, in some embodiments, protein generation module 230 can be fine-tuned for those unseen families as an alternative to training from random initialization, which may make it even more effective.
Memory 229 further includes a protein validation module 235. One goal of protein engineering is to generate a new protein that is both structural and functional relevant. The protein validation module 235 validates the relevancy of the generated protein sequence from the protein generation module 230. For structural relevancy, the protein validation module 235 evaluates three levels of structures: primary sequence similarity, secondary structure accuracy and conformational energy analysis of the engineered protein sequence 260. For functional accuracy of the engineered protein 260, the protein validation module 235 adopts zero-shot selection among variants of engineered proteins with the lowest perplexity values to achieve high fitness proteins.
The protein validation module 235 may further use sequence similarity, secondary structure accuracy, and conformational energy to assess how well the proteins generated by the protein generation model satisfy desired structural and functional properties specified by the conditioning tags. Proteins generated from the protein generation model appear of higher quality according to metrics that describe higher level structure. This indicates that amino acid substitutions marked as errors according to lower-level metrics are likely to be acceptable substitutions that conserve structure and function at the more relevant higher levels of evaluation. This suggests that the protein generation model has learned to generate within the constraints of natural, structural invariances to substitutions in amino acid sequences. Conformational energy analysis reveals that the protein generation model generates proteins that are near the energy levels of native proteins, providing further evidence that they fulfill the desired functional properties.
In this way, conditional protein generation can be re-formulated as next-token prediction in natural language processing, where a token xi can either be an amino acid or a conditioning tag from x.
The attention layers 310 may be a variant of the Transformer that learns the conditional distributions over amino acids and conditioning tags. Further details of the Transformer can be found in Vaswani et al., Attention is All You Need, in proceedings of NIPS, 2017, which is hereby expressly incorporated by reference herein in its entirety. The input sequence x containing n tokens is embedded as a sequence of n corresponding vectors in d. Each vector is the sum of a learned token embedding and a sinusoidal positional embedding as in the original Transformer architecture. This sequence of vectors is stacked into a matrix x0∈n×d so that it can be processed by l attention layers. Specifically, the ith layer 315 receives an input of Xi from the preceding layer and then generates an output of Xi+1 which is fed to the next attention layer 316.
Thus, the first block 315a can be operated as follows:
H1=MultiHead(
where Hi is the output of the first block 315a.
The second block 315b consists of a layer normalization module 423 and a feedforward network 424. The feedforward network 424 includes ReLU activation that projects inputs to an inner dimension f with parameters U∈f×dFF(X)=max (0,XU)V. Thus, the second block 315b can be operated as follows:
Xi+1=FF(
With reference to
Scores(X0)=LayerNorm(X1)Wvocab
where Wvocab denotes a weight matrix having a dimension of the same size as the number of tokens in the token vocabulary. The Wvocab matrix transforms the normalization layer output to a score per token.
During generation, the output scores 320 corresponding to the final token are then normalized with a softmax module 340, yielding a distribution for sampling a new token. During training, the output scores 320 are the inputs of a cross-entropy module 330. Specifically, the neural network of the attention layers 310 with parameters θ can then be trained to minimize the negative log-likelihood over a training dataset D={x1, x2, . . . x|D|}:
Note that p(a|c), the distribution over proteins conditioned on their corresponding conditioning tags, is just one of the many conditional distributions that can be re-covered from a model that learns p(x). Thus, during generation, a new protein ã of length ma with desired properties encoded by a conditioning tag sequence {tilde over (c)} of length mc can then be generated by sequentially sampling its constituent symbols: pθ(a0|{tilde over (c)})pθ(a1|ã0,{tilde over (c)}), pθ(ãp|a<p, {tilde over (c)}).
In some embodiments, the aggregated dataset 519 may contain over 281M proteins, which can be the most comprehensive, non-redundant, annotated database of proteins used to train a machine learning model. The protein data from the protein dataset 519 contains amino acids 519a, which uses a vocabulary according to the 25 amino acids designations in IUPAC (see Pettit et al., The iupac stability constants database. Chemistry international, 2006). The conditioning tags 519b associated with the protein data are divided into 2 categories (1) keyword tags 520a and (2) taxonomic tags 520b. Following the definitions laid out in the UniprotKB controlled, and hierarchical vocabulary of keywords (many of which are derived from Gene Ontology (GO) terms), the conditioning keyword tags 520a included 1100 terms ranging from cellular component, biological process, and molecular function terms. The taxonomic tags 520b include 100k terms from the NCBI taxonomy across the eight standard taxonomic ranks. The aggregated dataset can then be split into a training set 521 of size 280M, a held-out protein family test set (OOD-test) 522 of size 100k, and a randomly sampled test set (ID-test) 523 of size 1M.
In some embodiments, OOD-test set 522 comprises 20 protein families, as defined in Pfam, that were excluded from the training dataset 521. As further illustrated in Table 1, performance on OOD-test measures ability to model samples from unseen protein families, whereas performance on ID-test measures ability to model samples from a wider range of protein families that more closely match the distribution of the training set.
At process 602, the protein generation module (e.g., 120 or 230) receives a data data sequence of amino acids and a set of target protein properties. For example, data relating to amino acids 519a and the conditional tags 519b representing protein properties can be received from multiple protein databases discussed in relation to
At process 604, the module forms an input sequence of tokens by prepending the set of target protein properties to the data sequence of amino acids, e.g., the input sequence 305 as discussed in relation to
At process 606, a set of scores indicating conditional distributions of next-token prediction corresponding to the input sequence of tokens is generated. For example, a unidirectional Transformer architecture comprising multiple attention layers 310 may be used to generate the output scores 320 as described in relation to
The module then determines whether it is at a training stage or a generation stage at process 608. If the module is at training stage, method 600 proceeds to process 614, at which the module computes a loss metric based on the set of scores over an input training dataset, e.g., a negative log-likelihood function (D) as discussed in relation to
If the module is at generation stage (e.g., not at training stage at process 608), method 600 proceeds to process 610, at which constituent amino acids from the data sequence of amino acids based on the set of scores. Specifically, the module generates proteins one amino acid at a time. For instance, at one step of generation, the module takes a context sequence of amino acids as input and outputs a probability distribution over amino acids. The module determines one amino acid based on the probability distribution (e.g., by sampling over the distribution) and then the context sequence is updated with the sampled amino acid. This process repeats until a protein sequence of desired length has been generated.
At process 612, an output data sequence of amino acids is formed from the sequentially sampled constituent amino acids. For example, the output data sequence of amino acids may be provided to a protein synthesis facility such as a bio-chemical laboratory for synthesizing the protein.
Method 700 starts at a generation stage of the protein generation module, e.g., method 700 may proceed from process 610 in
At process 710, if the desired protein length has been reached, method 700 proceeds to process 712, where the formed data sequence of desired length is output to a protein synthesis facility (e.g., a laboratory setting, etc.) for protein generation. Otherwise, if the current output sequence of amino acids has not reached the desired protein length, the method 700 proceeds to process 714, at which the constituent amino acids is added to the protein sequence.
In some embodiments, different combinations of data sequences of amino acids are generated by top-k sampling with a repetition penalty. The top-k sampling may be applied in a similar way as discussed in Radford et al., Generating long sequences with sparse transformers. arXiv preprint arXiv:1904.10509, 2019, which is hereby expressly incorporated by reference herein in its entirety. The repetition penalty reduces the probability that the same amino acid previously determined within four tokens prior to the current token is determined again. Instead, top-k sampling draws the next token from the k most probable tokens in the distribution output from the language model. For example, results for top-k values of k=1 and k=3 with repetition penalties of 0 and 1.2 may be used for determining the next amino acid.
At process 802, a training dataset is obtained, e.g., from protein database 519 shown in
At process 803, a set of conditional tags representing protein properties of a sample data sequence of amino acids may be formed based on metadata in the training dataset. For example, the conditional tags 519b may be further divided into keyword tags 520a and taxonomic tags 520b as discussed in relation to
At process 804, an input sequence is generated by prepending the set of conditional tags associate with the sample sequence to a sample data sequence of amino acids. In some embodiments, for a given sequence, there can be multiple versions of conditional tags across databases, each with their own associated conditioning tags. In training, the conditional tags may be randomly sampled but a bias toward SWISSPROT tags may be applied as they are manually verified.
In some embodiments, a dropout may be applied to the conditioning tags themselves at a rate of 0.4. In some embodiments, a sample data sequence of amino acids with the data sequence alone without conditioning tags is fed to the language model so that the language model can be used to complete proteins using only sequence data even when no protein properties are known.
In some embodiments, the input sequences are truncated to a maximum length of 512. Sequences of length less than 512 may be padded, but no loss was backpropagated through the network for padding tokens.
At process 806, a next-token prediction is generated by the language model from the generated input sequence. For example, the resulting language model has dimension d=1028, inner dimension f=512, 36 layers, and 8 heads per layer. Dropout may be applied with a probability of 0.1 that follows the residual connections in each layer. Token embeddings may be tied with the embeddings of the final output layer. For another example, the language model may be implemented in TensorFlow, as discussed in further detail in Abadi et al., Tensorflow: A system for large-scale machine learning, in 12th Symposium on Operating Systems Design and Implementation, pp. 265-283, 2016, which is hereby expressly incorporated by reference herein in its entirety.
At process 808, if there are more training sequences, method 800 proceeds to process 804 and repeats processes 804-806. If no more training sequence is available, method 800 proceeds to process 810, at which a loss metric is computed by summing a respective loss metric corresponding to each generated next-token prediction distribution over the training dataset. For example, the loss metric may be computed using the negative log-likelihood over the training dataset, as discussed in relation to
At process 812, the language model may be updated using the computed loss metric. For example, the language model may be trained with a global batch size of 64 distributed across 256 cores of a Cloud TPU v3 Pod for 1M iterations. As an example, training may take approximately two weeks with a linear warmup from 0 to 1e-2 over 40k steps. Gradient norms were clipped to 0.25.
One objective of protein engineering is to engineer functional proteins, e.g., the resulting generated data sequence 123 of amino acids would actually yield the target properties 105. Traditionally, protein engineering adopts directed evolution, which iterates through rounds of mutation and screening to converge at a high-fitness (e.g., functioning) protein. Some machine learning methods may aid in the subsequent rounds of directed evolution by in silico screening of proteins. These methods, however, still largely rely on random mutation in an exponentially large search space. In one embodiment, as the protein generation module 230 has learned the distribution of evolutionarily-relevant proteins, the protein generation module 230 may be expected to directly generate data sequences of amino acids that yield high-fitness proteins.
For example, a particular protein, protein G domain B1 (GB1) is used for binding to an antibody, which is important for the purification, immobilization, and detection of immunoglobulins (antibodies), proteins used by the immune system to neutralize pathogenic viruses and bacteria. Ideally, data sequences of amino acids are to be generated to form GB1 proteins with high binding affinity and stability. Possible variants of data sequences may include 149,361 of a total 160,000 possible variants from NNK/NNS saturation mutagenesis at four positions known to interact especially. Reported fitness values correspond to a measure of both stability (i.e. the fraction of folded proteins) and function (i.e. binding affinity to IgG-Fc) by coupling mRNA display with next-generation sequencing. Therefore, protein sequences with high fitness values are desired.
Method 900 starts at process 902, where an input sequence composed of a data sequence of amino acids and a set of target protein properties are generated, e.g., in a similar manner as process 702 in
At process 904, an output data sequence of amino acids with the lowest perplexity value from the one or more output data sequences may be selected. For example, the perplexity may be a metric for language models, which is the exponentiated cross-entropy loss computed over each token in a dataset. Thus, high quality language models are expected to have low perplexities. For example, without supervised training of the protein generation model on the GB1 data or unsupervised fine-tuning of the protein generation model on a subset of similar immunoglobulin-binding protein data, each variant is passed through the protein generation model and select the top one hundred variants with the lowest perplexity values.
At process 906, the fitness value of the selected output data sequence of amino acids can then be determined. If the fitness value is higher than a threshold at process 908, the selected data sequence of amino acids may be outputted for protein synthesis at process 910. Otherwise, method 900 goes back to process 904 to select another output data sequence of amino acids with a low perplexity value.
In addition to perplexity value, another metric to evaluate the performance of the protein generation module may be the mean per-token hard accuracy over the tokens in a sequence, which judges a prediction incorrect for any amino acid that is not the ground truth. Mean per-token soft accuracy relies on BLO-SUM62, a block substitution matrix that specifies which amino acid substitutions are more or less acceptable according to their frequency in known well-formed proteins. BLOSUM62 is widely used across adopted alignment software (e.g., BLAST2). For example, the mean per-token soft accuracy may use BLOSUM62 to penalize incorrect amino acid predictions according to the frequency of that substitution in the matrix. In this way, if the substitution is likely in nature, soft accuracy may penalize the model less.
To assess the quality of the data sequences outputted from the protein generation module, three levels of structures may be evaluated: (1) primary sequence similarity, (2) secondary structure accuracy, and (3) conformational energy analysis. For example, primary sequence similarity may be defined by a global, pairwise sequence alignment score computed with the Biopython package3. This score is based on the Needleman-Wunsch algorithm (Needleman et al, a general method applicable to the search for similarities in the amino acid sequence of two proteins. Journal of molecular biology, 48(3):443-453, 1970) informed by the BLOSUM62 substitution matrix. A gap open penalty of −0.5 and a gap continue penalty of −0.1 may be used. The resulting score is then normalized by the length of the protein. Experiments reporting sequence similarity are limited to test samples with a form of experimental evidence of X-ray/NMR crystallography, mass spectrometry, or existence in cDNA or RT-PCR to indicate transcript existence.
In one embodiment, secondary structure accuracy may be computed per-residue for predicted secondary structures by PSIPREDS with greater than 0.5 confidence. PSI-BLAST was performed on each generated sample to extract the Multiple Sequence Alignments (MSAs) with respect to the UniRef90 database proposed in Suzek et al., Uniref clusters: a comprehensive and scalable alternative for improving sequence similarity searches. Bioinformatics, 31(6):926-932, 2015. These MSAs were provided to PSIPRED for higher quality secondary structure prediction. Experiments reporting secondary structure accuracy were limited to test samples with high UniprotKB existence scores as described in the previous paragraph.
In one embodiment, conformational energy uses the Rosetta-RelaxBB protocol6. Rosetta-RelaxBB performs a Monte Carlo optimization of the Rosetta energy function over the space of amino acid types and rotamers. The Rosetta energy is based on biophysical laws and constraints. Between each design round, amino acid side-chains are replaced, while the carbon backbone torsions are kept fixed. Energy minimization/relaxation is performed after threading the amino acid sequence through the known structure. This allows the backbone to move, possibly into a lower energy state. A lower resulting Rosetta energy correlates to a more relaxed-state and viable conformation for a given protein sequence. Before applying the procedure above, the native template may be relaxed first. Experiments that report conformational energy are limited to test samples from SWISSPROT with associated 3D structures in RCSB PDB 7.
To assess generative quality, baselines are provided for different levels of random mutation. For a given sequence, a proportion (25-100%) of amino acids in the sequence is randomly substituted within one of the 20 standard amino acids other than itself. For conformational energy, we also include an all-alanine baseline (i.e. a sequence with only the amino acid alanine), as it is a non-bulky, chemically inert amino acid that mimics the existing secondary structure well when substituted. These baselines provide a scale across each of the above metrics. A particular random mutation may or may not have constructive or destructive effects on protein structure or function. But viewed in aggregate, the performance of the 100% mutation baseline for any metric indicates failed generation. As performance approaches 0%, generation statistically indicates a closer reflection to desired structural and functional properties.
Table 1 shows that the protein generation module is a high-quality language model according to per-token metrics on the training and test sets.
Protein generation module generalizes to the full test set and achieves perplexities representative of a high-quality language model. Perplexities reported in Table 1 demonstrate that protein generation module dramatically improves over a uniform baseline, in which amino acids are sampled according to a uniform distribution, and an empirical baseline, in which amino acids are sampled according to the empirical frequencies in the training set. As a point of reference, state-of-the-art unidirectional language models for English Wikipedia achieve perplexities that range from 10 to 17 depending on model size (between 257M and 8.3B parameters) and whether training data was constrained to the English Wikipedia
In addition, protein generation module generalizes to unseen protein families. The second section of Table 1 breaks this result into perplexities over the ID-test and OOD-test sets separately. Results on ID-test confirm that protein generation module generalizes well to sequences that belonged to protein families randomly sampled. As expected, performance is worse on the sequences in the OOD-test set, but the model still outperforms the empirical baseline for those held out protein families.
Fine-tuning protein generation module on unseen protein families improves over training from random initialization. The OOD-test is split into OOD-test-80 and OOD-test-20, fine-tuned protein generation module on OOD-test-80 until convergence (5 epochs; Adam; linear learning rate warmup to 1k iterations) and retested on OOD-test-20. The third section of Table 1 shows that fine-tuning from protein generation module improves over training the same architecture with randomly initialized weights.
Training curves further suggests that protein generation would benefit from even larger models and longer training. With 1B parameters, the protein generation module is comparable in size to the largest language models that have been publicly released for any modality, and, to the best of our knowledge, it is the largest model trained on amino acid sequences.
BLOSUM62 soft accuracy reveals that protein prediction errors often follow natural amino acid substitutions that likely conserve higher level structure. Though the protein generation models proteins as pure sequences, protein function is more directly determined by the secondary and tertiary structures that these sequences encode in three-dimensional space. Model performance based on BLOSUM62 soft accuracy is more than 20% higher than using hard accuracy, which indicates that when the protein generation errors may often be substitutions that are acceptable in nature be-cause they still reflect the proper higher-level properties. This suggests that protein generation module has learned how to work within function-preserving mutational invariances.
Sequence similarity suggests that the protein generation module merely approaches the 25% mutation baseline, but secondary structure accuracy suggests that the protein generation module surpasses it.
After threading and relaxation, samples generated by the protein generation module are likely to exhibit desired structure and function. As a measure of generation quality, the protein generation module sequences may be threaded through known structures and examine if they exhibit favorable, low energy states.
In one embodiment, the protein generation module was trained from a randomly initialized embedding layer with no prior knowledge of residue biochemical properties. Through per-token training on millions of protein sequences, the protein generation module seems to have inherently learned the natural clustering of amino acids that align with biophysicochemical properties.
Therefore, the protein generation module provides a controllable protein generation language model trained on the full evolutionary diversity of one of the largest sequence databases. The model generates proteins that exhibit near native structure energies which likely implies functional viability. The protein generation module has the potential to play a new, complementary role alongside other state-of-the-art methods in protein engineering. For example, in directed evolution, initial sequences may be sampled from the protein generation module according to desired conditioning tags. In later rounds of evolution, protein completion with context for particular residue spans, or hotspots, may provide higher fitness samples. In de novo protein design, using the protein generation module with conditioning tags may allow for designing new proteins with existing folding motifs in new protein families or host organisms. This same strategy may be used in conjunction with threading and structure-based protein design. Because conditioning tags orient protein generation module in sequence space, the protein generation module may even be used as a model to sample from the distribution of evolutionarily viable proteins near one particular protein. This may provide useful augmentations around data for non-homologous domains where existing techniques, such as MSAs, fall short.
Some examples of computing devices, such as computing device 200 may include non-transitory, tangible, machine readable media that include executable code that when run by one or more processors (e.g., processor 210) may cause the one or more processors to perform the processes of methods 600-900. Some common forms of machine readable media that may include the processes of methods 600-900 are, for example, floppy disk, flexible disk, hard disk, magnetic tape, any other magnetic medium, CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, any other memory chip or cartridge, and/or any other medium from which a processor or computer is adapted to read.
This description and the accompanying drawings that illustrate inventive aspects, embodiments, implementations, or applications should not be taken as limiting. Various mechanical, compositional, structural, electrical, and operational changes may be made without departing from the spirit and scope of this description and the claims. In some instances, well-known circuits, structures, or techniques have not been shown or described in detail in order not to obscure the embodiments of this disclosure Like numbers in two or more figures represent the same or similar elements.
In this description, specific details are set forth describing some embodiments consistent with the present disclosure. Numerous specific details are set forth in order to provide a thorough understanding of the embodiments. It will be apparent, however, to one skilled in the art that some embodiments may be practiced without some or all of these specific details. The specific embodiments disclosed herein are meant to be illustrative but not limiting. One skilled in the art may realize other elements that, although not specifically described here, are within the scope and the spirit of this disclosure. In addition, to avoid unnecessary repetition, one or more features shown and described in association with one embodiment may be incorporated into other embodiments unless specifically described otherwise or if the one or more features would make an embodiment non-functional.
Although illustrative embodiments have been shown and described, a wide range of modification, change and substitution is contemplated in the foregoing disclosure and in some instances, some features of the embodiments may be employed without a corresponding use of other features. One of ordinary skill in the art would recognize many variations, alternatives, and modifications. Thus, the scope of the invention should be limited only by the following claims, and it is appropriate that the claims be construed broadly and in a manner consistent with the scope of the embodiments disclosed herein.
Claims
1. A method for protein generation via a language model, the method comprising:
- receiving a data sequence of amino acids and a set of target protein properties;
- forming an input sequence of tokens by prepending the set of target protein properties to the data sequence of amino acids;
- generating, via the language model, a set of scores indicating conditional distributions of next-token prediction corresponding to the input sequence of tokens;
- sequentially determining a constituent amino acid from the data sequence of amino acids based on the set of scores; and
- forming an output data sequence of amino acids representing a protein from the sequentially determined constituent amino acids.
2. The method of claim 1, wherein the generating the set of scores comprises:
- embedding the input sequence of tokens a sequence of corresponding vectors stacked in a form of an input matrix; and
- feeding the input matrix to the NLP module having a plurality of attention layers.
3. The method of claim 2, wherein the plurality of attention layers includes at least one layer that has a first block and a second block sequentially connected to the first block.
4. The method of claim 3, wherein the first block includes a multi-head attention module with a plurality of heads using a causal mask.
5. The method of claim 4, further comprising;
- normalizing a first input to the first block with layer normalization;
- generating, via the multi-head attention module, a multi-head attention distribution from the normalized first input; and
- generating a first output of the first block by adding the multi-head attention distribution to the normalized first input.
6. The method of claim 3, wherein the second block includes a feedforward network with a ReLU activation.
7. The method of claim 6, further comprising:
- normalizing a first output received from the first block with layer normalization;
- generating, via the feedforward network, a feedforward distribution from the normalized first output; and
- generating a second output of the second block by adding the feedforward distribution to the normalized first output.
8. The method of claim 2, further comprising:
- computing the set of scores from an output of a last layer of the plurality of attention layers with layer normalization; and
- computing a first conditional distribution for sampling the constituent amino acids conditioned on the data sequence of amino acids based on the set of scores.
9. The method of claim 8, wherein the sequentially determining constituent amino acids comprises:
- sampling a first constituent amino acid from the data sequence of amino acids based on the first conditional distribution;
- adding the first constituent amino acid to the data sequence of amino acids;
- updating the input sequence of tokens by re-combining the data sequence of amino acids having the added first constituent amino acid into a context sequence;
- generating, from the updated input sequence of tokens, a second conditional distribution for sampling the constituent amino acids; and
- sampling a second constituent amino acid from the context sequence based on the second conditional distribution.
10. The method of claim 9, wherein the forming the output data sequence of amino acids representing the protein comprises:
- repeating sequential sampling until the output protein at a target length is formed.
11. A system for protein generation via a language model, the system comprising:
- a communication interface configured to receive a data sequence of amino acids and a set of target protein properties;
- a memory configured to store the language model; and
- a processor configured to:
- form an input sequence of tokens by prepending the set of target protein properties to the data sequence of amino acids;
- generate, via the language model, a set of scores indicating conditional distributions of next-token prediction corresponding to the input sequence of tokens;
- sequentially determine a constituent amino acid from the data sequence of amino acids based on the set of scores; and
- form an output data sequence of amino acids representing a protein from the sequentially determined constituent amino acids.
12. The system of claim 11, wherein the processor is further configured to generate the set of scores by:
- embedding the input sequence of tokens a sequence of corresponding vectors stacked in a form of an input matrix; and
- feeding the input matrix to the NLP module having a plurality of attention layers.
13. The system of claim 12, wherein the plurality of attention layers includes at least one layer that has a first block and a second block sequentially connected to the first block.
14. The system of claim 13, wherein the first block includes a multi-head attention module with a plurality of heads using a causal mask.
15. The system of claim 14, wherein the processor is further configured to:
- normalize a first input to the first block with layer normalization;
- generate, via the multi-head attention module, a multi-head attention distribution from the normalized first input; and
- generate a first output of the first block by adding the multi-head attention distribution to the normalized first input.
16. The system of claim 13, wherein the second block includes a feedforward network with a ReLU activation.
17. The system of claim 16, wherein the processor is further configured to:
- normalize a first output received from the first block with layer normalization;
- generate, via the feedforward network, a feedforward distribution from the normalized first output; and
- generate a second output of the second block by adding the feedforward distribution to the normalized first output.
18. The system of claim 12, wherein the processor is further configured to:
- compute the set of scores from an output of a last layer of the plurality of attention layers with layer normalization; and
- compute a first conditional distribution for sampling the constituent amino acids conditioned on the data sequence of amino acids based on the set of scores.
19. The system of claim 18, wherein the processor is configured to sequentially determine constituent amino acids by:
- sampling a first constituent amino acid from the data sequence of amino acids based on the first conditional distribution;
- adding the first constituent amino acid to the data sequence of amino acids;
- updating the input sequence of tokens by re-combining the data sequence of amino acids having the added first constituent amino acid into a context sequence;
- generating, from the updated input sequence of tokens, a second conditional distribution for sampling the constituent amino acids;
- sampling a second constituent amino acid from the context sequence based on the second conditional distribution; and
- repeating sequential sampling until the output protein at a target length is formed.
20. A process-readable non-transitory storage medium storing processor-executable instructions for protein generation via a language model, the processor-executable instructions being executable by a processor to perform:
- receiving a data sequence of amino acids and a set of target protein properties;
- forming an input sequence of tokens by prepending the set of target protein properties to the data sequence of amino acids;
- generating, via the language model, a set of scores indicating conditional distributions of next-token prediction corresponding to the input sequence of tokens;
- sequentially determining a constituent amino acid from the data sequence of amino acids based on the set of scores; and
- forming an output data sequence of amino acids representing a protein from the sequentially determined constituent amino acids.
Type: Application
Filed: Aug 24, 2020
Publication Date: Aug 12, 2021
Inventors: Ali Madani (San Francisco, CA), Bryan McCann (Menlo Park, CA), Nikhil Naik (Mountain View, CA)
Application Number: 17/001,045