Course Syllabus
Computers have revolutionized modern biological research, by providing biologists with the means to manage and analyze the large amounts of data generated through high-throughput experiments. This course provides a practical introduction to the main algorithms, databases, and tools used in bioinformatics, at the same time providing insight into the biological problems being addressed.
Many of the techniques you learn in this course are applicable beyond the bioinformatics domain and are relevant to other data-driven fields of computer science.
No knowledge of biology is required for this course.
IMPORTANT:
1. Before you buy the book look carefully below as it may save you money.
Logistics
Instructors: Mihai Pop
Links to an external site. (mpop@umiacs.umd.edu), Mahfuza Sharmin (msharmin@umiacs.umd.edu)
Instructor office: Biomolecular Sciences Building, Room 3120F; or AVW 3223 (by appointment only)
Instructor office hours:
Monday 3:30-4:30pm by Mahfuza in AVW 3223
Friday 10-11am by Mihai in AVW 3223
TA: Alejandro Flores V. (alejandroflores.af@gmail.com)
TA office hours: Friday 2-4pm in AVW 4101 (or 4103 depending on availability of space)
Class Location: CSIC 1122
Class Days/time: Tue/Thu 12:30-1:45 pm
Textbook:
IMPORTANT - if you buy the book from the link below you can get a discount when buying the two volumes. This may not be true at the campus bookstore.
http://bioinformaticsalgorithms.com/ Links to an external site. - both volumes required!!
Also available at University Bookstore - http://umcp.bncollege.com Links to an external site.)
Learning outcomes
- Translate a biological problem into an algorithm and a software implementation
- Learn algorithmic strategies for processing strings of letters (also relevant beyond computational biology)
- Learn about biomedical questions of current relevance
- Learn to work in teams
Resources
See: Resource page Links to an external site.
Grading (see below for details)
- Quizzes/in class participation - 10%
- In-class teamwork - 5%
- Programming projects - 25%
- Two in-class midterms - 30% (15% each)
- In-class final - 30%
Late policy
You can submit up to 2 programming assignments up to 2 days late without any penalty. All other programming assignments received late will incur a 10% penalty for up to 2 days, after which no credit will be given.
For all other assignments (reading quizzes, exit tickets, etc.) no late submissions are allowed. Instead, the lowest 5 scores will be discounted when computing your grade.
Attendance policy
Please notify me in advance if you will miss any exam due to a University sanctioned excuse (medical absence, religious observance, etc.). In case of sudden illness that causes you to miss an exam you must provide me with a medical note documenting the illness, and clearly specifying the days/times that you were incapacitated due to illness.
Part of the class grade is participation/quizzes. Reasonable absences will be accommodated when grading - please inform me in advance if you will miss a class. Please see here: https://faculty.umd.edu/teach/attend_student.html Links to an external site. and below for further details.
Religious observances
You must notify me within 2 weeks from the beginning of class if you will miss a class or exam due to a religious observance. Requests received after two weeks will not be accommodated. Please check university policies from the following 2 links.
https://faculty.umd.edu/teach/attend_change.html Links to an external site.
Accommodations for disabilities
You must notify me within 2 weeks from the beginning of class if you require special accommodations due to disabilities. All such requests must be accompanied by documentation from DSS Links to an external site.. Requests received after this deadline will not be accommodated.
Communication is key
Please participate in Piazza discussions, interact with your colleagues, and contact the instructors and the TA if you have questions or concerns.
For general questions about class materials and discussion use Piazza.
To contact the instructors and TA directly, please use ELMS rather than our individual emails. This ensures that all emails are recorded and associated with the course, and also that no emails get lost in spam folders or the general email deluge that we are often faced with.
Academic honesty
Simply put: cheating will not be tolerated under any circumstance. While you are allowed to prepare for assignments together, you must complete all individual assignments by yourselves. Also, all exams are strictly individual.
In particular, the code you submit to Rosalind must be your own. We will run plagiarism detection software, and we are well aware of the various code floating around github and other online forums.
Quizzes
Prior to each class you will have to complete a quiz that tests that you have prepared for the class (read material, watched videos, etc.) These quizzes will not test that you fully understand the material, just that you have done your due diligence in preparing. I anticipate there will be about 20 such quizzes.
Class participation
During the class I will call on random students to encourage everyone to participate, not just those who sit in front. Most often I will give you some time to think and discuss with your team before I pick on you - i.e., I'm not going to try to trip you up with questions for which you cannot possibly know the answer. I will, however, record whether the answer was satisfactory - not necessarily correct, but demonstrating that you were paying attention and participating. These records will be taken into account when I decide the final grade in the class.
Class participation - team assignments
I will assign you to teams of 4-5 students based on your responses to an initial class survey. The members of each team will be responsible for helping each other learn, and also for working together during in-class exercises. Each team will be randomly called upon during class - the credit received will depend on satisfactory performance in these assignments. Note that points will not be distributed evenly to all team members, rather they will be decided by three team peer-assessments, submitted at the time of the two midterms and at the end of the class.
Illness/emergency preparedness
See http://www.umd.edu/emergencypreparedness Links to an external site. for more information.
If you are sick, don't come to class - no need to get others sick.
Please report sickness on http://grades.cs.umd.edu
Links to an external site. and through ELMS to the instructors.
Course Summary:
Date | Details | Due |
---|---|---|
Tue Aug 30, 2016 | Calendar Event Introduction to class | 12:30pm to 1:45pm |
Wed Aug 31, 2016 | Assignment Reading: introduction to biology | due by 11:59pm |
Thu Sep 1, 2016 | Quiz Reading quiz: Introduction to biological sequences | due by 10am |
Calendar Event Introduction to Biology | 12:30pm to 1:45pm | |
Tue Sep 6, 2016 | Calendar Event Exact Matching | 12:30pm to 1:45pm |
Calendar Event Z algorithm | 12:30pm to 1:45pm | |
Thu Sep 8, 2016 | Assignment Exit ticket - Z algorithm | due by 12pm |
Calendar Event KMP Algorithm | 12:30pm to 1:45pm | |
Mon Sep 12, 2016 | Assignment Reading: Chapter 1 from Compeau and Pevzner | due by 12pm |
Quiz Getting to know you | due by 11pm | |
Quiz Reading Quiz: Compeau and Pevzner Chapter 1 | due by 11pm | |
Tue Sep 13, 2016 | Assignment Reading: Z and KMP algorithms. | due by 12pm |
Calendar Event Finding origins of replication | 12:30pm to 1:45pm | |
Assignment Class expectations survey | due by 11pm | |
Wed Sep 14, 2016 | Assignment Exit ticket - Chapter 1 | due by 11pm |
Thu Sep 15, 2016 | Calendar Event Finding origins of replication--cont. | 1:45am |
Mon Sep 19, 2016 | Assignment Reading: Chapter 2 from Compeau and Pevzner - part 1 | due by 12pm |
Quiz Reading Quiz: Compeau and Pevzner Chapter 2: part 1 | due by 11pm | |
Assignment Rosalind: Finding patterns and skews | due by 11pm | |
Tue Sep 20, 2016 | Calendar Event Introduction to Motif Search | 12:30pm to 1:45pm |
Thu Sep 22, 2016 | Assignment Exit Ticket: Motif Search (Introduction) | due by 3am |
Calendar Event Greedy Motif Search | 12:30pm to 1:45pm | |
Mon Sep 26, 2016 | Assignment Exit Ticket: Median Motif Search, Greedy Motif Search | due by 10am |
Quiz Reading Quiz: Compeau and Pevzner Chapter 2: part 2 | due by 11pm | |
Assignment Reading: Chapter 2 from Compeau and Pevzner - part 2 | due by 11pm | |
Tue Sep 27, 2016 | Calendar Event Randomized Motif Search | 12:30pm to 1:45pm |
Thu Sep 29, 2016 | Calendar Event Motif Search Tools | 12am |
Assignment Exit Ticket: Motif Search-chapter 2 | due by 3am | |
Assignment Expectation survey - Midterm 1 | due by 11:59pm | |
Tue Oct 4, 2016 | Calendar Event Mid Term 1 | 12:30pm to 1:45pm |
Wed Oct 5, 2016 | Assignment Ethics readings | due by 11pm |
Thu Oct 6, 2016 | Calendar Event Biomedical ethics | 12:30pm to 1:45pm |
Fri Oct 7, 2016 | Assignment Rosalind: Build a Motif-Finder | due by 8pm |
Mon Oct 10, 2016 | Quiz Reading quiz: Assembly | due by 11pm |
Assignment Reading: Genome assembly part1 | due by 11pm | |
Tue Oct 11, 2016 | Calendar Event Genome assembly | 12:30pm to 1:45pm |
Assignment Midterm 1 - team | due by 1:45pm | |
Thu Oct 13, 2016 | Calendar Event Genome Assembly | 12:30pm to 1:45pm |
Quiz Exit ticket - Genome Assembly | due by 10pm | |
Assignment Exit ticket: assembly 2 | due by 11pm | |
Tue Oct 18, 2016 | Calendar Event De Bruijn Graph | 12:30pm to 1:45pm |
Calendar Event Intro to Genome Assembly | 12:30pm to 1:45pm | |
Quiz Rate your team-mates - midterm 1 | due by 11pm | |
Thu Oct 20, 2016 | Calendar Event More on De-Bruijn Graph | 12:30pm to 1:45pm |
Fri Oct 21, 2016 | Assignment Rosalind: Assembly part 1 | due by 11pm |
Mon Oct 24, 2016 | Quiz Reading Quiz: Proteomics | due by 11pm |
Assignment Reading: Proteomics - Chapter 4 in Compeau and Pevzner | due by 11pm | |
Thu Oct 27, 2016 | Calendar Event Intro to trie | 12:30pm to 1:45pm |
Fri Oct 28, 2016 | Assignment Rosalind: Assembly part 2 | due by 11pm |
Mon Oct 31, 2016 | Quiz Reading quiz: String indexing | due by 11pm |
Assignment Reading: String indexing - Chapter 9 [volume 2] | due by 11pm | |
Tue Nov 1, 2016 | Calendar Event Suffix Tree, Suffix Array | 12:30pm to 1:45pm |
Thu Nov 3, 2016 | Calendar Event BWT | 12:30pm to 1:45pm |
Fri Nov 4, 2016 | Assignment Rosalind on proteomics | due by 11pm |
Mon Nov 7, 2016 | Quiz Exit ticket - Genome indexing | due by 11:59pm |
Tue Nov 8, 2016 | Calendar Event Bowtie Demo | 12:30pm to 1:45pm |
Thu Nov 10, 2016 | Calendar Event Mid Term 2 | 12:30pm to 1:45pm |
Tue Nov 15, 2016 | Calendar Event Intro to Seq alignment | 12:30pm to 1:45pm |
Thu Nov 17, 2016 | Calendar Event Dynamic Programming | 12:30pm to 1:45pm |
Assignment Midterm 2 - team | due by 1:45pm | |
Mon Nov 21, 2016 | Quiz Reading quiz: sequence alignment | due by 11pm |
Assignment Reading: Sequence Alignment (Chapter 5) | due by 11pm | |
Tue Nov 22, 2016 | Calendar Event Local Alignment | 12:30pm to 1:45pm |
Quiz Exit ticket: Sequence Alignment | due by 11pm | |
Thu Nov 24, 2016 | Calendar Event Thanksgiving | 12:30pm to 1:45pm |
Tue Nov 29, 2016 | Calendar Event More on Seq. alignment: space & memory efficient algorithm | 12:30pm to 1:45pm |
Wed Nov 30, 2016 | Assignment Rosalind: Invert Burrows-Wheeler Transform Problem | due by 11pm |
Thu Dec 1, 2016 | Calendar Event BLAST Demo | 12am |
Quiz Rate your team-mates - midterm 2 | due by 11pm | |
Mon Dec 5, 2016 | Quiz Reading quiz: clustering | due by 11pm |
Assignment Reading: clustering | due by 11pm | |
Tue Dec 6, 2016 | Calendar Event Intro to Clustering, K-means clustering | 12am |
Quiz Exit ticket: clustering | due by 10pm | |
Thu Dec 8, 2016 | Calendar Event Hierarchical clustering | 12am |
Mon Dec 12, 2016 | Assignment Rosalind: Longest common subsequence | due by 10:59pm |
Mon Dec 19, 2016 | Assignment Final exam | due by 1:30pm |
Assignment Class policies | ||
Assignment Midterm 1 - in class | ||
Assignment Midterm 2 in class | ||
Assignment Peer evaluation midterm 1 | ||
Assignment Peer evaluation midterm 2 |