Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University,

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

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.
Introduction to Algorithms Rabie A. Ramadan rabieramadan.org 2 Some of the sides are exported from different sources.
Self-Assembly Ho-Lin Chen Nov Self-Assembly is the process by which simple objects autonomously assemble into complexes. Geometry, dynamics,
Reducing Tile Complexity for Self-Assembly Through Temperature Programming Midwest Theory Day, December 10, 2006 Based on paper to appear in SODA 2006.
Complexities for Generalized Models of Self-Assembly Gagan Aggarwal Stanford University Michael H. Goldwasser St. Louis University Ming-Yang Kao Northwestern.
DNA Computing by Self Assembly  Erik Winfree, Caltech.
Robust Self-Assembly of DNA Eduardo Abeliuk Dept. of Electrical Engineering Stanford University November 30, 2006.
DNA Self-Assembly The complexity of self-assembled shapes.
Complexities for Generalized Models of Self-Assembly Gagan Aggarwal Stanford University Michael H. Goldwasser St. Louis University Ming-Yang Kao Northwestern.
Reducing Tile Complexity for Self-Assembly Through Temperature Programming Symposium on Discrete Algorithms SODA 2006 January 23, 2006 Robert Schweller.
Lec 5 Feb 10 Goals: analysis of algorithms (continued) O notation summation formulas maximum subsequence sum problem (Chapter 2) three algorithms image.
Ashish Goel Stanford University Joint work with Len Adleman, Holin Chen, Qi Cheng, Ming-Deh Huang, Pablo Moisset, Paul.
Matthew J. Patitz Explorations of Theory and Programming in Self-Assembly Matthew J. Patitz Department of Computer Science University of Texas-Pan American.
Strand Design for Biomolecular Computation
DNA-Scaffolded Self-Assembling Nano-Circuitry An Ongoing Research Project with Dr. Soha Hassoun Presentation by Brandon Lucia and Laura Smith.
CS1Q Computer Systems Lecture 8
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.
Computing with DNA Many thanks to Dave Bevan for providing some of the material for this lecture.
Notes on local determinism Days 12, 13 and 14 of Comp Sci 480.
Notes on temperature programming: lines and scaled shapes Days 28, 29 and 30 of Comp Sci 480.
An Introduction to Algorithmic Tile Self-Assembly.
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 35 th International Colloquium on Automata, Languages and Programming July 8, 2008 Randomized Self-Assembly for Approximate Shapes Robert Schweller University.
BITS Pilani Pilani Campus Data Structure and Algorithms Design Dr. Maheswari Karthikeyan Lecture1.
CSE15 Discrete Mathematics 03/06/17
Molecular Algorithms -- Overview
CPSC 121: Models of Computation 2008/9 Winter Term 2
Computational and Experimental Design of DNA Devices
Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University,
Introduction to Algorithms
CS154, Lecture 18:.
Introduction to Tiling Assembly
Programmable DNA Lattices: Design Synthesis & Applications
Thirteenth International Meeting on DNA Computers
Tiing Error Correction & ExperimentsChen
Algorithm An algorithm is a finite set of steps required to solve a problem. An algorithm must have following properties: Input: An algorithm must have.
DNA Self-Assembly Robert Schweller Northwestern University
Objective of This Course
Data Structures Review Session
This Lecture Substitution model
Algorithm Discovery and Design
Strict Self-Assembly of Discrete Sierpinski Triangles
Renaming and Oriented Manifolds
Horn Clause Computation by Self-Assembly of DNA Molecules
Self-Assembly Ho-Lin Chen Nov
CSE 2010: Algorithms and Data Structures Algorithms
John H. Reif and Sudheer Sahu
Self-Assembly of Any Shape with
Linear-Time Sorting Algorithms
Combinatorial Optimization Problems in Self-Assembly (Given a shape, output an “efficient” tile-system for assembling it)
Dr. Clincy Professor of CS
Complexities for the Design of Self-Assembly Systems
Analysis of Algorithms
This Lecture Substitution model
The Power of Nondeterminism in Self-Assembly
Notes on temperature programming
This Lecture Substitution model
EGR 2131 Unit 12 Synchronous Sequential Circuits
David Kauchak CS158 – Spring 2019
Algorithms for Robust Self-Assembly
Error Correction Coding
Discrete Mathematics CS 2610
Presentation transcript:

Molecular Self-Assembly: Models and Algorithms Ashish Goel Stanford University MS&E 319/CS 369X; Research topics in optimization; Stanford University, Spring 2003-04 http://www.stanford.edu/~ashishg

Self-Assembly Self-Assembly is the process by which simple objects autonomously assemble into complexes. Geometry, dynamics, combinatorics are all important Inorganic: Crystals, supramolecules Organic: Proteins, DNA, cells, organisms Goals: Understand self-assembly, design self-assembling systems A key problem in nano-technology, molecular robotics, molecular computation (Chen, Goel, Cheng)

What is Molecular Self-assembly? Self-assembly is the spontaneous formation of a complex by small (molecular) components under simple combination rules Geometry, dynamics, combinatorics are all important Inorganic: Crystals, supramolecules Organic: Proteins, DNA Goals: Understand self-assembly, design self-assembling systems A key problem in nano-technology, molecular robotics, molecular computation MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

A Matter of Scale Question: Why a mathematical study of “molecular” self-assembly specifically? Answer: The scale changes everything Consider assembling micro-level (or larger) structures such as robotic swarms. We can attach rudimentary computers, motors, and radios to these structures. Can now implement an intelligent distributed algorithm. In molecular self-assembly, we have nano-scale components. No computers. No radios. No antennas. We need self-assembly to make computers, radios, antennas, motors. Local rules such as “attach to another component if it has a complementary DNA strand” Self-assembly at larger scales is interesting, but is more a sub-discipline of distributed algorithms, artificial intelligence etc. MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

The Tile Model of Self-Assembly [Wang ’61] MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Tiling Self-Assembly of Counter 1 1 1 1 1 1 1 1 1 1 Counter made by self-assembly [Adleman, Cheng, Goel, Huang ’01] (Chen, Goel, Cheng)

Synthesized Tile Systems – I Styrene molecules attaching to a Silicon substrate Coat Silicon substrate with Hydrogen Remove one Hydrogen atom and bombard with Styrene molecules One Styrene molecule attaches, removes another Hydrogen atom, resulting in a chain Suggested use: Self-assembled molecular wiring on electronic circuits [Wolkow et al. ’00] MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

DNA Tiles Glues = sticky ends Tiles = molecules [Winfree] (Chen, Goel, Cheng)

Tile System: A tile can attach to an assembly [Rothemund, Winfree, ’2000] Temperature: A positive integer. A set of tile types: Each tile is an oriented square with glues on its edges. Each glue has a non-negative strength. An initial assembly (seed). A tile can attach to an assembly iff the combined strength of the “matchings glues” is greater or equal than the temperature. (Chen, Goel, Cheng)

Example of a tile system Temperature: 2 Set of tile types: Seed: (Cheng, Goel, Cheng)

Example of a SA process Temperature: 2 Set of tile types: Seed: (Cheng, Goel, Cheng)

Example of a SA process Temperature: 2 Set of tile types: Seed: (Cheng, Goel, Cheng)

Example of a SA process Temperature: 2 Set of tile types: Seed: (Cheng, Goel, Cheng)

Synthesized Tile Systems - II A DNA “rug” assembled using DNA “tiles” The rug is roughly 500 nm wide, and is assembled using DNA tiles roughly 12nm by 4nm (false colored) (Due to Erik Winfree, Caltech) MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Applications of Self-Assembly Self-assembly can be used to create small electrical devices such as FLASH memory. [Black et. Al. ’03] Self-assembly can create nanostructures which “steer” light in the same way computer chips steer electrons. [Percec et. Al. ’03] DNA strands can self-assemble into tiles and those tiles can further self-assemble into larger structures. This has many potential applications. [Winfree ’96] DNA “rug” by Winfree (Chen, Goel, Cheng)

Toy Tile Systems in the Lab Performing XOR using self-assembling tiles (Square tiles floating on oil with “glues” on each side) (Due to Paul Rothemund, USC) MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Abstract Tile Systems Tile: the four glues and their strengths K tiles Infinitely many copies available of each tile Temperature  A seed tile s Accretion Model: Assembly starts with a single seed tile, and proceeds by repeated addition of single tiles e.g. Crystal growth Are interested primarily in tile systems that assemble into a unique terminal structure [Rothemund and Winfree ‘00] [Wang ‘61] MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Is Self-Assembly Just Crystallization? No. Crystals do not grow into unique terminal structures! A sugar crystal does not grow to precisely 20nm Crystals are typically made up of a small number of different types of components Two types of proteins; a single Carbon molecule Crystals have regular patterns Computer circuits, which we would like to self-assemble, don’t Self-assembly = combinatorics + crystallization Can count, make interesting patterns Nature doesn’t count too well, so molecular self-assembly is a genuinely new engineering paradigm. Think engines. Think semiconductors. MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

A Roadmap for This Course Self-assembly as a combinatorial process The computational power of self-assembly Self-assembling interesting shapes and patterns, efficiently Automating the design process? Analysis of design complexity, experiment complexity, and assembly time Self-assembly as a chemical reaction Entropy, Equilibria, and Error Rates Reversibility Review of experimental progress, interesting applications Self-assembly at larger scales Ant colony optimization; assembling autonomous robots MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

DNA Self-Assembly We will tacitly assume that the tiles are made of DNA strands woven together, and that the glues are really free DNA strands DNA is combinatorial, i.e., the functionality of DNA is determined largely by the sequence of ACTG bases. Can ignore geometry to a first order. Trying to “count” using proteins would be hell – proteins have a complicated geometry and it is hard to predict what shape a single protein will take, let alone an entire assembly Proof-of-concept from nature: DNA strands can attach to combinatorially matching sequences DNA tiles have been constructed in the lab, and DNA computation has been demonstrated Can simulate arbitrary tile systems, so we do not lose any theoretical generality, but we get a concrete grounding in the real world The correct size (in the nano range) MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

1-D, 2-D, and 3-D Linear self-assemblies are very different from 2-D self-assemblies 2-D and 3-D are essentially identical in terms of the theory Will focus on 2-D in this course, and will passingly refer to 1-D MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Design Complexity of a Tile System Suppose the tile system has k different tiles Assume that we have q(k) different glues Assume for simplicity that all glues are represented by DNA strands of the same length, x How many different glues can we have? Each position can be one of the bases A, C, T, or G. An A pairs with T on the complementary strand, and a C pairs with G. So we can think of each position as corresponding to an AC base pair or a CG base pair. Two choices ) Binary encoding Number of glues · 2x Total length of all the DNA strands in all the different tiles = q(k log k). We will refer to k log k as the design complexity Does not depend on the size of the final structure. This is how much time and expertise and resources you would have to invest into designing the components (like program complexity) MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Notes We will sometimes informally use the quantity k to refer to the design complexity. The rules of assembly are easy to code up in a simulator. Thus if a tile system of k tiles can assemble into a certain shape, then there is a computer program of size q(k log k) which generates that shape. Design complexity is only interesting for assembling larger and larger shapes of a particular type, eg. squares, lines, spirals. Design complexity of an infinite line, infinite square etc. is just 1. MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Three Exercises Suppose we did not assume that the number of glues is q(k). Can you still prove that the total length of all the strands in all the tiles is q(k log k)? We assumed that our tiles are oriented, i.e., east is always east and north is always north, and the tiles are not allowed to rotate. Show how an oriented tile system can be simulated using a system where tiles can rotate by +/- 90 degrees. Now use the fact that the glues are really DNA strands to show how an oriented tile system can be simulated using a system where tiles can rotate by +/- 90 as well as 180 degrees. MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Some Lower Bounds on Design Complexity Consider assembling a line of length n Need at least n different tiles (high design complexity) Suppose tiles B and F are the same.Then we can “pump” the line segment BCDE into an infinite line Are we doomed? No. Can assemble thicker rectangles more efficiently Consider assembling an n£n square The average Kolmogorov complexity (the smallest program size to produce a desired output) is log n bits Thus, k log k = W(log n), or k = W(log n/log log n) A B C D E B C D E B C D E F G H I B C D E MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Tile Systems and Running Time B C A Seed MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Tile Systems and Running Time A: 50%, B:30%, C: 20% Seed A B d 0.5 Seed A B 0.3 Seed 0.2 Seed A B C 0.5 0.3 MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Tile Systems and Running Time Define a continuous time Markov chain M State space S: set of all structures that a tile system can assemble into Tiles of type Ti have concentration Ci Σi Ci = 1 Unique terminal structure => unique sink in M Seed tile is the unique source state Assembly time: the hitting time for the sink state from the source state in the Markov Chain MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Old Example: Assembling Lines Very simple Markov Chain. Average time for the ith tile to attach is 1/Ci Assembly time = åi 1/Ci For fastest assembly, all tiles must have the same concentration of 1/(n-1) Expected assembly time is ¼ n2 Can assemble thicker rectangles much faster and with much fewer different tiles MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

A Pretty Picture: Sierpinski Triangles Consider the four “XOR” tiles, where the south side is labeled either 0 or 1, and the east side is labeled either 0 or 1, and the west and north sides are labeled e XOR s where e and s are the bits on the east and south sides Assume t = 2, and all glue strengths are 1 Given the appropriate inputs (i.e. seeds), these tiles can do some very interesting things like Computing the parity Assembling into a very pretty fractal They have already been designed in a lab setting MS&E 319, Molecular self-assembly: models and algorithms. Stanford University, Spring 2003-04

Theoretical and Algorithmic Issues Efficiently assembling basic shapes with precisely controlled size and pattern Constructing N X N squares with Ω(log n/log log n) tiles [Adleman, Cheng, Goel, Huang, ’01] Perform universal computation by simulating BCA [Winfree ’99] Library of primitives to use in designing nano-scale structures [Adleman, Cheng, Goel, Huang, ’01] Automate the design process [Adleman, Cheng, Goel, Huang, Kempe, Moisset de espanes, Rothemund ’01] Robustness (Cheng, Goel, Cheng)