Emergent Design
Encyclopedia
Emergent Design means that Design of Artifacts is itself an Emergent Phenomenon. This implies that it emerges in the creative design process, rather than being a blueprint that exists eternally in the ether like the Platonic source Forms and also that the artifact that is designed has emergent properties that are more than the sum of its parts. Supervenient Design would be the opposite and it would imply that the designed artifact's properties were the sum of its parts, and that the design itself was cobbled together only by permutations of factors that already existed in some other form, say in nature. Thus emergent design has a two fold meaning. It means that the design process is creative and cannot be done by rote, and thus it is a non-routine type of work, but also it implies that the result of this creative non-routine work itself has emergent properties that cannot be reduced to the parts that it is composed of by supervenience.
Emergent Design as an idea can be applied to many different disciplines, but the term is most well known as applied to Education and Software Engineering.
coined by David Cavallo to describe a theoretical framework
for the implementation of systemic change in education and learning environments. This examines how choice of design methodology
contributes to the success or failure of education reforms through studies in Thailand
. It is related to the theories of Situated learning
and of Constructionist learning
. The term constructionism was coined by Seymour Papert
who Cavallo studied under. Emergent Design holds that education systems cannot adapt effectively to technology change unless the education is rooted in the existing skills and needs of the local culture.
, whose concept work, also written by Cavallo can be found supported in Models of growth - towards fundamental change in learning environment.
As Emergent Design is heavily dependent upon Refactoring, practicing Emergent Design without a comfortable set of unit test
s is considered an irresponsible practice.
Emergent Design as an idea can be applied to many different disciplines, but the term is most well known as applied to Education and Software Engineering.
Emergent Design in Education
'Emergent Design' is a phrasePhrase
In everyday speech, a phrase may refer to any group of words. In linguistics, a phrase is a group of words which form a constituent and so function as a single unit in the syntax of a sentence. A phrase is lower on the grammatical hierarchy than a clause....
coined by David Cavallo to describe a theoretical framework
Conceptual framework
A conceptual framework is used in research to outline possible courses of action or to present a preferred approach to an idea or thought. For example, the philosopher Isaiah Berlin used the "hedgehogs" versus "foxes" approach; a "hedgehog" might approach the world in terms of a single organizing...
for the implementation of systemic change in education and learning environments. This examines how choice of design methodology
Methodology
Methodology is generally a guideline for solving a problem, with specificcomponents such as phases, tasks, methods, techniques and tools . It can be defined also as follows:...
contributes to the success or failure of education reforms through studies in Thailand
Thailand
Thailand , officially the Kingdom of Thailand , formerly known as Siam , is a country located at the centre of the Indochina peninsula and Southeast Asia. It is bordered to the north by Burma and Laos, to the east by Laos and Cambodia, to the south by the Gulf of Thailand and Malaysia, and to the...
. It is related to the theories of Situated learning
Situated learning
Situated learning was first proposed by Jean Lave and Etienne Wenger as a model of learning in a Community of practice. At its simplest, situated learning is learning that takes place in the same context in which it is applied...
and of Constructionist learning
Constructionist learning
Constructionist learning is inspired by the constructivist theory that individual learners construct mental models to understand the world around them. However, constructionism holds that learning can happen most effectively when people are also active in making tangible objects in the real world...
. The term constructionism was coined by Seymour Papert
Seymour Papert
Seymour Papert is an MIT mathematician, computer scientist, and educator. He is one of the pioneers of artificial intelligence, as well as an inventor of the Logo programming language....
who Cavallo studied under. Emergent Design holds that education systems cannot adapt effectively to technology change unless the education is rooted in the existing skills and needs of the local culture.
Applications
The most notable non-theoretical application of the principles of emergent design is in the OLPCThe Children's Machine
One Laptop per Child is a project supported by the Miami-based One Laptop per Child Association and the Cambridge-based OLPC Foundation , two U.S. non-profit organizations set up to oversee the creation of affordable educational devices for use in the developing world...
, whose concept work, also written by Cavallo can be found supported in Models of growth - towards fundamental change in learning environment.
Emergent Design in Agile Software Development
Emergent Design is a consistent topic in Agile Software Development, as a result of the methodology's focus on delivering small pieces of working code with business value. With Emergent Design, a development organization starts delivering functionality and lets the design emerge. Development will take piece of functionality A and implement it using best practices and proper test coverage, then then move on to delivering functionality B. Once B is built, or while it is being built, the organization will look at what A and B have in common and refactor out the commonality, allowing the design to emerge. This process continues as the organization continually delivers functionality. At the end of an agile or scrum release cycle, we are left with the smallest set of the design needed, as opposed to the design that could have been anticipated in advance. The end result is a smaller code base, which naturally has less room for defects and a lower cost of maintenance.As Emergent Design is heavily dependent upon Refactoring, practicing Emergent Design without a comfortable set of unit test
Unit test
In computer programming, unit testing is a method by which individual units of source code are tested to determine if they are fit for use.A unit is the smallest testable part of an application. In procedural programming a unit could be an entire module but is more commonly an individual function...
s is considered an irresponsible practice.
Emergent Architectural Design in Systems Engineering Product Development
Emergent Design refers to not just software but all forms of design of any kind of systems, including Architecture of Buildings, or large Systems of Systems produced by the networking of many systems together. Systems (and Systems of Systems) are by implication emergent as they have properties that cannot be reduced to their parts. Also in the process of Systems Design there is a creative and artful side to the Design Process by which the Design appears in the process of design. This broader sense of Systems Architectural Emergent Design is explored by Kent Palmer in his Dissertation titled Emergent Design.External links
- Models of Growth
- David Cavallo bio page
- David Cavallo MIT Media Lab page
- Emergent design and learning environments: building on indigenous knowledge
- http://www.agilesherpa.org/agile_coach/engineering_practices/emergent_design/
- Kent Palmer Emergent Design Dissertation See also http://emergentdesign.net
- Neal Ford of Thoughtworks on Emergent Design and Evolutionary Architecture
- MIT Emergent Design Group
- Brad Appleton ACME Blog -- Emergent Design and Evolutionary Architecture - Resources
- Venessa Miemis emergent by design Blog "What is Design Thinking, Really?"
- The Emergening Project
- Abel Avram Article titled "Reactions to Gartner’s Suggestion to Use an “Emergent Architecture”
- Michael Keeling article from Blog Reflections on Software Engineering