Amorphous computing refers to computational systems that use very large numbers of identical, parallel processors each having limited computational ability and local interactions. The term Amorphous Computing was coined at MIT in 1996 in a paper entitled [http://www-swiss.ai.mit.edu/projects/amorphous/white-paper/amorph-new/amorph-new.html "Amorphous Computing Manifesto"] by Abelson, Knight, Sussman, et al.
Examples of naturally occurring amorphous computations can be found in many fields, such as:
developmental biology(the development of multicellular organisms from a single cell), molecular biology(the organization of sub-cellular compartments and intra-cell signaling), neural networks, and chemical engineering(non-equilibrium systems) to name a few. The study of amorphous computation is "hardware agnostic" -- it is not concerned with the physical substrate (biological, electronic, nanotech, etc.) but rather with the characterization of amorphous algorithms as abstractions with the goal of both understanding existing natural examples and engineering novel systems.
Amorphous computers tend to have many of the following properties:
* Implemented by redundant, potentially faulty, massively parallel devices.
* Devices having limited memory and computational abilities.
* Devices being asynchronous.
* Devices having no a priori knowledge of their location.
* Devices communicating only locally.
* Exhibit emergent or self-organizational behavior (patterns or states larger than an individual device).
* Fault-tolerant, especially to the occasional malformed device or state perturbation.
Algorithms, tools, and patterns
(Some of these algorithms have no agreed-upon names. Where a name is not known, a descriptive one is given.)
* "Fickian communication". Devices communicate by generating messages which diffuse through the medium in which the devices dwell. Message strength will follow the inverse square law as described by
Fick's law of diffusion. Examples of such communication are common in biological and chemical systems.
* "Link diffusive communication". Devices communicate by propagating messages down links wired from device to device. Unlike "Fickian communication", there is not necessarily a diffusive medium in which the devices dwell and thus the spatial dimension is irrelevant and Fick's Law is not applicable. Examples are found in Internet routing algorithms such as the
Diffusing Update Algorithm. Most algorithms described in the amorphous computing literature assume this kind of communication.
* "Wave Propagation". (Ref 1) A device emits a message with an encoded hop-count. Devices which have not seen the message previously, increment the hop count, and re-broadcast. A wave propagates through the medium and the hop-count across the medium will effectively encode a distance gradient from the source.
* "Random ID". Each device gives itself a random id, the random space being sufficiently large to preclude duplicates.
* "Growing-point program". (Coore). Processes that move among devices according to 'tropism' (movement of an organism due to external stimuli).
* "Wave coordinates". (from the DARPA PPT slide, to be referenced). To be written
* "Neighborhood query". (Nagpal) A device samples the state of its neighbors by either a push or pull mechanism.
* "Peer-pressure". Each device maintains a state and communicates this state to its neighbors. Each device uses some voting scheme to determine whether or not to change state to its neighbor's state. The algorithm partitions space according to the initial distributions and is an example of a clustering algorithm. (Illustration, citation needed)
* "Self maintaining line". ( [http://www-swiss.ai.mit.edu/projects/amorphous/Robust/laurenc/amorphous/self-repair.html|Lauren Lauren, Clement] ). A gradient is created from one end-point on a plane covered with devices via Link Diffusive Communication. Each device is aware of its value in the gradient and the id of its neighbor that is closer to the origin of the gradient. The opposite end-point detects the gradient and informs its closer neighbor that it is part of a line. This propagates up the gradient forming a line which is robust against disruptions in the field. (Illustration needed).
* "Club Formation". ( [http://citeseer.ist.psu.edu/cache/papers/cs/2546/http:zSzzSzswissnet.ai.mit.eduzSz~switzzSzamorphouszSzpaperszSzaimemo1614.pdf/coore97paradigms.pdf|Coore, Coore ,Nagpal, Weiss] ). Local clusters of processors elect a leader to serve as a local communication hub.
* "Coordinate formation" ( [ftp://publications.ai.mit.edu/ai-publications/pdf/AIM-1666.pdf Nagpal] ). Multiple gradients are formed and used to form a coordinate system via triangulation.
Researchers and labs
Hal Abelson, MIT
* [http://web.mit.edu/jakebeal/www/ Jacob Beal] , graduate student MIT (high level languages for amorphous computing)
* [http://www.mona.uwi.edu/fpas/isconf/5.htm Daniel Coore] , University of West Indies (growing point language, tropism, grown inverter series)
* Tom Knight, MIT (computation with synthetic biology)
* [http://www.eecs.harvard.edu/~rad/ Radhika Nagpal] , Harvard (self-organizing systems)
Zack Booth Simpson, Ellington Lab, Univ. of Texas at Austin. (Bacterial edge detector)
Gerry Sussman, MIT AI Lab
* [http://www.princeton.edu/~rweiss/ Ron Weiss] , Princeton (rule triggering, microbial colony language, coli pattern formation)
# [http://www-swiss.ai.mit.edu/projects/amorphous/ The Amorphous Computing Home Page]
#:A collection of papers and links at the MIT AI lab
# [http://www-swiss.ai.mit.edu/projects/amorphous/cacm-2000.html Amorphous Computing (Communications of the ACM, May 2000)]
#:A review article showing examples from Coore's Growing Point Language as well as patterns created from Weiss's rule triggering language.
# [http://www-swiss.ai.mit.edu/projects/amorphous/tucson-talk/ Amorphous Computing Slides from DARPA talk in 1998]
#:An overview of ideas and proposals for implementations
# [http://isandtcolloq.gsfc.nasa.gov/fall2002/presentations/abelson.ppt Amorphous and Cellular Computing PPT from 2002 NASA Lecture]
#:Almost the same as above, in PPT format
# [http://people.csail.mit.edu/jrb/stp/proto-isys-2006.pdf Infrastructure for Engineered Emergence on Sensor/Actuator Networks] , Beal and Bachrach, 2006.
#:An amorphous computing language called "Proto".
# [http://www-swiss.ai.mit.edu/projects/amorphous/Robust/laurenc/amorphous/ Self-repairing Topological Patterns] Clement, Nagpal.
#:Algorithms for self-repairing and self-maintaining line.
# [http://www-swiss.ai.mit.edu/projects/amorphous/Robust/joshuag/ Robust Methods of Amorphous Synchronization] , Joshua Grochow
#:Methods for inducing global temporal synchronization.
# [http://www.swiss.ai.mit.edu/projects/amorphous/Progmat/ Programmable Self-Assembly: Constructing Global Shape Using Biologically-Inspired Local Interactions and Origami Mathematics] and [http://www.swiss.ai.mit.edu/projects/amorphous/Progmat/talk/img0.htm Associated Slides] Nagpal PhD Thesis
#:A language to compile local-interaction instructions from a high-level description of an origami-like folded structure.
# [http://www-swiss.ai.mit.edu/projects/amorphous/Progmat/thesis/activecells.html Towards a Programmable Material] , Nagpal [http://swiss.csail.mit.edu/projects/amorphous/Progmat/thesis/old-talk/ Associated Slides]
#:Similar outline to previous paper
# [http://www-swiss.ai.mit.edu/~zucker/paper/ Self-Healing Structures in Amorphous Computing] Zucker
#:Methods for detecting and maintaining topologies inspired by biological regeneration.
# [http://www.csail.mit.edu/~jrb/Projects/rseam.pdf Resilient serial execution on amorphous machines] , Sutherland Master's Thesis
#:A language for running serial processes on amorphous computers
# [http://citeseer.ist.psu.edu/cache/papers/cs/2546/http:zSzzSzswissnet.ai.mit.eduzSz~switzzSzamorphouszSzpaperszSzaimemo1614.pdf/coore97paradigms.pdf Paradigms for Structure in an Amorphous Computer] , 1997 Coore, Nagpal, Weiss
#:Techniques for creating hierarchical order in amorphous computers.
# [ftp://publications.ai.mit.edu/ai-publications/pdf/AIM-1666.pdf Organizing a Global Coordinate System from Local Information on an Amorphous Computer] , 1999 Nagpal.
#:Techniques for creating coordinate systems by gradient formation and analyzes precision limits.
Wikimedia Foundation. 2010.
Look at other dictionaries:
Amorphous solid — Amorphous redirects here. For amorphousness in computational systems, see amorphous computing. For amorphousness in science fiction, see amorphous creature. For amorphousness in set theory, see amorphous set. In condensed matter physics, an… … Wikipedia
Natural computing — For the scientific journal, see Natural Computing (journal). Natural computing, also called Natural computation, is a terminology introduced to encompass three classes of methods: 1) those that take inspiration from nature for the development of… … Wikipedia
Unconventional computing — is computing by a wide range of new or unusual methods. It is also known as alternative computing. The different methods of unconventional computing include optical computing, quantum computing, chemical computing, natural computing, biologically … Wikipedia
Billiard-ball computer — [ Fredkin and Toffoli Gate Billiard Ball Model] A billiard ball computer as in ref|penr is an idealized model of a computing machine based on Newtonian dynamics. Instead of using electronic signals like a conventional computer, it relies on the… … Wikipedia
Morphological computation (robotics) — Morphological computation is computation obtained through interactions of physical form. Contents 1 Birth of the term morphological computation 2 Relevance 2.1 Robotics 2.2 Artificial intellige … Wikipedia
Message passing — This article is about the computer science concept. For other uses, see Message passing (disambiguation). Message passing in computer science is a form of communication used in parallel computing, object oriented programming, and interprocess… … Wikipedia
David De Roure — photo of DDeR by Adi Himpson, July 2010 Born 3 September 1962(1962 09 03) North London, England Nationality … Wikipedia
Hal Abelson — Infobox Scientist name = Hal Abelson image width = 150px caption = Abelson in 2007 birth date = birth place = death date = death place = residence = citizenship = nationality = ethnicity = field = computer science, ethics, law, methodology,… … Wikipedia
Zack Simpson — Zachary Booth Simpson is an engineer, scientist and artist. A high school dropout, he was a game developer and the Director of Technology for Origin and Titanic Entertainment from 1991 1997. He was Origin s only research fellow in 1998 during… … Wikipedia
Phase-change memory — Computer memory types Volatile RAM DRAM (e.g., DDR SDRAM) SRAM In development T RAM Z RAM TTRAM Historical Delay line memory Selectron tube Williams tube Non volatile … Wikipedia