BCH394P BCH364C 2023: Difference between revisions

From Marcotte Lab
Jump to navigationJump to search
No edit summary
 
(42 intermediate revisions by the same user not shown)
Line 31: Line 31:




'''Mar 30, 2023 - Deep learning'''
* Guest speaker: [https://scholar.google.com/citations?hl=en&user=AOYsDhsAAAAJ&view_op=list_works&sortby=pubdate Dr. Claire McWhite], who is a Lewis-Sigler Fellow at Princeton where she develops protein language models using deep learning. She previously completed her B.S. at Rice University, interned at the National Cancer Institute, earned her Ph.D. at UT Austin working extensively in computational biology and proteomics, and appeared as a contestant in [http://bahfest.com/houston2017/ BahFest].
* [http://www.marcottelab.org/users/BCH394P_364C_2023/ClaireMcWhite-BCH394p-364c_2023.pdf Today's slides]
* [https://www.youtube.com/watch?v=CfAL_cL3SGQ Why neural networks aren't neural networks]
-->
'''April 11, 2023 - Synthetic Biology, highly compressed'''
'''April 11, 2023 - Synthetic Biology, highly compressed'''
* '''Reminder: All projects are due by midnight, April 25'''.  Turn them in as a URL to the web site you created, sent by email to the TA AND PROFESSOR.   
* '''Reminder: All projects are due by 10PM, April 12'''.  Turn them in as a URL to the web site you created, sent by email to the TA AND PROFESSOR.   
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_SyntheticBio_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_SyntheticBio_Spring2023.pdf Today's slides]
A collection of further reading, if you're so inclined:
A collection of further reading, if you're so inclined:
Line 51: Line 57:
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EdgeDetector.pdf Edge detector]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EdgeDetector.pdf Edge detector]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/nbt.2510.pdf A nice example of digital logic]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/nbt.2510.pdf A nice example of digital logic]
[http://www.popsci.com/woolly-mammoth-dna-brought-life-elephant-cells Food for thought]
[https://colossal.com/ Food for thought]




'''April 6, 2023 - Phenologs'''
'''April 6, 2023 - Orthologs and Phenologs'''
* '''Remember: The final project web page is due by midnight April 25, 2023, turned in as a URL emailed to the TA+Professor.  Please indicate in the email if you are willing to let us post the project to the course web site.  Also, note that ''late days can't be used for the final project'' '''  
* '''Remember: The final project web page is due by 10PM April 12, 2023, turned in as a URL emailed to the TA+Professor.  Please indicate in the email if you are willing to let us post the project to the course web site.  Also, note that ''late days can't be used for the final project'' '''  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Phenologs_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Phenologs_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/paper-pdfs/PNAS_Phenologs_2010.pdf Phenologs] and the [http://www.marcottelab.org/paper-pdfs/PLoSBiology_TBZ_2012.pdf drug discovery story] we'll discuss in class. This is a fun example of the power of opportunistic data mining aka [http://researchparasite.com/ "research parasitism"] in biomedical research.
* [http://www.marcottelab.org/paper-pdfs/PNAS_Phenologs_2010.pdf Phenologs] and the [http://www.marcottelab.org/paper-pdfs/PLoSBiology_TBZ_2012.pdf drug discovery story] we'll discuss in class. This is a fun example of the power of opportunistic data mining aka [http://researchparasite.com/ "research parasitism"] in biomedical research.
* Search for phenologs [http://www.phenologs.org/ here].  You can get started by rediscovering the plant model of Waardenburg syndrome.  Search among the known diseases for "Waardenburg", or enter the human genes linked to Waardenburg (Entrez gene IDs 4286, 5077, 6591, 7299) to get a feel for how this works.
* Search for phenologs [http://www.phenologs.org/ here].  You can get started by rediscovering the plant model of Waardenburg syndrome.  Search among the known diseases for "Waardenburg", or enter the human genes linked to Waardenburg (Entrez gene IDs 4286, 5077, 6591, 7299) to get a feel for how this works.
Tools for finding orthologs:<br>
Tools for finding orthologs:<br>
* One good tool for discovering orthologs is [http://inparanoid.sbc.su.se/cgi-bin/index.cgi InParanoid].  Note: InParanoid annotation lags a bit, so you'll need to find the [http://www.ensembl.org/index.html Ensembl] protein id, or try a text search for the common name. Or, just link there from [http://www.uniprot.org/ Uniprot]. InParanoid tends towards higher recall, lower precision for finding orthologs. Approaches with higher precision include [http://omabrowser.org/oma/home/ OMA] (introduced in [http://www.marcottelab.org/users/BCH394P_364C_2023/OMA.pdf this paper]), [http://phylomedb.org/ PhylomeDB], and [http://eggnogdb.embl.de/#/app/home EggNOG].  The various algorithms basically have different trade-offs with regard to precision vs recall, and ease of use.  For example, we use EggNOG in the lab for annotating genes in new genomes/transcriptomes because the EggNOG HMM ortholog models are easily downloadable/re-run on any set of genes you happen to be interested in.
* One good tool for discovering orthologs is [https://inparanoidb.sbc.su.se/ InParanoid].  Note: InParanoid annotation lags a bit, so you'll need to find the [http://www.ensembl.org/index.html Ensembl] protein id, or try a text search for the common name. Or, just link there from [http://www.uniprot.org/ Uniprot]. InParanoid tends towards higher recall, lower precision for finding orthologs. Approaches with higher precision include [http://omabrowser.org/oma/home/ OMA] (introduced in [http://www.marcottelab.org/users/BCH394P_364C_2023/OMA.pdf this paper]), [http://phylomedb.org/ PhylomeDB], and [http://eggnogdb.embl.de/#/app/home EggNOG].  The various algorithms basically have different trade-offs with regard to precision vs recall, and ease of use.  For example, we use EggNOG in the lab for annotating genes in new genomes/transcriptomes because the EggNOG HMM ortholog models are easily downloadable/re-run on any set of genes you happen to be interested in.
* All (well, at least some) of [http://www.marcottelab.org/users/BCH394P_364C_2023/Sonnhammer2002TiG.pdf your ortholog definition questions answered!]
* All (well, at least some) of [http://www.marcottelab.org/users/BCH394P_364C_2023/Sonnhammer2002TiG.pdf your ortholog definition questions answered!]


Line 66: Line 72:
'''Apr 4, 2023 - Networks'''
'''Apr 4, 2023 - Networks'''
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Networks_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Networks_Spring2023.pdf Today's slides]
* Metabolic networks: [https://web.expasy.org/pathways/ The wall chart] (it's interactive. For example, can you find enolase?), the [http://www.marcottelab.org/users/BCH394P_364C_2023/HumanMetabolicReactionNetwork-2013.pdf human metabolic reaction network], a review of [http://www.marcottelab.org/users/BCH394P_364C_2023/ChiPSeqReview.pdf mapping transcriptional networks by Chip-SEQ] (with the current record holder in this regard held by [https://www.encodeproject.org/ ENCODE]), and a review of [http://www.marcottelab.org/users/BCH394P_364C_2023/PPIsAndDiseaseReview.pdf protein interaction mapping in humans] and how it is informing disease genetics.
* Metabolic networks: [https://web.expasy.org/pathways/ The wall chart] (it's interactive. For example, can you find enolase?), the [https://metabolicatlas.org/ human metabolic reaction network], a review of [http://www.marcottelab.org/users/BCH394P_364C_2023/ChIP-profiling-review.pdf mapping transcriptional networks by Chip-SEQ] (with the current record holder in this regard probably held by [https://www.encodeproject.org/ ENCODE]), and a review of [http://www.marcottelab.org/users/BCH394P_364C_2023/PPIsAndDiseaseReview.pdf protein interaction mapping in humans] and how it is informing disease genetics.
* Useful gene network resources include:
* Useful gene network resources include:
** [http://www.reactome.org/ Reactome]), which we've seen before, links human genes according to reactions and pathways, and also calculated functional linkages from various high-throughput data.
** [http://www.reactome.org/ Reactome]), which we've seen before, links human genes according to reactions and pathways, and also calculated functional linkages from various high-throughput data.
Line 72: Line 78:
** [http://string-db.org/ STRING] is available for many organisms, including large numbers of prokaryotes. Try searching on the <i>E. coli</i> enolase (Eno) as an example.
** [http://string-db.org/ STRING] is available for many organisms, including large numbers of prokaryotes. Try searching on the <i>E. coli</i> enolase (Eno) as an example.
** [http://www.genemania.org/ GeneMania], which aggregates many individual gene networks.
** [http://www.genemania.org/ GeneMania], which aggregates many individual gene networks.
** The best interactive tool for network visualization is [http://www.cytoscape.org/ Cytoscape]. You can download and install it locally on your computer, then visualize and annotated any gene network, such as are output by the network tools linked above.  There is also a web-based network viewer that can be incorporated into your own pages (e.g., as used in [http://www.inetbio.org/yeastnet/ YeastNet]).  Here's an example file to visualize, the [http://proteincomplexes.org/static/downloads/humap2_protein_complex_map_20200821.cys human protein complex map] from [http://humap2.proteincomplexes.org/ Hu.MAP].
** The best interactive tool for network visualization is [http://www.cytoscape.org/ Cytoscape]. You can download and install it locally on your computer, then visualize and annotated any gene network, such as are output by the network tools linked above.  There is also a web-based network viewer that can be incorporated into your own pages (e.g., as used in [http://www.inetbio.org/yeastnet/ YeastNet]).  Here's an example file to visualize, the [http://humap2.proteincomplexes.org/static/downloads/humap2/humap2_protein_complex_map_20200821.cys human protein complex map] from [http://humap2.proteincomplexes.org/ Hu.MAP2].
** Clustering algorithms can be applied to networks. For example, we frequently use the [http://www.marcottelab.org/users/BCH394P_364C_2023/WalktrapAlgorithm.pdf Walktrap algorithm] developed by Pascal Pons and Matthieu Latapy, which is available in the Python iGraph library. Here's [https://towardsdatascience.com/detecting-communities-in-a-language-co-occurrence-network-f6d9dfc70bab a nice blog demonstration] using it.
** Clustering algorithms can be applied to networks. For example, we frequently use the [http://www.marcottelab.org/users/BCH394P_364C_2023/WalktrapAlgorithm.pdf Walktrap algorithm] developed by Pascal Pons and Matthieu Latapy, which is available in the Python iGraph library. Here's [https://towardsdatascience.com/detecting-communities-in-a-language-co-occurrence-network-f6d9dfc70bab a nice blog demonstration] using it.
Reading:<br>
Reading:<br>
Line 82: Line 88:




'''Mar 30, 2023 - Deep learning'''
'''Mar 30, 2023 - Principal Component Analysis (& the curious case of European genotypes)'''
* Guest speaker: [https://scholar.google.com/citations?hl=en&user=AOYsDhsAAAAJ&view_op=list_works&sortby=pubdate Dr. Claire McWhite], who is a Lewis-Sigler Fellow at Princeton where she develops protein language models using deep learning. She previously completed her B.S. at Rice University, interned at the National Cancer Institute, earned her Ph.D. at UT Austin working extensively in computational biology and proteomics, and appeared as a contestant in [http://bahfest.com/houston2017/ BahFest].
* [http://www.marcottelab.org/users/BCH394P_364C_2023/ClaireMcWhite-BCH394p-364c_2023.pdf Today's slides]
* [https://www.youtube.com/watch?v=CfAL_cL3SGQ Why neural networks aren't neural networks]
 
 
'''Mar 28, 2023 - Principal Component Analysis (& the curious case of European genotypes)'''
* '''Reminder: Problem Set 3 is due tomorrow!'''
* Science news of the day:  Just a fun piece, a [https://pursuit.unimelb.edu.au/articles/piecing-thylacine-dna-back-together chromosome level genome assembly of the extinct thylacine (Tasmanian tiger)]"
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_PCA_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_PCA_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EuropeanGenesPCA.pdf European men, their genomes, and their geography]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EuropeanGenesPCA.pdf European men, their genomes, and their geography]
Line 102: Line 100:




'''Mar 23, 2023 - 3D Protein Structure Modeling'''
'''Mar 28, 2023 - Classifiers'''
* Guest speaker: [https://scholar.google.com/citations?hl=en&user=XK51dq0AAAAJ&view_op=list_works&sortby=pubdate Caitie McCafferty], who is finishing up her Ph.D. at UT Austin, prior to which she earned her B.S. in Chemistry at the University of Maryland and worked as a computational researcher for 3 years at the NIH National Eye Institute. She has mentored numerous undergrads in computational structural biology, co-developed the citizen science video game [https://vitalmindmedia.com/proteinpuzzles/ Protein Puzzles], and is now leading local efforts to solve the 3D structures of ciliary proteins by cryoEM, mass spec, and integrative modeling.
* [https://twitter.com/JedMSP/status/1247920130941538304 A topical tSNE visualization]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/2023-03-ProteinStructurePrediction_CaitieMcCafferty.pdf Today's slides] and the [http://www.marcottelab.org/users/BCH394P_364C_2023/EVcouplings.pdf EVcouplings method] discussed
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P_364C_Classifiers_Spring2023.pdf Today's slides]
* 3D macromolecular structural modeling software: [https://www.cgl.ucsf.edu/chimerax/ UCSF ChimeraX], the [https://www.rosettacommons.org/software Rosetta] software suite, and [http://www.marcottelab.org/users/BCH394P_364C_2023/RosettaOverview.pdf an overview] of what it can do for you, and last but not least: [https://alphafold.ebi.ac.uk/ AlphaFold predicted structures] and the [https://colab.research.google.com/github/deepmind/alphafold/blob/main/notebooks/AlphaFold.ipynb AlphaFold colab] where you can run your own structure predictions.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/MachineLearningReview.pdf A nice review explaining Support Vector Machines and k-NN classifiers]
* & a few other useful 3D structure tools: The [http://www.rcsb.org/ Protein Data Bank], [https://salilab.org/modeller/ MODELLER], and [http://www.pymol.org/ Pymol]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/AMLALLclassification.pdf Classifying leukemias], and [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC6036716/ a 2018 review] and [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC8000474/ 2021 review] of how that field has led to commercial cancer diagnostics, such as the Prosigna breast cancer diagnostic. If you're curious, the authors of the AMLALL classification paper [http://www.marcottelab.org/users/BCH394P_364C_2023/LanderGolubPatentOnExpressionClassification.pdf patented their approach]
* For those of you interesting in trying out classifiers on your own, here's the best stand-alone open software for do-it-yourself classifiers and data mining: [http://www.cs.waikato.ac.nz/ml/weka/ Weka].  There is a great introduction to using Weka in this book chapter [http://link.springer.com/protocol/10.1007/978-1-4939-3578-9_17 Introducing Machine Learning Concepts with WEKA], as well as the very accessible Weka-produced book [http://www.cs.waikato.ac.nz/ml/weka/book.html Data Mining: Practical Machine Learning Tools and Techniques].
* & to do this directly in Python, there's a really excellent library of simple, easy-to-use, classification, regression, machine learning and data mining tools called [https://scikit-learn.org/stable/ scikit-learn].  I highly recommend using scikit-learn in combination with the [https://pandas.pydata.org/ pandas library], which makes it easy to work with large, tabular datasets. Here's [https://www.youtube.com/watch?v=PcvsOaixUh8 a helpful pandas tutorial] to get you started.
 


'''Mar 23, 2023 - Proteomics'''
* Guest speaker: [https://scholar.google.com/citations?hl=en&user=vnlxkVwAAAAJ&view_op=list_works Dr. Peter Faull], who earned his Ph.D. at the University of Edinburgh and subsequently served as Head of Proteomics at the MRC UK Clinical Sciences Centre and as a senior lab research scientist at the Francis Crick Institute in London before joining us at UT, where he now serves as Principal Proteomics Scientist in the [https://research.utexas.edu/cbrs/cores/bms/ UT Biological Mass Spectrometry core].
<!--
* [http://www.marcottelab.org/users/BCH394P_364C_2023/IntroToProteomics2-03-24-2023.pdf Today's slides]-->


'''Mar 21, 2023 - Proteomics'''
* Guest speaker: [https://scholar.google.com/citations?hl=en&user=sYCFT1YAAAAJ&view_op=list_works Dr. Daniel Boutz], who earned his Ph.D. at UCLA and worked extensively in the UT Center for Systems and Synthetic Biology and the Army Research Laboratories - South in Austin. He co-developed a [https://cns.utexas.edu/news/ut-austin-harnesses-power-of-biology-in-partnership-with-army-research-laboratory highly effective therapeutic antibody discovery approach] that he is now setting up a dedicated center around at Houston Methodist Hospital.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/IntroToProteomics2-03-24-2023.pdf Today's slides]


'''Mar 21, 2023 - 3D Protein Structure Modeling'''
* '''Reminder: Your project topic is due today, and Problem Set #3 is due tomorrow.'''
* Guest speaker: [https://sites.cns.utexas.edu/zhanglab/bio Prof. Y. Jessie Zhang], an expert on RNA polymerase, its post-translational modifications, and their effects on eukaryotic transcription. She combines experimental structure determination by X-ray crystallography with computational structure prediction using techniques like AlphaFold, and will talk about protein 3D structure modeling and prediction.
<!--
* [http://www.marcottelab.org/users/BCH394P_364C_2023/2023-03-ProteinStructurePrediction_CaitieMcCafferty.pdf Today's slides]
-->
* 3D macromolecular structural modeling software:  [https://www.cgl.ucsf.edu/chimerax/ UCSF ChimeraX], the [https://www.rosettacommons.org/software Rosetta] software suite, and [http://www.marcottelab.org/users/BCH394P_364C_2023/RosettaReview.pdf an overview] of what it can do for you, and last but not least: [https://alphafold.ebi.ac.uk/ AlphaFold predicted structures] and the [https://colab.research.google.com/github/sokrypton/ColabFold/blob/main/AlphaFold2.ipynb AlphaFold colab] where you can run your own structure predictions.
* & a few other useful 3D structure tools: The [http://www.rcsb.org/ Protein Data Bank], [https://salilab.org/modeller/ MODELLER], and [http://www.pymol.org/ Pymol]


'''Mar 14,16, 2023 - SPRING BREAK'''
* Don't forget to finish HW3 and turn in the proposal for your course project by "March 21st".


'''Mar 20, 2023''' - Apologies, no office hours today. Feel free to reach out by email or attend the TA office hours this week.


'''Mar 9, 2023 - Classifiers'''
* [https://twitter.com/JedMSP/status/1247920130941538304 A topical tSNE visualization]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P_364C_Classifiers_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/MachineLearningReview.pdf A nice review explaining Support Vector Machines and k-NN classifiers]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/AMLALLclassification.pdf Classifying leukemias], and [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC6036716/ a 2018 review] and [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC8000474/ 2021 review] of how that field has led to commercial cancer diagnostics, such as the Prosigna breast cancer diagnostic.
* For those of you interesting in trying out classifiers on your own, here's the best stand-alone open software for do-it-yourself classifiers and data mining: [http://www.cs.waikato.ac.nz/ml/weka/ Weka].  There is a great introduction to using Weka in this book chapter [http://link.springer.com/protocol/10.1007/978-1-4939-3578-9_17 Introducing Machine Learning Concepts with WEKA], as well as the very accessible Weka-produced book [http://www.cs.waikato.ac.nz/ml/weka/book.html Data Mining: Practical Machine Learning Tools and Techniques].
* & to do this directly in Python, there's a really excellent library of simple, easy-to-use, classification, regression, machine learning and data mining tools called [https://scikit-learn.org/stable/ scikit-learn].  I highly recommend using scikit-learn in combination with the [https://pandas.pydata.org/ pandas library], which makes it easy to work with large, tabular datasets. Here's [https://www.youtube.com/watch?v=PcvsOaixUh8 a helpful pandas tutorial] to get you started.


'''Mar 14,16, 2023 - SPRING BREAK'''
* Don't forget to turn in the proposal for your course project by '''March 21st''' and finish HW3 by '''March 22nd'''.




'''Mar 7, 2023 - Clustering II'''
'''Mar 9, 2023 - Clustering II'''
-->
* We'll be continuing the slides from last time
<!-- * Fun article: [http://journals.plos.org/plosbiology/article?id=10.1371/journal.pbio.2002050 All biology is computational biology]-->
<!--
* We'll be continuing the slides from just before the guest lecture
* I'm also posting the next (last) problem set:
* I'm also posting the next (last) problem set:
[http://www.marcottelab.org/users/BCH394P_364C_2023/ProblemSet3_2023.pdf '''Problem Set 3], due before midnight Apr. 8, 2023'''.  You will need the following software and datasets:<br>
[http://www.marcottelab.org/users/BCH394P_364C_2023/ProblemSet3_2023.pdf '''Problem Set 3], due before 10PM Mar. 22, 2023'''.  You will need the following software and datasets:<br>
* The clustering software is available [https://software.broadinstitute.org/morpheus/ here]. There is an alternative package [http://bonsai.hgc.jp/~mdehoon/software/cluster/software.htm here] that you can download and install on your local computer if you prefer.<br>  
* The clustering software is available [https://software.broadinstitute.org/morpheus/ here]. There is an alternative package [http://bonsai.hgc.jp/~mdehoon/software/cluster/software.htm here] that you can download and install on your local computer if you prefer.<br>  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteins.fasta Amino acid sequences of 1832 human proteins]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteins.fasta Amino acid sequences of 1832 human proteins]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteinsPhyloprofiles.txt Human protein phylogenetic profiles]. These data come from [http://www.marcottelab.org/users/BCH394P_364C_2023/CiliaPhyloProfiles.pdf this paper].
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteinsPhyloprofiles.txt Human protein phylogenetic profiles]. These data come from [http://www.marcottelab.org/users/BCH394P_364C_2023/CiliaPhyloProfiles.pdf this paper].
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteinsCFMS.txt Human protein co-fractionation/mass spectrometry profiles].  These data come from [http://www.marcottelab.org/paper-pdfs/Nature_AnimalComplexes_2015.pdf this paper].
* [http://www.marcottelab.org/users/BCH394P_364C_2023/1832HumanProteinsCFMS.txt Human protein co-fractionation/mass spectrometry profiles].  These data come from [http://www.marcottelab.org/paper-pdfs/Nature_AnimalComplexes_2015.pdf this paper].
-->
<!--* [https://twitter.com/iddux/status/1377587235051204610 New changes for the next version of Python?]-->
<!--
Reading:
Reading:
* [http://www.marcottelab.org/users/BCH394P_364C_2023/nature_review_2000.pdf Review of phylogenetic profiles]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/nature_review_2000.pdf Review of phylogenetic profiles]
Line 147: Line 145:
* [http://www.marcottelab.org/users/BCH394P_364C_2023/SOM-geneexpression.pdf SOM gene expression]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/SOM-geneexpression.pdf SOM gene expression]
** Links to various applications of SOMs: [http://en.wikipedia.org/wiki/Self-organizing_map 1], [http://vizier.u-strasbg.fr/kohonen.htx 2], [http://wn.com/Self_Organizing_Maps_Application 3]. You can run SOM clustering with the [http://bonsai.hgc.jp/~mdehoon/software/cluster Open Source Clustering package] with the '-s' option, or GUI option (here's the [http://bonsai.hgc.jp/~mdehoon/software/cluster/manual/SOM.html#SOM manual]). (FYI, it also supports PCA). If you are not happy with Cluster's SOM function, the statistical package R also provides a package for calculating SOMs (http://cran.r-project.org/web/packages/som/index.html).  
** Links to various applications of SOMs: [http://en.wikipedia.org/wiki/Self-organizing_map 1], [http://vizier.u-strasbg.fr/kohonen.htx 2], [http://wn.com/Self_Organizing_Maps_Application 3]. You can run SOM clustering with the [http://bonsai.hgc.jp/~mdehoon/software/cluster Open Source Clustering package] with the '-s' option, or GUI option (here's the [http://bonsai.hgc.jp/~mdehoon/software/cluster/manual/SOM.html#SOM manual]). (FYI, it also supports PCA). If you are not happy with Cluster's SOM function, the statistical package R also provides a package for calculating SOMs (http://cran.r-project.org/web/packages/som/index.html).  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/tSNE.pdf t-SNE]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/tSNE.pdf t-SNE] and [https://umap-learn.readthedocs.io/en/latest/how_umap_works.html UMAP]
** Links to various applications of t-SNE: [https://en.wikipedia.org/wiki/T-distributed_stochastic_neighbor_embedding 1], [http://lvdmaaten.github.io/tsne/ 2], [https://www.youtube.com/watch?v=RJVL80Gg3lA 3], [http://distill.pub/2016/misread-tsne/ 4]. You can run t-SNE on the [http://projector.tensorflow.org/ following web site].  
** Links to various applications of t-SNE: [https://en.wikipedia.org/wiki/T-distributed_stochastic_neighbor_embedding 1], [http://lvdmaaten.github.io/tsne/ 2], [https://www.youtube.com/watch?v=RJVL80Gg3lA 3], [http://distill.pub/2016/misread-tsne/ 4]. You can run t-SNE and UMAP on the [http://projector.tensorflow.org/ following web site].  




'''Mar 2, 2023 - Functional Genomics & Data Mining - Clustering I'''
'''Mar 7, 2023 - Functional Genomics & Data Mining - Clustering I'''
* Science news of the day: The [https://www.biorxiv.org/content/10.1101/2023.02.14.480449v2.full latest tests] of HexaPro look very promising! UT has granted a royalty-free license to 80 low and middle income countries around the world for vaccine use of HexaPro. You can read more about the development of HexaPro by the McLellan, Finkelstein, and Maynard labs in [https://www.nytimes.com/2021/04/05/health/hexapro-mclellan-vaccine.html this very nice NYT article].
* '''Due March 21 by email to the TA+Instructor''' - One to two (full) paragraphs describing your plans for a final project, along with the names of your collaborators. Please limit to no more than 3 per group, please.  It's also fine to do this independently, if you prefer. (Do you have a particular skill/interest/exciting dataset you need help analyzing? There is a class_projects channel on the slack where you can ask around for partners.) This assignment (planning out your project) will account for 5 points out of your 25 total points for your course project. Here are a few examples of final projects from previous years: [https://sites.google.com/view/bioinformaticsproject/introduction-and-goals?authuser=0 1] [https://sites.google.com/view/bch394ssy/home 2] [https://sites.google.com/view/bch394p-project/home 3] [https://sites.google.com/site/modelingpyrosequencingerror/ 4] [http://sites.google.com/site/pathtarandmore/ 5] [http://sites.google.com/site/zlutexas/Home/project-for-ch391l 6] [https://sites.google.com/view/subcellularloc/projects 7] [https://sites.google.com/utexas.edu/voigt-final-project/home?authuser=0 8] [https://sites.google.com/site/ch391lchipseq/ 9] [https://sites.google.com/utexas.edu/oishika-das-bioinformatics-pro/home 10] [https://sites.google.com/site/biogridviewer/home 11] [https://sites.google.com/a/utexas.edu/immunoglobulin-team/home 12] [https://metabolicnetworkpathways.wordpress.com/ 13] [https://sites.google.com/a/utexas.edu/quantum-tunneling-on-enzymatic-kinetics/home 14]<br>
* Science news of the day:  [https://www.cell.com/cell/fulltext/S0092-8674(23)00107-1 The genome of Antarctic krill (the crustacean E. superba) has been sequenced] and is crazy. It's 48 Gb in size, so 15x the human genome (!), one of the largest genomes ever assembled. And >92% of that is repetitive DNA. Solved with a combination of short and long read DNA sequencing.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P_364C_LargeScaleExperiments_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P_364C_LargeScaleExperiments_Spring2023.pdf Today's slides]
Reading:<br>
Reading:<br>
Line 163: Line 162:




'''Feb 28, 2023 - Motifs'''
'''Mar 2, 2023 - Motifs'''
* '''Due March 21 by email to the TA+Instructor''' - One to two (full) paragraphs describing your plans for a final project, along with the names of your collaborators. Please limit to no more than 3 per group, please.  It's also fine to do this independently, if you prefer. (Do you have a particular skill/interest/exciting dataset you need help analyzing? There is a class_projects channel on the slack where you can ask around for partners.) This assignment (planning out your project) will account for 5 points out of your 25 total points for your course project. Here are a few examples of final projects from previous years: [https://sites.google.com/view/bch394pproject/homepage?authuser=1 0] [http://sites.google.com/site/ch391fall08finaloconnellwang/?pageDeleted=%2Fa-monte-carlo-simulation-of-protein-polymerization-in-budding-yeast 1] [http://sites.google.com/site/polyomamirnatargeting/ 2] [http://sites.google.com/site/pathtarandmore/ 3] [http://sites.google.com/site/zlutexas/Home/project-for-ch391l 4] [https://sites.google.com/site/structureandevolutionofaprd4/home 5] [https://sites.google.com/site/modelingpyrosequencingerror/ 6]  [https://sites.google.com/site/bioinformaticsch391lproject/ 7] [https://sites.google.com/site/emilo83/home 8] [https://sites.google.com/site/ch391lchipseq/ 9] [https://sites.google.com/site/arabmybgrant/ 10] [https://sites.google.com/site/biogridviewer/home 11] [https://sites.google.com/a/utexas.edu/immunoglobulin-team/home 12] [https://metabolicnetworkpathways.wordpress.com/ 13] [https://sites.google.com/a/utexas.edu/quantum-tunneling-on-enzymatic-kinetics/home 14] [https://sites.google.com/view/bch394ssy/home 15]<br>
* We'll talk about motif finding today.  
* We'll talk about motif finding today.  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Motifs_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_Motifs_Spring2023.pdf Today's slides]
Line 174: Line 172:




'''Feb 23, 2023 - NGS analysis best practices'''
'''Feb 28, 2023 - NGS analysis best practices'''
* Homework #3 (worth 10% of your final course grade) has been assigned on Rosalind and is '''due by 11:59PM March 21'''. In past years, we've run into problems with Rosalind timing out before Meme completes although it usually runs eventually, so be warned you may have to try it a couple of times. Meme also runs faster using the "zero to one" or "one" occurrence per sequence option, rather than the "any number of repeats" option.
* Homework #3 (worth 10% of your final course grade) has been assigned on Rosalind and is '''due by 10:00PM March 9'''. In past years, we've run into problems with Rosalind timing out before Meme completes although it usually runs eventually, so be warned you may have to try it a couple of times. Meme also runs faster using the "zero to one" or "one" occurrence per sequence option, rather than the "any number of repeats" option.
* Guest speaker: [https://www.linkedin.com/in/anna-battenhouse-abba1/details/experience/ Anna Battenhouse] from the [https://research.utexas.edu/cbrs/ Center for Biomedical Research Support], where she maintains the [https://wikis.utexas.edu/display/RCTFusers Biomedical Research Computing Facility].  
* Guest speaker: [https://www.linkedin.com/in/anna-battenhouse-abba1/ Anna Battenhouse] from the [https://research.utexas.edu/cbrs/ Center for Biomedical Research Support], where she maintains the [https://wikis.utexas.edu/display/RCTFusers Biomedical Research Computing Facility].  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/2023-03-NGS_IntroForEdM.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/2023-02-NGS_IntroForEdM.pdf Today's slides]




'''Feb 21, 2023 - Genomes II'''<br>
'''Feb 23, 2023 - Genome Assembly/Mapping II'''<br>
* We're finishing up the slides from last time. Note that we give short shrift to read mapping/alignment algorithms, of which there are now [https://en.wikipedia.org/wiki/List_of_sequence_alignment_software#Short-Read_Sequence_Alignment a very long list]. Here's an interesting discussion by Lior Pachter of the [https://liorpachter.wordpress.com/2015/11/01/what-is-a-read-mapping/ major developments in that field.]
* We're finishing up the slides from last time. Note that we give short shrift to read mapping/alignment algorithms, of which there are now [https://en.wikipedia.org/wiki/List_of_sequence_alignment_software#Short-Read_Sequence_Alignment a very long list]. Here's an interesting discussion by Lior Pachter of the [https://liorpachter.wordpress.com/2015/11/01/what-is-a-read-mapping/ major developments in that field.]
* Here is [http://blog.thegrandlocus.com/2016/07/a-tutorial-on-burrows-wheeler-indexing-methods an excellent explanation of how the BWT relates to a suffix tree and enables fast read mapping to a genome]
* Here is [https://web.archive.org/web/20221208084304/http://blog.thegrandlocus.com/2016/07/a-tutorial-on-burrows-wheeler-indexing-methods an excellent explanation (now archived) of how the BWT relates to a suffix tree and enables fast read mapping to a genome]
* If you want a more detailed explanation, the [http://www.marcottelab.org/users/BCH394P_364C_2023/BWApaper.pdf BWA paper] more formally describes how the Burrows–Wheeler transform can be used to construct an index.
* If you want a more detailed explanation, the [http://www.marcottelab.org/users/BCH394P_364C_2023/BWApaper.pdf BWA paper] more formally describes how the Burrows–Wheeler transform can be used to construct an index.
Supporting reading:<br>
Supporting reading:<br>
* Two notable advances in genome assembly: [http://www.marcottelab.org/users/BCH394P_364C_2023/StringGraphAssembly.pdf String Graphs] and more recently, [http://www.marcottelab.org/users/BCH394P_364C_2023/MultiplexDeBruijnGraphs.pdf multiplexed De Bruijn graphs].  Both have been used to assemble a [http://www.marcottelab.org/users/BCH394P_364C_2023/CompleteHumanGenomeSequence.pdf fully complete human genome sequence] (check out the [https://www.biorxiv.org/content/biorxiv/early/2021/05/27/2021.05.26.445798/F2.large.jpg?width=800&height=600&carousel=1 beautiful string graph visualizations] of the final assemblies)
* Two notable advances in genome assembly: [http://www.marcottelab.org/users/BCH394P_364C_2023/StringGraphAssembly.pdf String Graphs] and more recently, [http://www.marcottelab.org/users/BCH394P_364C_2023/MultiplexDeBruijnGraphs.pdf multiplexed De Bruijn graphs].  Both have been used to assemble a [http://www.marcottelab.org/users/BCH394P_364C_2023/CompleteHumanGenomeSequence.pdf fully complete human genome sequence] (check out the [https://www.biorxiv.org/content/biorxiv/early/2021/05/27/2021.05.26.445798/F2.large.jpg?width=800&height=600&carousel=1 beautiful string graph visualizations] of the final assemblies, which capture gapless telomere-to-telomere assemblies for all 22
human autosomes and Chromosome X)




'''Feb 21, 2023 - Genome Assembly'''
* Science news of the day: [https://www.cell.com/molecular-cell/fulltext/S1097-2765(23)00075-8 New evidence for very short human ORFs coding for real microproteins & peptides]
* & [https://twitter.com/simocristea/status/1626304239931912192?t=mH-gk3V7PLd7mvyZAgKzRw&s=03 A compilation of advances in the last 2 years on deep learning protein structure prediction]
* Relevant to the last lecture, some definitions of [https://en.wikipedia.org/wiki/Sensitivity_and_specificity sensitivity/specificity] & [https://en.wikipedia.org/wiki/Precision_and_recall precision/recall]. Note that the gene finding community settled early on to a different definition of specificity that corresponds to the precision or PPV in other fields. Other fields define specificity as the true negative rate.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-GenomeAssembly_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/DeBruijnPrimer.pdf DeBruijn Primer] and [http://www.marcottelab.org/users/BCH394P_364C_2023/DeBruijnSupplement.pdf Supplement]


'''Feb 16, 2023 - Genome Assembly'''
 
* A gentle reminder that Problem Set 2 is '''due by 11:59PM Mar 3'''<br>
'''PROBLEM SET #2 ANNOUNCEMENT'''
* Science news of the day: [https://www.mercurynews.com/2023/02/28/uc-berkeley-loses-crispr-gene-editing-patent-case/ UC Berkeley loses core CRISPR patent rights]
* If you would like a few examples of proteins annotated with their transmembrane and soluble regions (according to UniProt) to help troubleshoot your homework, here are some [http://www.marcottelab.org/images/5/5a/Annotated_peptides.txt example yeast protein sequences].
* If you would like a few examples of proteins annotated with their transmembrane and soluble regions (according to UniProt) to help troubleshoot your homework, here are some [http://www.marcottelab.org/images/5/5a/Annotated_peptides.txt example yeast protein sequences].
* From last time, some definitions of [https://en.wikipedia.org/wiki/Sensitivity_and_specificity sensitivity/specificity] & [https://en.wikipedia.org/wiki/Precision_and_recall precision/recall]. Note that the gene finding community settled early on to a different definition of specificity that corresponds to the precision or PPV in other fields. Other fields define specificity as the true negative rate.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-GenomeAssembly_Spring2023.pdf Today's slides]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/DeBruijnPrimer.pdf DeBruijn Primer] and [http://www.marcottelab.org/users/BCH394P_364C_2023/DeBruijnSupplement.pdf Supplement]




'''Feb 14, 2023 - Gene finding II'''
'''Feb 16, 2023 - Gene finding II'''
* [https://research.utexas.edu/cbrs/classes/short-courses/spring-2023-semester/ Short classes at UT] start this week in genome sequencing, proteomics, and bioinformatics
* [https://research.utexas.edu/cbrs/classes/short-courses/spring-2023-semester/ Short classes at UT] start this week in genome sequencing, proteomics, and bioinformatics
* Several of you have asked about programming the Viterbi algorithm for the homework, so I wanted to make sure everyone realized that you are not required to program it. The sequence is short enough that you can solve it in a spreadsheet if that's easier for you.
* Several of you have asked about programming the Viterbi algorithm for the homework, so I wanted to make sure everyone realized that you are not required to program it. The sequence is short enough that you can solve it in a spreadsheet if that's easier for you.
* We're finishing up the slides from last time.
* We're finishing up the slides from last time.
Reading:<br>
Reading:<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/2019StateOfGeneAnnotation.pdf The current state of gene annotation]
* Reposting this so it doesn't fall through the cracks: [http://www.marcottelab.org/users/BCH394P_364C_2023/2019StateOfGeneAnnotation.pdf The current state of gene annotation]
* [https://news.usc.edu/16163/he-s-got-algorithm/ Why do we call it the Viterbi algorithm?]
* [https://news.usc.edu/16163/he-s-got-algorithm/ Why do we call it the Viterbi algorithm?]




'''Feb 9, 2023 - Gene finding'''
'''Feb 14, 2023 - Gene finding'''
* Science news of the day from two years ago: A great connection to HMMs, [http://www.marcottelab.org/users/BCH394P_364C_2023/DeepLearningPfamDomains.pdf using deep learning to annotate the protein universe], just out in Nature Biotech
* Happy Valentine's Day!
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-GeneFinding-Spring2023.pdf Today's slides on gene finding]  
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-GeneFinding-Spring2023.pdf Today's slides on gene finding]  
* A nice commentary on gene finding: [http://www.marcottelab.org/users/BCH394P_364C_2023/2019StateOfGeneAnnotation.pdf Next-generation genome annotation: we still struggle to get it right]
* For a few more examples of HMMs in action, here's a [http://www.marcottelab.org/users/BCH394P_364C_2023/MinionHumanGenome.pdf paper on sequencing the human genome by nanopore], which used HMMs in 3-4 different ways for polishing, contig inspection, repeat analysis and 5-methylcytosine detection.
* For a few more examples of HMMs in action, here's a [http://www.marcottelab.org/users/BCH394P_364C_2023/MinionHumanGenome.pdf paper on sequencing the human genome by nanopore], which used HMMs in 3-4 different ways for polishing, contig inspection, repeat analysis and 5-methylcytosine detection.
* [http://genome.ucsc.edu/cgi-bin/hgTracks?db=hg38&lastVirtModeType=default&lastVirtModeExtraState=&virtModeType=default&virtMode=0&nonVirtPosition=&position=chr11%3A61755389-61788517&hgsid=477602291_ccTRfcOcZIQHnMkBKGzbQLBRc6HL The UCSC genome browser]
* [http://genome.ucsc.edu/cgi-bin/hgTracks?db=hg38&lastVirtModeType=default&lastVirtModeExtraState=&virtModeType=default&virtMode=0&nonVirtPosition=&position=chr11%3A61755389-61788517&hgsid=477602291_ccTRfcOcZIQHnMkBKGzbQLBRc6HL The UCSC genome browser]
* A few useful links about programming: [http://www.marcottelab.org/users/BCH394P_364C_2023/GoodEnoughPracticesInScientificComputing.pdf Recommendations for "good enough" programming habits]
* A few useful links about programming: [http://www.marcottelab.org/users/BCH394P_364C_2023/GoodEnoughPracticesInScientificComputing.pdf Recommendations for "good enough" programming habits] and a great [https://www.youtube.com/playlist?list=PL-osiE80TeTskrapNbzXhwoFUiLCjGgY7 Python beginners Youtube tutorial]
Reading (a couple of old classics + a review + better splice site detection):<br>
Reading (a couple of old classics + a review + better splice site detection):<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EukGeneAnnotation.pdf Eukaryotic gene finding], [http://www.marcottelab.org/users/BCH394P_364C_2023/GeneMark.hmm.pdf GeneMark.hmm], and [http://www.marcottelab.org/users/BCH394P_364C_2023/BurgeKarlin-main.pdf GENSCAN]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/EukGeneAnnotation.pdf Eukaryotic gene finding], [http://www.marcottelab.org/users/BCH394P_364C_2023/GeneMark.hmm.pdf GeneMark.hmm], and [http://www.marcottelab.org/users/BCH394P_364C_2023/BurgeKarlin-main.pdf GENSCAN]
Line 218: Line 220:




'''Feb 7, 2023 - HMMs II'''
'''Feb 9, 2023 - HMMs II'''
'''Problem Set 2, due before midnight Mar. 3, 2023''':<br>
* Science news of the day: [https://doi.org/10.1101/2023.01.24.525373 a fun preprint] illustrating the scale of efforts to identify protein families. This one clustered "19 billion sequences in 18 days on 27 high performance computing nodes, using 250,000 CPU hours in total".  In all, they found 544 million sequence families (clusters) capturing ~94% of all known proteins, giving a sense of the overall size of the universe of proteins.
'''Problem Set 2, due before 10 PM, Feb. 20, 2023''':<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_ProblemSet2_Spring2023.pdf '''Problem Set 2'''].   
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C_ProblemSet2_Spring2023.pdf '''Problem Set 2'''].   
* You'll need these 3 files: [http://www.marcottelab.org/users/BCH394P_364C_2023/state_sequences State sequences], [http://www.marcottelab.org/users/BCH394P_364C_2023/soluble_sequences Soluble sequences], [http://www.marcottelab.org/users/BCH394P_364C_2023/transmembrane_sequences Transmembrane sequences]
* You'll need these 3 files: [http://www.marcottelab.org/users/BCH394P_364C_2023/state_sequences State sequences], [http://www.marcottelab.org/users/BCH394P_364C_2023/soluble_sequences Soluble sequences], [http://www.marcottelab.org/users/BCH394P_364C_2023/transmembrane_sequences Transmembrane sequences]
* Link to [http://setosa.io/blog/2014/07/26/markov-chains/ a great interactive visualization of Markov chains], by Victor Powell & Lewis Lehe. It's worth checking out to build some intuition. They correctly point out that [https://en.wikipedia.org/wiki/PageRank Google's PageRank algorithm] is based on Markov chains. There, the ranking of pages in a web search relates to how random walks across linked web pages spend more time on some pages than on others.
* Link to [http://setosa.io/blog/2014/07/26/markov-chains/ a great interactive visualization of Markov chains], by Victor Powell & Lewis Lehe. It's worth checking out to build some intuition. They correctly point out that [https://en.wikipedia.org/wiki/PageRank Google's PageRank algorithm] is based on Markov chains. There, the ranking of pages in a web search relates to how random walks across linked web pages spend more time on some pages than on others.
* A non-biological example of using log odds ratios & Bayesian stats [https://priceonomics.com/how-statistics-solved-a-175-year-old-mystery-about/ to learn the authors of the Federalist Papers]
* A non-biological example of using log odds ratios & Bayesian stats [https://priceonomics.com/how-statistics-solved-a-175-year-old-mystery-about/ to learn the authors of the Federalist Papers]. In a related example, [https://arstechnica.com/science/2023/02/lost-and-found-code-breakers-decipher-50-letters-of-mary-queen-of-scots/ researchers just decoded >50 coded letters from a French archive] and discovered they were lost correspondence from Mary, Queen of Scots, before she was executed in 1587 for treason against Elizabeth I.  The researchers used an approach closely related to computing log odds ratios of 5-mer frequencies between putative decoded texts and known free text to figure out the correct ciphers. If you're curious, you can read about it in [https://www.tandfonline.com/doi/full/10.1080/01611194.2022.2160677 Appendix A of their paper]




'''Feb 7, 2023 - Hidden Markov Models'''
'''Feb 7, 2023 - Hidden Markov Models'''
* Happy Class-After-Valentine's Day!
* Don't forget: Rosalind Homework #2 (worth 10% of your final course grade) is '''due by 10 PM February 8'''.  Note: choose one of the two protein translation problems and see the update below on the IUPAC code example.
* Don't forget: Rosalind Homework #2 (worth 10% of your final course grade) is due '''by 11:59PM February 16'''.
* More stats for comp biologists worth checking out:  [https://www.huber.embl.de/msmb/ Modern Statistic for Modern Biology], by Susan Holmes and Wolfgang Huber. It's currently available online and [https://www.amazon.com/Modern-Statistics-Biology-Susan-Holmes/dp/1108705294/ available on dead tree]. (FYI, all code is in R.)
* More stats for comp biologists worth checking out:  [https://www.huber.embl.de/msmb/ Modern Statistic for Modern Biology], by Susan Holmes and Wolfgang Huber. It's currently available online and [https://www.amazon.com/Modern-Statistics-Biology-Susan-Holmes/dp/1108705294/ available on dead tree]. (FYI, all code is in R.)
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-HMMs-Spring2023.pdf Today's slides]<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-HMMs-Spring2023.pdf Today's slides]<br>
Line 236: Line 238:




'''Feb 2, 2023 - GUEST LECTURE'''
'''ROSALIND ANNOUNCEMENT'''
* It looks like a number of people are struggling with the Rosalind problem titled ''Protein Translation''.  As an alternative option, I've assigned a problem titled ''Translating RNA into Protein''. Choose one; you'll get credit regardless of which of them you do.  Also, it looks like the problem titled "Complementing a Strand of DNA" uses a now out-of-date call for IUPAC codes in the Programming Shortcut.  Just delete the "from Bio.Alphabet import IUPAC" line & delete the ", IUPAC.unambiguous_dna" portion of the Seq() functions and it should work fine.
 
 
'''Feb 2, 2023 - We'll have a guest lecture from your TA Matt McGuffie on advancing your Python data analysis skills'''
* '''WEATHER WARNING #2: Change of plans!''' UT has now officially canceled in-person classes, but more to the point, >100,000 people have lost power in Austin today. We're going to cancel the live zoom class tomorrow, and Matt will instead record the lecture and upload it to Canvas for viewing.
* Matt is an expert in the bioinformatic analyses of plasmid sequences and developed the popular [http://plannotate.barricklab.org/ pLannotate tool] to annotate and visualize plasmid features, based on a large database of genetic parts and protein sequences. Funny enough, he first described an early version of pLannotate as his project for this class back in 2019. He'll be introducing several useful Python libraries, including the Pandas package for handling large tables and a data visualization library for plotting data.




'''Jan 31, 2023 - Biological databases'''
'''Jan 31, 2023 - Biological databases'''
* Homework #2 (worth 10% of your final course grade) has been assigned on Rosalind and is '''due by 10 PM February 8'''. Note that several questions will use BioPython (see the "programming shortcuts" at the bottom of several questions). If you need to install this Python library on your computer, you can open Anaconda prompt (on a PC) or launch a console window from the Anaconda Navigator & type "pip install biopython". (You can use this approach to install most Python libraries.)
* WEATHER WARNING: UT just announced a campus closure for the morning, so for those of you that are able to attend online, I'll plan to hold it at the normal time on the class zoom channel (link available on Canvas). However, for those that can't make it, don't stress! We'll record the lecture and post the video to Canvas so that you can watch it later. Note: the next Rosalind homework is assigned below.
* Science news of the day: [https://www.biorxiv.org/content/10.1101/2022.01.28.478251v1 Reanimated 46,000-year-old nematodes!]
* Science news of the day: [https://www.theguardian.com/science/2023/jan/26/science-journals-ban-listing-of-chatgpt-as-co-author-on-papers Cell, Nature, Science, eLife, and the Lancet ban listing ChatGPT as a co-author]
* Just a note that we'll be seeing ever more statistics as go on. Here's a [http://www.marcottelab.org/users/BCH394P_364C_2023/StatisticsPrimer.pdf good primer] from [http://www.bio.utexas.edu/research/meyers/LaurenM/index.html Prof. Lauren Ancel Myers] (who leads the [https://covid-19.tacc.utexas.edu/ UT Austin COVID-19 Modeling Consortium]) to refresh/explain basic concepts.
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-BiologicalDatabases-Spring2023.pdf Today's slides]<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-BiologicalDatabases-Spring2023.pdf Today's slides]<br>
Homework #2 (worth 10% of your final course grade) has been assigned on Rosalind and is '''due by 10 PM February 8''':
* Besides giving a bit more programming experience, these questions will also introduce you to the [https://biopython.org/ BioPython] Python library (see the "programming shortcuts" at the bottom of several questions). If you need to install BioPython on your computer, open an Anaconda prompt window (on a PC) or launch a console window from the Anaconda Navigator & type "pip install biopython".  (You can use this approach to install most Python libraries.) There's a very useful tutorial [http://biopython.org/DIST/docs/tutorial/Tutorial.html here] (also downloadable as a [http://biopython.org/DIST/docs/tutorial/Tutorial.pdf pdf file])
Extra reading/classes:<br>
* Just a note that we'll be seeing ever more statistics as go on. Here's a [http://www.marcottelab.org/users/BCH394P_364C_2023/StatisticsPrimer.pdf good primer] from [https://stat.utexas.edu/people/lauren-ancel-meyers Prof. Lauren Ancel Myers] (who leads the [https://covid-19.tacc.utexas.edu/ UT Austin COVID-19 Modeling Consortium]) to refresh/explain basic concepts.
* Finally, here's great opportunity to hone your Python skills a bit more: The UT CBRS cores will offer [https://research.utexas.edu/cbrs/classes/short-courses/spring-2023-semester/ short courses] in Python, Unix, and Python for Data Sciences starting in March.


-->
'''Jan 26, 2023 - BLAST'''
'''Jan 26, 2023 - BLAST'''
<!--* Science news of the day: There are still lots of fundamental discoveries to be made using sequence alignment, [http://www.marcottelab.org/users/BCH394P_364C_2023/s41586-021-04332-2.pdf e.g. using peta-scale sequence alignment to discovery >10^5 new RNA viruses]. Plus, fodder for your end-of-class projects: "we deposited 7.3 terabytes of virus alignments and assemblies into an open-access database that can be explored via a graphical web interface." -->
<!--* Science news of the day: There are still lots of fundamental discoveries to be made using sequence alignment, [http://www.marcottelab.org/users/BCH394P_364C_2023/s41586-021-04332-2.pdf e.g. using peta-scale sequence alignment to discovery >10^5 new RNA viruses]. Plus, fodder for your end-of-class projects: "we deposited 7.3 terabytes of virus alignments and assemblies into an open-access database that can be explored via a graphical web interface." -->
Line 280: Line 292:




'''Jan 17, 2023 - Intro to Python #2'''
'''Jan 17, 2023 - Intro to Python II'''
* Reminder that today will be part 2 of the "Python boot camp" for those of you with little to no previous Python coding experience. We'll be finishing the slides from last time, plus Rosalind help & programming Q/A.
* Reminder that today will be part 2 of the "Python boot camp" for those of you with little to no previous Python coding experience. We'll be finishing the slides from last time, plus Rosalind help & programming Q/A.
* *** Rosalind assignments are '''due by 10 PM January 18'''.  ***
* *** Rosalind assignments are '''due by 10 PM January 18'''.  ***
Line 291: Line 303:
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-PythonPrimer-Spring2023.pdf Today's slides].  Remember that today and the next lecture are dedicated to the Python Boot Camp to start getting those of you with minimal coding skills up to speed on the basics. Advanced programmers can skip class!<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/BCH394P-364C-PythonPrimer-Spring2023.pdf Today's slides].  Remember that today and the next lecture are dedicated to the Python Boot Camp to start getting those of you with minimal coding skills up to speed on the basics. Advanced programmers can skip class!<br>
* [http://www.marcottelab.org/users/BCH394P_364C_2023/Ecoli_genome.txt E. coli genome]
* [http://www.marcottelab.org/users/BCH394P_364C_2023/Ecoli_genome.txt E. coli genome]
* Don't forget that the Rosalind assignments are due by 10 PM January 18. Please do start if you haven't already, or you won't have time to get help if you have any issues installing Python.  
* Don't forget that the '''Rosalind assignments are due by 10 PM January 18'''. Please do start if you haven't already, or you won't have time to get help if you have any issues installing Python.  
* Python 2 vs 3? Bioinformatics researchers [http://astrofrog.github.io/blog/2015/05/09/2015-survey-results/ held out for 2 until quite recently], but [https://careerkarma.com/blog/python-2-vs-python-3/ the shift to 3 is pretty clear now]. We'll use Python 3 (the latest version in Anaconda is 3.9, but any recent version will be fine), but Rosalind and some materials are only available in Python 2.7, so we'll generally try to be version agnostic for compatibility. Use whichever you wish, but be aware that support for Python 2.7 has officially been stopped. For beginners, the [http://www.practicepython.org/blog/2017/02/09/python2-and-3.html differences are quite minimal] and are [https://www.guru99.com/python-2-vs-python-3.html summarized in a table here].  There's also a great [https://python-future.org/compatible_idioms.html cheat sheet here] for writing code compatible with both versions.
* Python 2 vs 3? We'll exclusively use Python 3 (any recent version will be fine). Some legacy materials, notably for us Rosalind, are only available in Python 2.7, so we'll generally try to be version-agnostic for compatibility. For beginners, the [http://www.practicepython.org/blog/2017/02/09/python2-and-3.html differences are quite minimal] and are [https://www.guru99.com/python-2-vs-python-3.html summarized in a table here].  There's also a great [https://python-future.org/compatible_idioms.html cheat sheet here] for writing code compatible with both versions.




Line 300: Line 312:
Here are some online Python resources that you might find useful:
Here are some online Python resources that you might find useful:
* First and foremost, and very, very useful if you're a complete Python newbie:  Eric Matthes's [https://nostarch.com/pythoncrashcourse2e Python Crash Course book]. He made some GREAT, free [https://github.com/ehmatthes/pcc/releases/download/v1.0.0/beginners_python_cheat_sheet_pcc_all.pdf Python command cheat sheets] to support the book.
* First and foremost, and very, very useful if you're a complete Python newbie:  Eric Matthes's [https://nostarch.com/pythoncrashcourse2e Python Crash Course book]. He made some GREAT, free [https://github.com/ehmatthes/pcc/releases/download/v1.0.0/beginners_python_cheat_sheet_pcc_all.pdf Python command cheat sheets] to support the book.
* [https://learnxinyminutes.com/docs/python/ Learn Python in Y Minutes] is a great resource for examples of syntax and concepts
* [https://dabeaz-course.github.io/practical-python/ Practical Python], worth checking out!
* [https://dabeaz-course.github.io/practical-python/ Practical Python], worth checking out!
* If you have any basic experience at all in other programming languages, Google offered an extremely good, 2 day intro course to Python (albeit version 2) that is now [https://www.youtube.com/playlist?list=PLC8825D0450647509 available on Youtube].
* If you have any basic experience at all in other programming languages, Google offered an extremely good, 2 day intro course to Python (albeit version 2) that is now [https://www.youtube.com/playlist?list=PLC8825D0450647509 available on Youtube].
Line 341: Line 354:
* How to make a web site for the final project  
* How to make a web site for the final project  
** Google Site: https://sites.google.com/new
** Google Site: https://sites.google.com/new
** You might also consider [https://streamlit.io/ streamlit], which lets you generate web sites on the fly direct from Python


* [http://abstrusegoose.com/strips/ars_longa_vita_brevis.PNG Why we don't teach C++]
* [http://abstrusegoose.com/strips/ars_longa_vita_brevis.PNG Why we don't teach C++]

Latest revision as of 11:11, 5 January 2024

BCH394P/BCH364C Systems Biology & Bioinformatics

Course unique #: 55425/55330
Lectures: Tues/Thurs 11 – 12:30 PM WEL 2.110
Instructor: Edward Marcotte, marcotte @ utexas.edu

  • Office hours: Mon 4 – 5 PM on the class Zoom channel (available on Canvas)

TA: Matt McGuffie, mmcguffie @ utexas.edu

  • TA Office hours: Wed 1 - 2 PM / Thu 12:30 - 1:30 in MBB 1.448BA or by appointment on Zoom

Class Canvas site: https://utexas.instructure.com/courses/1352289

Lectures & Handouts

April 11, 2023 - Synthetic Biology, highly compressed

  • Reminder: All projects are due by 10PM, April 12. Turn them in as a URL to the web site you created, sent by email to the TA AND PROFESSOR.
  • Today's slides

A collection of further reading, if you're so inclined:

Food for thought


April 6, 2023 - Orthologs and Phenologs

  • Remember: The final project web page is due by 10PM April 12, 2023, turned in as a URL emailed to the TA+Professor. Please indicate in the email if you are willing to let us post the project to the course web site. Also, note that late days can't be used for the final project
  • Today's slides
  • Phenologs and the drug discovery story we'll discuss in class. This is a fun example of the power of opportunistic data mining aka "research parasitism" in biomedical research.
  • Search for phenologs here. You can get started by rediscovering the plant model of Waardenburg syndrome. Search among the known diseases for "Waardenburg", or enter the human genes linked to Waardenburg (Entrez gene IDs 4286, 5077, 6591, 7299) to get a feel for how this works.

Tools for finding orthologs:

  • One good tool for discovering orthologs is InParanoid. Note: InParanoid annotation lags a bit, so you'll need to find the Ensembl protein id, or try a text search for the common name. Or, just link there from Uniprot. InParanoid tends towards higher recall, lower precision for finding orthologs. Approaches with higher precision include OMA (introduced in this paper), PhylomeDB, and EggNOG. The various algorithms basically have different trade-offs with regard to precision vs recall, and ease of use. For example, we use EggNOG in the lab for annotating genes in new genomes/transcriptomes because the EggNOG HMM ortholog models are easily downloadable/re-run on any set of genes you happen to be interested in.
  • All (well, at least some) of your ortholog definition questions answered!


Apr 4, 2023 - Networks

  • Today's slides
  • Metabolic networks: The wall chart (it's interactive. For example, can you find enolase?), the human metabolic reaction network, a review of mapping transcriptional networks by Chip-SEQ (with the current record holder in this regard probably held by ENCODE), and a review of protein interaction mapping in humans and how it is informing disease genetics.
  • Useful gene network resources include:
    • Reactome), which we've seen before, links human genes according to reactions and pathways, and also calculated functional linkages from various high-throughput data.
    • HumanNet (older versions for other organisms at netbiolab.org and FunctionalNet), which provides interactive searches of a human functional gene network. The earlier versions helped my own group find genes for a wide variety of biological processes.
    • STRING is available for many organisms, including large numbers of prokaryotes. Try searching on the E. coli enolase (Eno) as an example.
    • GeneMania, which aggregates many individual gene networks.
    • The best interactive tool for network visualization is Cytoscape. You can download and install it locally on your computer, then visualize and annotated any gene network, such as are output by the network tools linked above. There is also a web-based network viewer that can be incorporated into your own pages (e.g., as used in YeastNet). Here's an example file to visualize, the human protein complex map from Hu.MAP2.
    • Clustering algorithms can be applied to networks. For example, we frequently use the Walktrap algorithm developed by Pascal Pons and Matthieu Latapy, which is available in the Python iGraph library. Here's a nice blog demonstration using it.

Reading:


Mar 30, 2023 - Principal Component Analysis (& the curious case of European genotypes)

A smattering of links on PCA:


Mar 28, 2023 - Classifiers


Mar 23, 2023 - Proteomics

  • Guest speaker: Dr. Peter Faull, who earned his Ph.D. at the University of Edinburgh and subsequently served as Head of Proteomics at the MRC UK Clinical Sciences Centre and as a senior lab research scientist at the Francis Crick Institute in London before joining us at UT, where he now serves as Principal Proteomics Scientist in the UT Biological Mass Spectrometry core.


Mar 21, 2023 - 3D Protein Structure Modeling

  • Reminder: Your project topic is due today, and Problem Set #3 is due tomorrow.
  • Guest speaker: Prof. Y. Jessie Zhang, an expert on RNA polymerase, its post-translational modifications, and their effects on eukaryotic transcription. She combines experimental structure determination by X-ray crystallography with computational structure prediction using techniques like AlphaFold, and will talk about protein 3D structure modeling and prediction.
  • 3D macromolecular structural modeling software: UCSF ChimeraX, the Rosetta software suite, and an overview of what it can do for you, and last but not least: AlphaFold predicted structures and the AlphaFold colab where you can run your own structure predictions.
  • & a few other useful 3D structure tools: The Protein Data Bank, MODELLER, and Pymol


Mar 20, 2023 - Apologies, no office hours today. Feel free to reach out by email or attend the TA office hours this week.


Mar 14,16, 2023 - SPRING BREAK

  • Don't forget to turn in the proposal for your course project by March 21st and finish HW3 by March 22nd.


Mar 9, 2023 - Clustering II

  • We'll be continuing the slides from last time
  • I'm also posting the next (last) problem set:

Problem Set 3, due before 10PM Mar. 22, 2023. You will need the following software and datasets:

Reading:


Mar 7, 2023 - Functional Genomics & Data Mining - Clustering I

  • Due March 21 by email to the TA+Instructor - One to two (full) paragraphs describing your plans for a final project, along with the names of your collaborators. Please limit to no more than 3 per group, please. It's also fine to do this independently, if you prefer. (Do you have a particular skill/interest/exciting dataset you need help analyzing? There is a class_projects channel on the slack where you can ask around for partners.) This assignment (planning out your project) will account for 5 points out of your 25 total points for your course project. Here are a few examples of final projects from previous years: 1 2 3 4 5 6 7 8 9 10 11 12 13 14
  • Science news of the day: The genome of Antarctic krill (the crustacean E. superba) has been sequenced and is crazy. It's 48 Gb in size, so 15x the human genome (!), one of the largest genomes ever assembled. And >92% of that is repetitive DNA. Solved with a combination of short and long read DNA sequencing.
  • Today's slides

Reading:


Mar 2, 2023 - Motifs


Feb 28, 2023 - NGS analysis best practices

  • Homework #3 (worth 10% of your final course grade) has been assigned on Rosalind and is due by 10:00PM March 9. In past years, we've run into problems with Rosalind timing out before Meme completes although it usually runs eventually, so be warned you may have to try it a couple of times. Meme also runs faster using the "zero to one" or "one" occurrence per sequence option, rather than the "any number of repeats" option.
  • Guest speaker: Anna Battenhouse from the Center for Biomedical Research Support, where she maintains the Biomedical Research Computing Facility.
  • Today's slides


Feb 23, 2023 - Genome Assembly/Mapping II

Supporting reading:

human autosomes and Chromosome X)


Feb 21, 2023 - Genome Assembly


PROBLEM SET #2 ANNOUNCEMENT

  • If you would like a few examples of proteins annotated with their transmembrane and soluble regions (according to UniProt) to help troubleshoot your homework, here are some example yeast protein sequences.


Feb 16, 2023 - Gene finding II

  • Short classes at UT start this week in genome sequencing, proteomics, and bioinformatics
  • Several of you have asked about programming the Viterbi algorithm for the homework, so I wanted to make sure everyone realized that you are not required to program it. The sequence is short enough that you can solve it in a spreadsheet if that's easier for you.
  • We're finishing up the slides from last time.

Reading:


Feb 14, 2023 - Gene finding

Reading (a couple of old classics + a review + better splice site detection):


Feb 9, 2023 - HMMs II

  • Science news of the day: a fun preprint illustrating the scale of efforts to identify protein families. This one clustered "19 billion sequences in 18 days on 27 high performance computing nodes, using 250,000 CPU hours in total". In all, they found 544 million sequence families (clusters) capturing ~94% of all known proteins, giving a sense of the overall size of the universe of proteins.

Problem Set 2, due before 10 PM, Feb. 20, 2023:


Feb 7, 2023 - Hidden Markov Models

  • Don't forget: Rosalind Homework #2 (worth 10% of your final course grade) is due by 10 PM February 8. Note: choose one of the two protein translation problems and see the update below on the IUPAC code example.
  • More stats for comp biologists worth checking out: Modern Statistic for Modern Biology, by Susan Holmes and Wolfgang Huber. It's currently available online and available on dead tree. (FYI, all code is in R.)
  • Today's slides

Reading:


ROSALIND ANNOUNCEMENT

  • It looks like a number of people are struggling with the Rosalind problem titled Protein Translation. As an alternative option, I've assigned a problem titled Translating RNA into Protein. Choose one; you'll get credit regardless of which of them you do. Also, it looks like the problem titled "Complementing a Strand of DNA" uses a now out-of-date call for IUPAC codes in the Programming Shortcut. Just delete the "from Bio.Alphabet import IUPAC" line & delete the ", IUPAC.unambiguous_dna" portion of the Seq() functions and it should work fine.


Feb 2, 2023 - We'll have a guest lecture from your TA Matt McGuffie on advancing your Python data analysis skills

  • WEATHER WARNING #2: Change of plans! UT has now officially canceled in-person classes, but more to the point, >100,000 people have lost power in Austin today. We're going to cancel the live zoom class tomorrow, and Matt will instead record the lecture and upload it to Canvas for viewing.
  • Matt is an expert in the bioinformatic analyses of plasmid sequences and developed the popular pLannotate tool to annotate and visualize plasmid features, based on a large database of genetic parts and protein sequences. Funny enough, he first described an early version of pLannotate as his project for this class back in 2019. He'll be introducing several useful Python libraries, including the Pandas package for handling large tables and a data visualization library for plotting data.


Jan 31, 2023 - Biological databases

  • WEATHER WARNING: UT just announced a campus closure for the morning, so for those of you that are able to attend online, I'll plan to hold it at the normal time on the class zoom channel (link available on Canvas). However, for those that can't make it, don't stress! We'll record the lecture and post the video to Canvas so that you can watch it later. Note: the next Rosalind homework is assigned below.
  • Science news of the day: Cell, Nature, Science, eLife, and the Lancet ban listing ChatGPT as a co-author
  • Today's slides

Homework #2 (worth 10% of your final course grade) has been assigned on Rosalind and is due by 10 PM February 8:

  • Besides giving a bit more programming experience, these questions will also introduce you to the BioPython Python library (see the "programming shortcuts" at the bottom of several questions). If you need to install BioPython on your computer, open an Anaconda prompt window (on a PC) or launch a console window from the Anaconda Navigator & type "pip install biopython". (You can use this approach to install most Python libraries.) There's a very useful tutorial here (also downloadable as a pdf file)

Extra reading/classes:


Jan 26, 2023 - BLAST


Jan 24, 2023 - Sequence Alignment II


Jan 19, 2023 - Sequence Alignment I

  • Science news of the day, relevant to our discussion of ChatGPT last class: CNET & other news sources used it to write articles; this Gizmodo story reports that "the AI-program fabricates information and bungles facts like nobody’s business" and CNET "has been forced to issue multiple, major corrections". So, if you do opt to try ChatGPT to help with Python, be sure to check (and then double-check) everything.
  • Today's slides

Problem Set I, due 10PM Jan. 30, 2023:

  • Problem Set 1
  • H. influenzae genome. Haemophilus influenza was the first free living organism to have its genome sequenced. NOTE: there are some additional characters in this file from ambiguous sequence calls. For simplicity's sake, when calculating your nucleotide and dinucleotide frequencies, you can just ignore anything other than A, C, T, and G.
  • T. aquaticus genome. Thermus aquaticus helped spawn the genomic revolution as the source of heat-stable Taq polymerase for PCR.
  • 3 mystery genes (for Problem 5): MysteryGene1, MysteryGene2, MysteryGene3
  • *** HEADS UP FOR THE PROBLEM SET *** If you try to use the Python string.count function to count dinucleotides, Python counts non-overlapping instances, not overlapping instances. So, AAAA is counted as 2, not 3, dinucleotides. You want overlapping dinucleotides instead, so will have to try something else, such as the python string[counter:counter+2] command, as explained in the Rosalind homework assignment on strings.

Extra reading, if you're curious:


Jan 17, 2023 - Intro to Python II

  • Reminder that today will be part 2 of the "Python boot camp" for those of you with little to no previous Python coding experience. We'll be finishing the slides from last time, plus Rosalind help & programming Q/A.
  • *** Rosalind assignments are due by 10 PM January 18. ***
  • We'll talk a bit about ChatGPT today for co-programming
  • Another strong recommendation (really) to the Python newbies to download Eric Matthes's GREAT, free Python command cheat sheets that he provides to accompany his Python Crash Course book.


Jan 12, 2023 - Intro to Python

  • STANDARD REMINDER: My email inbox is always fairly backlogged (e.g., my median time between non-spam emails was 11 minutes when I measured it some time ago, and it's gotten much worse since then), so please copy the TA on all emails to help us make sure they get taken care of.
  • Today's slides. Remember that today and the next lecture are dedicated to the Python Boot Camp to start getting those of you with minimal coding skills up to speed on the basics. Advanced programmers can skip class!
  • E. coli genome
  • Don't forget that the Rosalind assignments are due by 10 PM January 18. Please do start if you haven't already, or you won't have time to get help if you have any issues installing Python.
  • Python 2 vs 3? We'll exclusively use Python 3 (any recent version will be fine). Some legacy materials, notably for us Rosalind, are only available in Python 2.7, so we'll generally try to be version-agnostic for compatibility. For beginners, the differences are quite minimal and are summarized in a table here. There's also a great cheat sheet here for writing code compatible with both versions.


Jan 10, 2023 - Introduction

  • Today's slides
  • We'll be conducting homework using the online environment Rosalind. Go ahead and register on the site, and enroll specifically for BCH394P/364C (Spring 2023) Systems Biology/Bioinformatics using this link. Homework #1 (worth 10% of your final course grade) has already been assigned on Rosalind and is due by 10:00PM January 18.

Here are some online Python resources that you might find useful:

  • First and foremost, and very, very useful if you're a complete Python newbie: Eric Matthes's Python Crash Course book. He made some GREAT, free Python command cheat sheets to support the book.
  • Learn Python in Y Minutes is a great resource for examples of syntax and concepts
  • Practical Python, worth checking out!
  • If you have any basic experience at all in other programming languages, Google offered an extremely good, 2 day intro course to Python (albeit version 2) that is now available on Youtube.
  • Khan Academy has archived their older intro videos on Python here (again, version 2)

Syllabus & course outline

Course syllabus

An introduction to systems biology and bioinformatics, emphasizing quantitative analysis of high-throughput biological data, and covering typical data, data analysis, and computer algorithms. Topics will include introductory probability and statistics, basics of Python programming, protein and nucleic acid sequence analysis, genome sequencing and assembly, proteomics, synthetic biology, analysis of large-scale gene expression data, data clustering, biological pattern recognition, and gene and protein networks.

Open to graduate students and upper division undergrads (with permission) in natural sciences and engineering. Prerequisites: Basic familiarity with molecular biology, statistics & computing, but realistically, it is expected that students will have extremely varied backgrounds. Undergraduates have additional prerequisites, as listed in the catalog.

Note that this is not a course on practical sequence analysis or using web-based tools. Although we will use a number of these to help illustrate points, the focus of the course will be on learning the underlying algorithms, exploratory data analyses, and their applications, esp. in high-throughput biology. By the end of the course, students will know the fundamentals of important algorithms in bioinformatics and systems biology, will be able to design and implement computational studies in biology, and will have performed an element of original computational biology research.

Most of the lectures will be from research articles and slides posted online, with some material from the...
Optional text (for sequence analysis): Biological sequence analysis, by R. Durbin, S. Eddy, A. Krogh, G. Mitchison (Cambridge University Press),

For biologists rusty on their stats, The Cartoon Guide to Statistics (Gonick/Smith) is very good. A reasonable online resource for beginners is Statistics Done Wrong.

Some online references:
An online bioinformatics course
Online probability & stats texts: #1, #2 (which has some lovely visualizations)

No exams will be given. Grades will be based on online homework (counting 30% of the grade), 3 problem sets (given every 2-3 weeks and counting 15% each towards the final grade) and an independent course project (25% of final grade), which can be collaborative (1-3 students/project). The course project will consist of a research project on a bioinformatics topic chosen by the student (with approval by the instructor) containing an element of independent computational biology research (e.g. calculation, programming, database analysis, etc.). This will be turned in as a link to a web page. The final project is due by 10 PM, April 12, 2023. The last 3 classes will be spent presenting your projects to each other. (The presentation will account for 5/25 points of the project grade.)

If at some point, we have to go into coronavirus lockdown, that portion of the class will be web-based. We will hold lectures by Zoom during the normally scheduled class time. Log in to the UT Canvas class page for the link, or, if you are auditing, email the TA and we will send the link by return email. Slides will be posted before class so you can follow along with the material. We'll record the lectures & post the recordings afterward on Canvas so any of you who might be in other time zones or otherwise be unable to make class will have the opportunity to watch them. Note that the recordings will only be available on Canvas and are reserved only for students in this class for educational purposes and are protected under FERPA. The recordings should not be shared outside the class in any form. Violation of this restriction could lead to Student Misconduct proceedings.

Online homework will be assigned and evaluated using the free bioinformatics web resource Rosalind.

All projects and homework will be turned in electronically and time-stamped. No makeup work will be given. Instead, all students have 5 days of free “late time” (for the entire semester, NOT per project, and counting weekends/holidays). For projects turned in late, days will be deducted from the 5 day total (or what remains of it) by the number of days late (in 1 day increments, rounding up, i.e. 10 minutes late = 1 day deducted). Once the full 5 days have been used up, assignments will be penalized 10 percent per day late (rounding up), i.e., a 50 point assignment turned in 1.5 days late would be penalized 20%, or 10 points.

Homework, problem sets, and the project total to a possible 100 points. There will be no curving of grades, nor will grades be rounded up. We’ll use the plus/minus grading system, so: A= 92 and above, A-=90 to 91.99, etc. Just for clarity's sake, here are the cutoffs for the grades: 92% = A, 90% = A- < 92%, 88% = B+ < 90%, 82% = B < 88%, 80% = B- < 82%, 78% = C+ < 80%, 72% = C < 78%, 70% = C- < 72%, 68% = D+ < 70%, 62% = D < 68%, 60% = D- < 62%, F < 60%.

Students are welcome to discuss ideas and problems with each other, but all programs, Rosalind homework, problem sets, and written solutions should be performed independently (except the final collaborative project). Students are expected to follow the UT honor code. Cheating, plagiarism, copying, & reuse of prior homework, projects, or programs from CourseHero, Github, or any other sources are all strictly forbidden and constitute breaches of academic integrity and cause for dismissal with a failing grade, possibly expulsion (UT's academic integrity policy). In particular, no materials used in this class, including, but not limited to, lecture hand-outs, videos, assessments (papers, projects, homework assignments), in-class materials, review sheets, and additional problem sets, may be shared online or with anyone outside of the class unless you have the instructor’s explicit, written permission. Any materials found online (e.g. in CourseHero) that are associated with you, or any suspected unauthorized sharing of materials, will be reported to Student Conduct and Academic Integrity in the Office of the Dean of Students. These reports can result in sanctions, including failure in the course.

The final project web site is due by 10 PM April 12, 2023.

  • How to make a web site for the final project