420 likes | 555 Views
סמינר 2 במדעי המחשב 236802 סמסטר חרף 2004-5. http: //www.cs.technion.ac.il/~moran/COURSES/SEM04-5/sem04-5.htm. 236803 סמינר במדעי המחשב 3 סמסטר ב', תשס"ג. הרשמה לקורס כל מי שרשום לקורס, או לא רשום אך מעונין להרשם – שיירשם בדף הנוכחות.
E N D
סמינר 2 במדעי המחשב 236802סמסטר חרף 2004-5 http://www.cs.technion.ac.il/~moran/COURSES/SEM04-5/sem04-5.htm .
236803 סמינר במדעי המחשב 3 סמסטר ב', תשס"ג הרשמה לקורס כל מי שרשום לקורס, או לא רשום אך מעונין להרשם – שיירשם בדף הנוכחות. עדיפות לאלו שאי רישום לסמינר עלול לעכב את סיום לימודיהם. תלמידי תואר שני המעונינים להרשם – נא שלחו לי דוא"ל. אישור הרשמה מותנה במקומות פנויים בקורס.
236803 סמינר במדעי המחשב 3 סמסטר ב', תשס"ג דרישות הקורס המשתתפים בקורס יעבירו הרצאות על אלגוריתמים הקשורים לבניית עצים פילוגנטיים (עצי אבולוציה). נושאי ההרצאה יילקחו ממאמרים ברשימה המופיעה באתר הקורס. אחת או שתי ההרצאות הראשונות (כולל הנוכחית) יינתנו על ידי המרצה. הרצאת סטודנטים ראשונה תינתן לכל המאוחר ב 4.11.04. מבנה הציון: 80-90% הרצאה, 10-20% נוכחות. ייתכן בוחן סיום לבדיקת בקיאות בהרצאות שהועברו.
236803 סמינר במדעי המחשב 3 סמסטר ב', תשס"ג הכנת הרצאה ככלל, ההרצאות יוכנו ויוגשו בזוגות, כל זוג ירצה שעתיים (פגישה אחת). יש להכין תקציר של ההרצאה, שיחולק לסטודנטים בכתה . ניתן להעזר במרצה לפני ההרצאה. בתאום עם המרצה, ניתן להציג רק חלק מהמאמר. יש לשלוח אל המרצה בדוא"ל את תקציר ההרצאה לפחות 72 שעות לפני ההרצאה. התקציר יועלה על אתר הקורס.
236803 סמינר במדעי המחשב 3 סמסטר ב', תשס"ג • רישום נוכחות: • ניקוד על נוכחות ייעשה מהרצאה שניה (28.10.03) והלאה. • היעדרות מהרצאה תחשב מוצדקת עבור מי שיש לו אישור מילואים\מחלה של ארבעה ימים או יותר. • למי שתהיה היעדרות לא מוצדקת אחת יוכל לכתוב תקציר של ההרצאה ממנה נעדר (עד שני עמודים מודפסים – ניתן לשלוח אלי קבצים בדאר אלקטרוני), ויוחזרו לו חלק או מלוא הנקודות שירדו מציונו בגין אותה היעדרות. מועד אחרון להגשת התקציר היום האחרון בסמסטר. • מי שתהיה לו יותר מהיעדרות לא מוצדקת אחת יוכל לסכם, בתאום אתי ובהיקף שייקבע על ידי, את אחת ההרצאות מהן נעדר, ויוחזרו לו חלק או מלוא הנקודות שירדו מציונו בגין אותן היעדרויות.
הקצאת הרצאות ראשונות: • מיד לאחר הרצאה זו מוזמנים אלי למשרד אלו המוכנים להרצות עד מחצית נובמבר, לצורך קבלת המאמרים להרצאה. • הקצאת הרצאות מאוחרות יותר: • סטודנטים הרשומים לקורס מתבקשים לשלוח אלי תוך שבוע מהיום, או מיד לאחר אישור הרשמתם: • תאריכים בהם לא יוכלו להרצות מסיבות מלואים, • (מומלץ) זמני הרצאה מועדפים, בני זוג מוסכמים להרצאה. • המגמה לקבוע שבוץ ההרצאות עד ההרצאה של ה4.11.03.
Course Prerequisites Computer Science and Probability Background • Data structure 1 (cs234218) • Algorithms 1 (cs234247) • Computability theory (cs236343) • Probability (any course) Not a prerequisite, but recommended: • Algorithms in Computational Biology (cs236522).
Questions so far? Introduction
Evolution Evolution of new organisms is driven by • Diversity • Different individuals carry different variants of the same basic blue print • Mutations • The DNA sequence can be changed due to single base changes, deletion/insertion of DNA segments, etc. • Selection bias
The Tree of Life Source: Alberts et al
Primate evolution A phylogeny is a tree that describes the sequence of speciation events that lead to the forming of a set of current day species; also called a phylogenetic tree.
Historical Note • Until mid 1950’s phylogenies were constructed by experts based on their opinion (subjective criteria) • Since then, focus on objective criteria for constructing phylogenetic trees • Thousands of articles in the last decades • Important for many aspects of biology • Classification • Understanding biological mechanisms
Morphological vs. Molecular • Classical phylogenetic analysis: morphological features: number of legs, lengths of legs, etc. • Modern biological methods allow to use molecular features • Gene sequences • Protein sequences • Analysis based on homologous sequences (e.g., globins) in different species
Morphological topology Bonobo Chimpanzee Man Gorilla Sumatran orangutan Bornean orangutan Common gibbon Barbary ape Baboon White-fronted capuchin Slow loris Tree shrew Japanese pipistrelle Long-tailed bat Jamaican fruit-eating bat Horseshoe bat Little red flying fox Ryukyu flying fox Mouse Rat Glires Vole Cane-rat Guinea pig Squirrel Dormouse Rabbit Pika Pig Hippopotamus Sheep Cow Alpaca Blue whale Fin whale Sperm whale Donkey Horse Indian rhino White rhino Elephant Carnivora Aardvark Grey seal Harbor seal Dog Cat Asiatic shrew Insectivora Long-clawed shrew Small Madagascar hedgehog Hedgehog Gymnure Mole Armadillo Xenarthra Bandicoot Wallaroo Opossum Platypus (Based on Mc Kenna and Bell, 1997) Archonta Ungulata
From sequences to a phylogenetic tree Rat QEPGGLVVPPTDA Rabbit QEPGGMVVPPTDA Gorilla QEPGGLVVPPTDA Cat REPGGLVVPPTEG There are many possible types of sequences to use (e.g. Mitochondrial vs Nuclear proteins).
Theory of Evolution • Basic idea • speciation events lead to creation of different species. • Speciation caused by physical separation into groups where different genetic variants become dominant • Any two species share a (possibly distant) common ancestor
Aardvark Bison Chimp Dog Elephant Phylogenenetic trees • Leafs - current day species • Internal vertices - hypothetical most recent common ancestors • Edges length - “time” from one speciation to the next
Dangers in Molecular Phylogenies • We have to emphasize that gene/protein sequence can be homologous for several different reasons: • Orthologs -- sequences diverged after a speciation event • Paralogs -- sequences diverged after a duplication event • Xenologs -- sequences diverged after a horizontal transfer (e.g., by virus)
Dangers of Paralogs Gene Duplication Speciation events 2B 1B 3A 3B 2A 1A
Dangers of Paralogs If we happen to consider only species 1A, 2B, and 3A, we get a wrong tree that does not represent the phylogeny of the host species of the given sequences because duplication does not create new species. Gene Duplication S S S Speciation events 2B 1B 3A 3B 2A 1A In the sequel we assume all given sequences are orthologs.
Types of Trees A natural model to consider is that of rooted trees Common Ancestor
Types of trees Unrooted tree represents the same phylogeny without the root node Depending on the model, data from current day species does not distinguish between different placements of the root.
Tree a Tree b Rooted versus unrooted trees Tree c b a c Represents the three rooted trees
Positioning Roots in Unrooted Trees • We can estimate the position of the root by introducing an outgroup: • a set of species that are definitely distant from all the species of interest Proposed root Falcon Aardvark Bison Chimp Dog Elephant
Type of Data • Distance-based • Input is a matrix of distances between species • Can be fraction of residue they disagree on, or alignment score between them, or … • Character-based • Examine each character (e.g., residue) separately
Three Methods of Tree Construction • Distance- A weighted tree that realizes the distances between the objects. • Parsimony – A tree with a total minimum number of character changes between nodes. • Maximum likelihood - Finding the “most probable” tree.
Molecular clock The tree has all leaves in the same depth. When this property holds, the phylogenetic tree is said to satisfy a molecular clock. Namely, the time from a speciation event to the formation of current species is identical for all paths (wrong assumption in reality).
k c b j a i Additivity Molecular clock: a special case of additive distances: distances that can be realized by a tree. Always true for 3 or less vertices:
Additive sets Given a set M of L objects with pairwise distances: • d(i,i)=0, and for i≠j, d(i,j)>0 • d(i,j)=d(j,i). • For all i,j,k it holds that d(i,k) ≤ d(i,j)+d(j,k). we say that the set is additive if there is a tree T, L of its nodes correspond to the L objects, with positive weights on the edges, such that for all i,j, d(i,j) = dT(i,j), the length of the path from i to j in T. Note 1: If the tree is required to be binary, the edge weights are required to be non-negative. Note 2: For simplicity, we will assume the nodes corresponding to objects are all leaves
Important Note • In reality, the input data is not an additive set. • So we need the algorithm to return a tree which approximates the distances of the input data. • A natural requirement: If the input set is additive, then the algorithm should return a correct tree (which is unique if all distances are positive). • Algorithmic questions: Decide if a given set is additive, and if it is, construct the corresponding weighted tree.
Basic property of Additivity • Suppose input distances are additive. • For any three vertices i,j,k there is a “junction” m. • Thus k c b j a m i
l i j k Identifying additive sets:The four points condition Theorem: A set M is additive iff any subset of four objects can be labeled i,j,k,l so that: d(i,j) +d(k,l) = d(i,l) +d(k,j) ≥ d(i,k) + d(j,l) Proof: Additivity 4P Condition: By the figure...
The four point condition d(i,j) +d(k,l) = d(i,l) +d(k,j) ≥ d(i,k) + d(j,l) 4P Condition Additivity: Induction on the number of objects L. For L≤ 3 the condition is empty and tree exists. So assume L>3. Let a set of objects {1,..,L} be given, with pairwise distances which satisfy the 4P condition.
L cij bij j aij mijL i Induction step: • Remove Object L from the set • By induction, there is a tree for the L-1 nodes, T’. • For each pair of labeled nodes (i,j) in T’, let aij, bij, cij be defined by the following figure:
L cij bij j aij mijL T’ i Induction step: • Pick i and j that minimize cij. • T is constructed by adding L (and possibly mijL) to T’, as in the figure. • Remains to prove: For each k ≠ i,j:d(k,L) = dT(k,L).
L cij k bij j aij mijL mijk T’ i Induction step Proof according the location of mijk on T’. Case 1: mijk ≠ mijL . WLOG Assume that mijk lies between mijL and j. By induction hypothesis: d(i,j )=dT(i,j), d(i,k )=dT(i,k), d(j,k )=dT(j,k) By construction: d(i,L )=dT(i,L), d(j,L )=dT(j,L) Need to prove: d(k,L) = dT(k,L)
L cij k bij j aij mijL mijk T’ i Induction step Proof case 1: mijk is located on T’ as shown. By the 4P condition on {i,j,k,L}: d(k,L) +d(i,j) = d(j,L) +d(i,k)> d(i,L) +d(j,k ): and by the location of mijk : dT(k,L) +d(i,j) = d(j,L) +d(i,k): Which implies that d(k,L) = dT(k,L).
L cij k j mijL T’ i Induction step (cont.) Case 2: mijk = mijL. It is suffice to prove that d(k,L) +d(i,j) = d(j,L) +d(i,k). By the 4P condition on {i,j,k,L} and the fact that: d(j,L) +d(i,k) = d(i,L) +d(j,k), we have that: d(k,L) +d(i,j) ≤ d(j,L) +d(i,k),
L cij k bij aij j mijL T’ i Induction step (end) It remains to prove that d(k,L) +d(i,j) ≥ d(j,L) +d(i,k): this is proved by the formula below. The left inequality is implied by the minimality of cij.
Constructing additive trees:The neighbor finding problem The formula shows that if we knew that i and j are neighboring leaves, then we can construct their parent node m and compute the distances of m to all other leaves m. We remove nodes i,j and add m.
k m i j Neighbor Joining Algorithms • Set L to contain all leaves Iteration: • Choose i,j such that i,j are leaves with same father. • Create new node m, and set • remove i,j from L, and add m Terminate:when |L| =2, connect two remaining nodes
Neighbor Joining Algorithms Question: How do we decide, from the distance matrix, if vertices i and j are neighboring leaves? This is one of the topics to be discussed.