Robust Self-Assembly of DNA Eduardo Abeliuk Dept. of Electrical Engineering Stanford University November 30, 2006.

Slides:



Advertisements
Similar presentations
Ashish Goel, 1 A simple analysis Suppose complementary DNA strands of length U always stick, and those of length L never stick (eg:
Advertisements

DNA Self-Assembly For Constructing 3D Boxes Ming-Yang KaoVijay Ramachandran Northwestern UniversityYale University Evanston, IL, USANew Haven, CT, USA.
Strict Self-Assembly of Discrete Sierpinski Triangles James I. Lathrop, Jack H. Lutz, and Scott M. Summers Iowa State University © James I. Lathrop, Jack.
An information-bearing seed for nucleating algorithmic self-assembly Presented by : Venkata Chaitanya Goli Robert D. Barish1, Rebecca Schulman1,
1 SODA January 23, 2011 Temperature 1 Self-Assembly: Deterministic Assembly in 3D and Probabilistic Assembly in 2D Matthew CookUniversity of Zurich and.
1 The Limits of Computation Intractable and Non-computable functions.
Design of a Minimal System for Self-replication of Rectangular Patterns of DNA Tiles Vinay K Gautam 1, Eugen Czeizler 2, Pauline C Haddow 1 and Martin.
Induction and recursion
Introduction to Computability Theory
1 Introduction to Computability Theory Lecture3: Regular Expressions Prof. Amos Israeli.
1 Introduction to Computability Theory Lecture12: Decidable Languages Prof. Amos Israeli.
1 Introduction to Computability Theory Lecture12: Reductions Prof. Amos Israeli.
1 Introduction to Computability Theory Lecture2: Non Deterministic Finite Automata Prof. Amos Israeli.
1 Introduction to Computability Theory Lecture4: Regular Expressions Prof. Amos Israeli.
Introduction to Computability Theory
1 Introduction to Computability Theory Lecture7: PushDown Automata (Part 1) Prof. Amos Israeli.
Introduction to Computability Theory
CPSC 411, Fall 2008: Set 12 1 CPSC 411 Design and Analysis of Algorithms Set 12: Undecidability Prof. Jennifer Welch Fall 2008.
Self-Assembly Ho-Lin Chen Nov Self-Assembly is the process by which simple objects autonomously assemble into complexes. Geometry, dynamics,
Equivalence, DFA, NDFA Sequential Machine Theory Prof. K. J. Hintz Department of Electrical and Computer Engineering Lecture 2 Updated and modified by.
1 Undecidability Andreas Klappenecker [based on slides by Prof. Welch]
DNA Computing by Self Assembly  Erik Winfree, Caltech.
Validating Streaming XML Documents Luc Segoufin & Victor Vianu Presented by Harel Paz.
December 8, 2009Theory of Computation Lecture 22: Turing Machines IV 1 Turing Machines Theorem 1.1: Any partial function that can be computed by a Post-
DNA Self-Assembly The complexity of self-assembled shapes.
Normal forms for Context-Free Grammars
MOHAMMAD IMRAN DEPARTMENT OF APPLIED SCIENCES JAHANGIRABAD EDUCATIONAL GROUP OF INSTITUTES.
Copyright © Cengage Learning. All rights reserved. CHAPTER 2 THE LOGIC OF COMPOUND STATEMENTS THE LOGIC OF COMPOUND STATEMENTS.
Ashish Goel Stanford University Joint work with Len Adleman, Holin Chen, Qi Cheng, Ming-Deh Huang, Pablo Moisset, Paul.
Neural Networks Lecture 8: Two simple learning algorithms
Software Testing Sudipto Ghosh CS 406 Fall 99 November 9, 1999.
1 Compact Error-Resilient Computational DNA Tiling Assemblies John H.Reif, Sudheer Sahu, and Peng Yin Presenter: Seok, Ho-SIK.
Lecture 05: Theory of Automata:08 Kleene’s Theorem and NFA.
Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University,
Theoretical Tile Assembly Models Tianqi Song. Outline Wang tiling Abstract tile assembly model Reversible tile assembly model Kinetic tile assembly model.
Notes for self-assembly of thin rectangles Days 19, 20 and 21 of Comp Sci 480.
Notes on the optimal encoding scheme for self-assembly Days 10, 11 and 12 Of Comp Sci 480.
4/4/20131 EECS 395/495 Algorithmic DNA Self-Assembly General Introduction Thursday, 4/4/2013 Ming-Yang Kao General Introduction.
Notes on local determinism Days 12, 13 and 14 of Comp Sci 480.
ICS 253: Discrete Structures I Induction and Recursion King Fahd University of Petroleum & Minerals Information & Computer Science Department.
Algorithmic Self-Assembly of DNA Sierpinski Triangles Ahn, Yong-Yeol Journal Club.
Notes on temperature programming: lines and scaled shapes Days 28, 29 and 30 of Comp Sci 480.
An Introduction to Algorithmic Tile Self-Assembly.
Recognising Languages We will tackle the problem of defining languages by considering how we could recognise them. Problem: Is there a method of recognising.
NP-Completness Turing Machine. Hard problems There are many many important problems for which no polynomial algorithms is known. We show that a polynomial-time.
Notes for temperature 1 self- assembly Days 15, 16, 17 and 18 of Comp Sci 480.
Ashish Goel, 1 The Source of Errors: Thermodynamics Rate of correct growth ¼ exp(-G A ) Probability of incorrect growth ¼ exp(-G A.
1 David DotyCalifornia Institute of Technology Matthew J. PatitzUniversity of Texas Pan-American Dustin ReishusUniversity of Southern California Robert.
Chapter 5. Section 5.1 Climbing an Infinite Ladder Suppose we have an infinite ladder: 1.We can reach the first rung of the ladder. 2.If we can reach.
Modeling Arithmetic, Computation, and Languages Mathematical Structures for Computer Science Chapter 8 Copyright © 2006 W.H. Freeman & Co.MSCS SlidesTuring.
Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University,
Computer Graphics Filling.
Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University,
Numerical Representation of Strings
Introduction to Tiling Assembly
Equivalence, DFA, NDFA Sequential Machine Theory Prof. K. J. Hintz
Tiing Error Correction & ExperimentsChen
Compact Error Resilient Computational DNA Tiling Assemblies
Induction and recursion
Strict Self-Assembly of Discrete Sierpinski Triangles
Self-Assembly Ho-Lin Chen Nov
John H. Reif and Sudheer Sahu
Self-Assembly of Any Shape with
Combinatorial Optimization Problems in Self-Assembly (Given a shape, output an “efficient” tile-system for assembling it)
The Power of Nondeterminism in Self-Assembly
Notes on temperature programming
Algorithms for Robust Self-Assembly
Theory of Computation Lecture 23: Turing Machines III
Presentation transcript:

Robust Self-Assembly of DNA Eduardo Abeliuk Dept. of Electrical Engineering Stanford University November 30, 2006

Agenda for today Robust Self-Assembly: definitions and motivation Basic assembly model and examples “Complexity of Self-Assembled Shapes” D. Soloveichik, E.Winfree. DNA Computers 10, LNCS v.3384, 2005 “Error Free Self-Assembly using Error Prone Tiles”, H. Chen, A. Goel. 10 th Int. Meeting on DNA Based Computers, “Self-Healing Tile Sets” E. Winfree, Nanotechnolgy: Science and computation, p.55-78, 2006

Self-Assembly Theory Self-assembly: no precise general definition But roughly speaking: “ process by which an organized structure can spontaneously form from simpler parts” Programming Complexity Fault-tolerance Self-healing Self-reproduction and evolution Schulman R., Winfree E., “Self-replication and evolution of DNA crystals” 2005.

Self-assembly Already present in nature Inside cells Robust self-assembly of organisms over 18 orders of magnitude in volume! Bottom-up fabrication of complex structures: Arbitrary shapes can be self-assembled (2D) Enabled by DNA nanotechnology Rothemund PWK, “Folding DNA to create nanoscale shapes and patterns”, Nature 2006

Another Motivation Compute “along the way” The self-assembly of a crystal can resemble a program that leaves the traces of its operations embedded in it. The assembly of a 2D crystal can simulate a universal Turing machine! input: output: input: output:

Robust self-assembly of DNA Do we need robustness? "In theory, there is no difference between theory and practice. But, in practice, there is." - Jan L.A. van de Snepscheut Computing with DNA, and not transistors?? DNACurrent computer Information density (bits/nm 3 ) ~1~ Parallelism (operations/sec) ~10 18 ~10 12 Energy expediture (J/operation) ~ ~10 -9

The tile assembly model Infinite lattice: Z x Z Every position in the grid has a relative position associated: N(i,j)=(i,j+1) S(i,j)=(i,j-1) E(i,j)=(i+1,j) W(i,j)=(i-1,j) (i,j) N WE S

Our fundamental unit is a square tile with labelled edges, or bond types. We consider a set of bond types. (e.g., ={A,B,C,D,null}) A reflection or rotation gives a different tile. So a tile type is a quadruple: and we have unlimited supply of them Tiles types with identical edges can pair with each other. We will represent tile types with different colors. All tile types for the set T. Bond types and Tile Types A B C D A C D B A B D A B C D A C D B A B D A B C D B A B D

Tiles A tile is a pair, i.e., it corresponds to a tile with certain tile type located in a certain position in our grid A configuration is a set of tiles, such that there is exactly one tile in every location Configuration 1 Configuration 2

Interaction between tiles A strength function defines the interactions between two tiles. We say a tile t 1 interacts with its neighbor t 2 with strength Usually, only diagonal strength functions are considered, and the range of g is {0,1,2} A B C D B A B C A C C D g A B C D null A B C D null

The tile assembly model (aTAM) A tile system is a quadruple i.e., it consist of a set of tile types a seed tile a strength function a binding threshold or “temperature” Self-assembly is defined as a relation between configurations: AB

Example of Tile Systems Sierpinski tile set 7 types of tiles: 1 seed, 2 boundary (input) tiles, 4 rule tiles Seed Boundary tiles “Rule” tiles

Sierpinski tile set Tiles

Sierpinski tile set

Binary counter Tyle types:

Binary counter Begin with seed Continue with boundary tiles Then “rule” tiles Count upwards (binary) = 1 = 0 Tiles

Square self-assembly Example for 9x9 square 41 Tile types

More on assemblies Tile additions are non-deterministic 1. Several locations for adding tiles 2. Several possible tiles could be added in one spot Defininitions: input sides propagation (output) sides terminal sides. terminal input output From binary counter

Final Assembly Theorem Definition: an assembly is locally deterministic if: every tile addition has strength 2. if tile at (i,j) and all tiles touching its propagation sides are removed, then there is only one tile type that can be added at (i,j) Theorem: “ If a tile set has one locally determinist assembly sequence, then the same final assembly is produced regardless of order of tile additions”.

From theory to practice (biology) Tiles are “do-able” in practice DNA Nano-technology Winfree, E. et at. Design and self-assembly of two dimensional. DNA crystals

More on the technology More tiles from DNA Hao Yan et al. “4x4 DNA Tile and Lattices: Characterization, Self- Assembly and Metallization of a Novel DNA Nanostructure Motif” 2003.

Road ahead… 1. First paper (complexity): Ties (Kolmogorov) computation of a shape with complexity of tile system that self-assembles it Note: the former has nothing to do with self-assembly Robust self-assembly 2. Second paper (fault-tolerance): how to avoid nucleation and growth errors 3. Third paper (self-healing): how to avoid gross damage

First paper D. Soloveichik, E.Winfree, “Complexity of Self-Assembled Shapes”

Coordinated shapes Let S be a finite set of locations in Z 2. S is a coordinated shape if it’s connected Coordinated shapeThis is not

Transforming coordinated shapes Scalings: Translations:

Shapes Scale and translation equivalence relations on coordinated shapes define class of shapes coordinated shape 1coordinated shape 3 coordinated shape 2 All belong to the same class of shapes =

Computer Science Concepts Kolmogorov complexity: = size of the smallest program outputting the coordinated shape as a list of locations Similarly

Tile Complexity The tile-complexity of a coordinated shape S is: n s.t. exists a tile system T of n tile types K sa (S)= min that uniquely produces assembly A and S is the coordinated shape of A. n s.t. exists a tile system T of n tile types K sa ( )= min that uniquely produces assembly A and is the shape of A.

Main Theorem There exist constants such that for any shape, To show the right inequality, the paper explicitly shows how to find an optimum tile system that assembles a given shape! (proof in paper) The minimun number of bits required to store n tile types is i.e., same complexity as Kolmogorov complexity of shape!

Corollary (tile complexity) of shapes is uncomputable. i.e., given a shape, the minimun number of tiles required to assemble it cannot be computed Formally, the following language is undecidable:

Second paper H. Chen, A. Goel, “Error Free Self-Assembly using Error Prone Tiles”

Kinetic Tile Assembly Model (kTAM) Stochastic model. Add and remove tiles Kinetics: Two parameter:

Snake proof reading A simple one dimensional example will be used to illustrate the algorithm. We will consider four tile types, with two bond types + null bond:

Snake proof reading (2) The input will consist of a structure of n+2 tiles Our 1-D crystal will output the parity of the input. input=“1111” (n=4)

Definition Insufficient attachment (at ) is: A process where a tile attaches with strength one but before it falls, another tile attaches next to it (and now both are held by strength ). They can cause two type of errors: growth errors nucleation errors.

Growth Errors A growth error is an invalid tile attachment to a “valid” position Incorrect pairing

Nucleation Errors When a tile attaches to an incorrect position (small binding strength) Correct pairing, but weak bonding..that then stabilizes 0 1 1

Replace each tile with 2x2 blocks. The internal glues are all unique to the 2x2 block Corrects for growth but not nucleation errors. Winfree-Bekbolatov proofreading system

Snake proofreading Replace each tile with 2x2 blocks. The internal glues are all unique to the 2x2 block Corrects for growth and nucleation errors.

Robust parity check Replace tiles with 2x2 blocks Note location of strong bonds and null bonds 1L 1L 0 B X20B1LX20B1L 0 T 1L 1L 1R 1R 1L 1L 1R 1R 1R 1R 1R 1R 1L 1L X20B1LX20B1L 0 B X 3 X 2 X 3 1 T X 4 1 B 1 R X 3 1 T X 4 0 B X 3 X 2 X 4 1 B 1 R X 8 X 5 0 B 1 R X61B1LX61B1L 1 T X 7 X 6 X 7 0 T X 8 1 T X 7 X 6 X61B1LX61B1L X 7 0 T X 8 0 B 1 R

Insufficient attachments 1L 1L 0 B X20B1LX20B1L 0 T 1L 1L 1R 1R 1L 1L 1R 1R 1R 1R 1R 1R 1L 1L X 8 X 5 0 B 1 R 0 B X 3 X 2 X 3 1 T X 4 1 B 1 R X20B1LX20B1L Insufficient Attachment Weak tile attaches No error Insufficient attachment Continuous Markov Chain Model

Insufficient attachments 1 insufficient attachment is very unlikely, but over the course of n attachments, the probability of getting at least one insufficient attachment might become significant. Snake-proofreading requires two insufficient attachments in close proximity to have an error than can propagate. No error Insufficient attachment

Nucleation error improvement 1L 1L 0 B X20B1LX20B1L 0 T 1L 1L 1R 1R 1L 1L 1R 1R 1R 1R 1R 1R 1L 1L X 8 X 5 0 B 1 R 0 B X 3 X 2 X 3 1 T X 4 1 B 1 R X20B1LX20B1L Cannot propagate with tau=2 unless another insufficient attachment occurs 1 Insufficient attachment No error 2 Insufficient attachments

General Snake proofreading Previous example only considered one directional growth. General method extends to: L-bounded systems (growth S  N and E  W) Replaces a tile by k x k block Set of rules to construct internal bonds All internal bonds are unique to the tile block Most of them have strength 1, some have strength 0, some have strength 2.

Example Notice how tiles are constructed following a snake pattern. T 1,1 T 4,2 T 4,1 T 3,1 T 2,1 T 3,3 T 4,3 T 3,2 T 2,2 T 2,3 T 1,2 T 2,4 T 3,4 T 4,4 T 1,4 T 1,3

Theorem 1 With a 2k x 2k snaked tile system (for k sufficiently large) assuming we can set to be, an N x N square of blocks can be assembled in time and w.h.p no block errors happen for time after that. Theorem 2 With a 2k x 2k snaked tile system ( ) assuming that we can set to be, an N x N square of blocks can be assembled in time and w.h.p no block errors happen for time after that. Informally, snaked proofreading results in tile systems which assemble quickly and remain stable for long time Main analytical results

Simulation results (1) Three systems simulated using xgrow no proofreading, WB proofreading, snaked 4x4 tile blocks

Simulation results (2) Simulations relaxed idealized modeling conditions They corroborate analytical results

Third paper E. Winfree, “Self-Healing Tile Sets”

A new type of error: Gross damage Gross damage: removes a region containing many tiles This error is rare in kTAM model, but is not hard to imagine in practice ripping induced by fluid flow interactions with other objects in solution) Is healing possible? Under general assumptions, Yes! We formulate the answer in the framework of aTAM: “focus on the information-propagation aspects of the problem rather than on the probabilistic aspects”

Self-healing tiles Definition: A tile system is self-healing (in the aTAM) if, for any produced assembly, the following holds: “If n tiles are removed such that all remaining tiles are still connected to the seed tile, then subsequent growth is guaranteed to eventual restore every removed tile without error in time O(n) ”

Are self-assembled patterns self-healing? Is any of our previous examples self-healing? NO! Example: BANG!

Main results 3x3 block transformation: repair tile sets that grow in a quarter-plane from L- shaped boundary 5x5 transformation: more general case, work for our three examples 7x7 transformation: even more general, works for “polyomino” tile sets.

3x3 Transformations L-bounded tile sets are self-healing under these transformation Quarter plane growth from L-shape boundary is a rich class of tile sets capable of creating a variety of patterns sufficient for universal computation

3x3 Transformations For every tile type, we introduce 9 new tile types Define tile-type bonds, and bond-type bonds The 3x3 block transformation shown above produces a self-healing tile set when applied to an L-bounded tile set.

3x3 Transformations Example:

5x5 Transformation Theorem Definition: A transformable tile set is a locally deterministic tile set such that 1. each tile type always appears with the same sides as input, propagation, and terminal sides 2. Termina sides have null bonds.

5x5 Transformation Theorem Theorem: The 5x5 block transformation shown below produces a self-healing tile set when applied to a transformable tile set.

7x7 Transformation Theorem Problem: Some of the new tiles can act as “seeds”. Definition: A polyomino set is a tile set that also includes block of tiles (polyominos) that can grow from tiles that are not original seed tiles. Theorem: An 7x7 block transformation can produce a self- healing tile set, even with a polyomino set.

7x7 Transformation Theorem Transformations:

Open questions There are still other type of errors that can occur e.g., when seed is removed, or continual gross damage Can we combine in a single method or transformation, a scheme that is robust under a wide class of type of errors and tile types? Are there smaller self-healing tile sets? What about errors that damage a tile itself? What about 3D assemblies (theory and practice)?

THE END Thanks! Questions?