Jump to content

User:YoavShapira/Principles of system architecture: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m m
 
(17 intermediate revisions by 10 users not shown)
Line 1: Line 1:
This article lists several [[principle|principles]] of [[system architecture]]. For each principle, a short description is provided, along with longer normative and descriptive explanations, and in some cases an example.
== Introduction ==
This page describes the theoretical principles of System Architecture (SA). System Architecture can be defined in several ways, including:

# ''The composite of the design architectures for products and their life cycle processes.'' From [[IEEE]] 1220-1998 as found at [http://www.acq.osd.mil/osjtf/termsdef.html their glossary].
# ''A representation of a system in which there is a mapping of functionality onto [[hardware]] and [[software]] [[components]], a mapping of the [[software architecture]] onto the [[hardware architecture]], and human interaction with these components.'' From the [http://www.cmu.edu Carnegie Mellon University]'s [http://www.sei.cmu.edu Software Engineering Institute] as found at [http://www.sei.cmu.edu/opensystems/glossary.html its glossary].
# ''An allocated arrangement of physical elements which provides the design solution for a consumer product or life-cycle process intended to satisfy the requirements of the functional architecture and the requirements baseline.'' From [http://www.manningaffordability.com/s&tweb/HEResource/Other/Definitions.htm The Human Engineering Home Page's Glossary].
# ''An architecture is the most important, pervasive, top-level, strategic inventions, decisions, and their associated rationales about the overall structure (i.e., essential elements and their relationships) and associated characteristics and behavior.'' From [http://www.opfro.org/Components/WorkProducts/ArchitectureSet/Architectures/Architectures.html OPEN Process Framework (OPF) Repository].
# ''A description of the design and contents of a computer system. If documented, it may include information such as a detailed inventory of current hardware, software and networking capabilities; a description of long-range plans and priorities for future purchases, and a plan for upgrading and/or replacing dated equipment and software.'' From [http://nces.ed.gov/pubs98/tech/glossary.asp The National Center for Education Statistics glossary].

The original motivation for creating this page was an assignment by [http://web.mit.edu/aeroastro/www/people/crawley/bio.html Professor Edward Crawley] of [[MIT]], for his class titled ''System Architecture'' and taught in [[2005]]. However, we recognize the general applicability and interest of this material: equivalent classes are taught at numerous schools, and we invite everyone to provide feedback and add principles from their own experience or creation.
<!-- This is one beautiful definition! normxxx -->

== List of Principles ==
Principle: ''underlying and long enduring fundamentals that are always (or almost always) valid.''

For each pricinple, a short description is provided, along with longer normative and descriptive explanations, and hopefully an example. If the principle is inspired by a person, a thing, or a quote, that attribution should be given and/or explained.

There is no one perfect way to phrase a principle: wording is significant, but the spirit of the principle is more important.


=== Principle 1: What Is Good Architecture? ===
=== Principle 1: What Is Good Architecture? ===
# A good architecture is one that meets the needs of the stakeholders (especially the users) to their satisfaction, does not violate established principles of system architecture, and takes into account the relevant [[ilities]] by allowing for maintenance, evolution, further development, embedding, etc. as the customer requires.

# A good architecture is one that meets the needs of the stakeholders to their satisfaction, does not violate established principles of system architecture, and takes into account the relevant "ilities" by allowing for maintenance, evolution, further development, embedding, etc as the customer requires. Really good architectures are also elegant and intellectually pleasing to both the architect and other stakeholders, and hopefully provide an advantage (such as a competitive advantage) or utility to the customer.
# Really good architectures are also elegant (intellectually clean of unnecessary complexities or 'exceptions'), can direct a builder to cost-effective structures that can be completed within a reasonable time frame, conceptually pleasing to all stakeholders (especially the user), and provide some special advantage (such as a competitive advantage) or utility to the customer.


=== Principle 2: Robust Functionality Drives Essential Complexity ===
=== Principle 2: Robust Functionality Drives Essential Complexity ===

# Essential complexity is that which is essential to deliver functionality before gratuitous complexity slips in.
# Essential complexity is that which is essential to deliver functionality before gratuitous complexity slips in.
# Functionality drives complexity in any given concept.
# Functionality drives complexity in any given concept.
Line 29: Line 11:
# Therefore, it is the (often implicit) robust functionality which drives essential complexity.
# Therefore, it is the (often implicit) robust functionality which drives essential complexity.


=== Principle 3: Every System Is Made Up of Subsystems ===
=== Principle 3: Every System Consists of Subsystems ===
# Every system consists of subsystems.

# Every system is made up of subsystems.
# Alternatively, every system can be viewed as a part of another system, up to the whole universe.
# Alternatively, every system can be viewed as a part of another system, up to the whole universe.
# The interfaces between subsystems are a place of key leverage for the architect.
# The interfaces between subsystems are a place of key leverage for the architect.
Line 37: Line 18:


=== Principle 4: All Design Processes Should Involve Iteration ===
=== Principle 4: All Design Processes Should Involve Iteration ===

# All design processes can and should involve iteration.
# All design processes can and should involve iteration.
# Many systems are too complex, and many architects are not competent enough, to do a perfect job on the first pass.
# Many systems are too complex, and many architects are not competent enough, to do a perfect job on the first pass.
Line 44: Line 24:


=== Principle 5: Local versus Global Optimality ===
=== Principle 5: Local versus Global Optimality ===

# The optimal architecture or design for a given subsystem may result in sub-optimal global functionality of the bigger system.
# The optimal architecture or design for a given subsystem may result in sub-optimal global functionality of the bigger system.
# Therefore, the architect must be cognizant of the global system when optimizing and designing subsystems.
# Therefore, the architect must be cognizant of the global system when optimizing and designing subsystems.


=== Principle 6: Omnipresent Risk ===
=== Principle 6: Omnipresent Risk ===

# Every system has risks associated with it.
# Every system has risks associated with it.
# Risks can rarely be completely eliminated, but they can be noted and accommodated in the architecture.
# Risks can rarely be completely eliminated, but they can be noted and accommodated in the architecture.
Line 55: Line 33:


=== Principle 7: The Customer is the Judge of Quality ===
=== Principle 7: The Customer is the Judge of Quality ===

# An architecture that satisfies the architect but not the customer is useless.
# An architecture that satisfies the architect but not the customer is useless.
# The customer should be involved in the process as much as possible, giving frequent and honest feedback on all aspects of the system architecture.
# The customer should be involved in the process as much as possible, giving frequent and honest feedback on all aspects of the system architecture.
Line 61: Line 38:


=== Principle 8: Holistic Thinking ===
=== Principle 8: Holistic Thinking ===

# The architect should strive to think holistically about the system, its components, its usage contexts, and other relevant systems.
# The architect should strive to think holistically about the system, its components, its usage contexts, and other relevant systems.
# Holistic thinking is important in coming up with the best possible architecture.
# Holistic thinking is important in coming up with the best possible architecture.
Line 67: Line 43:


=== Principle 9: Modularity ===
=== Principle 9: Modularity ===

# One of the architect's roles is to ensure the best modularization of the system architecture, so as to allow for all the benefits of modularity: easier testing, easier accommodation of new requirements at the component level, and easier accommodation of new components at the system level.
# One of the architect's roles is to ensure the best modularization of the system architecture, so as to allow for all the benefits of modularity: easier testing, easier accommodation of new requirements at the component level, and easier accommodation of new components at the system level.


=== Principle 10: KISS ===
=== Principle 10: KISS ===
# The architect should strive to adhere to the KISS principle, "keep it simple, stupid." There are

# The architect should strive to adhere to the KISS principle, "keep it simple, stupid." There are other expansions of this acronym, and in fact this principle has [[KISS_principle|its own page]].
# The system architecture should be as simple as possible without conflicting with other design principles.
# Architectures that are more complex than necessary will result in sub-optimal systems.
# This principle is also known as [[Occam's Razor]].


=== Principle 11: Identity ===
=== Principle 11: Identity ===

# Everything that exists have a specific set of characteristics or identity that describe what it is.
# Everything that exists have a specific set of characteristics or identity that describe what it is.
# A system's identity is based on the identities of its constituent parts and how they interact together. In other words, an entity is more than the sum of its parts.
# A system's identity is based on the identities of its constituent parts and how they interact together. In other words, an entity is more than the sum of its parts.
Line 84: Line 54:


=== Principle 12: Conceptual Brilliance Doesn't Blind the Laws of Physics ===
=== Principle 12: Conceptual Brilliance Doesn't Blind the Laws of Physics ===

# A system architecture may be elegant, but the architect must not become so enamored with his or her work so as to lose track of the basic governing laws of the usage context in which the system operates.
# A system architecture may be elegant, but the architect must not become so enamored with his or her work so as to lose track of the basic governing laws of the usage context in which the system operates.
# Most of the time, the laws of physics must be obeyed: perhaps if the system is to be operated in a complete vacuum in outer space, some may be relaxed, but not all ;)
# Most of the time, the laws of physics must be obeyed: perhaps if the system is to be operated in a complete vacuum in outer space, some may be relaxed, but not all ;)
# Therefore, the architect and other stakeholders must not be blinded by the beauty (in their eyes) of their creation, and always review features with a pragrmatic and detail-oriented eye as well.
# Therefore, the architect and other stakeholders must not be blinded by the beauty (in their eyes) of their creation, and always review features with a pragrmatic and detail-oriented eye as well.
# The inspiration for this pri
# The inspiration for this principle comes from the [http://sunnyday.mit.edu/16.355/Augustine.htm 1996 Woodruff Distinguished Lecture], delivered by Norman R. Augustine, at the time the Chairman and Chief Executive Officer of [http://www.lockheedmartin.com Lockheed Martin Corporation].


=== Principle 13: Develop a common language for your team ===
=== Principle 13: Develop a common language for your team ===
#Not only is the job of the architect to drive ambiguity out of the system by defining the boundaries of the system, to creating the concept of the system, by allocating functionality and defining interfaces and abstractions, but the architect needs to be able to communicate these goals completely and clearly in the deliverables. Moreover, a common language is needed for continuous communication among team members throughout the developmental process. It is the architect’s job to define the language of the system.

#Not only is the job of the architect to drive ambiguity out of the system by defining the boundaries of the system, to creating the concept of the system, by allocating functionality and defining interfaces and abstractions, but the architect need to be able to communicate these goals completely and clearly in the deliverables. Moreover, a common language is needed for continuous communication among team members throughout the developmental process. It is the architect’s job to define the language of the system.
#The architect must not allow ambiguity to creep back into the system through difficulties in communication. The architect must create a basic method of communication, so that all team members can communicate clearly and accurately.
#The architect must not allow ambiguity to creep back into the system through difficulties in communication. The architect must create a basic method of communication, so that all team members can communicate clearly and accurately.
#On any given project, an architect has the responsibility of getting everyone on the same page so that they can speak about their system in common terms. One example from industry is the use of UML in many projects. UML provides a common language for teams to communicate about designs.
#On any given project, an architect has the responsibility of getting everyone on the same page so that they can speak about their system in common terms. One example from industry is the use of UML in many projects. UML provides a common language for teams to communicate about designs.


=== Principle 14: Garbage In, Garbage Out ===
=== Principle 14: Garbage In, Garbage Out ===

# The quality of a system architecture depends largely on the inputs provided to the architect.
# The quality of a system architecture depends largely on the inputs provided to the architect.
# The architect is partially responsible for ensuring high-fidelity inputs. For example, the architect should identify sources for user needs appropriately, and obtain user needs from them, rather than through other indirect or secondary sources.
# The architect is ''particularly'' responsible for ensuring high-fidelity inputs. For example, the architect must identify ''legitimate sources'' for user (and sponsor) ''needs'' appropriately (e.g., as distinguished from user— or sponsor— ''wants'' or ''wishes''; or, sponsor ''constraints''), and obtain user needs from ''them,'' rather than from uncertified personnel, or other indirect or secondary sources.
# If low-fidelity, noisy, inaccurate, or otherwise low-quality upstream data is provided to the architect, the system will suffer with a sub-optimal architecture.
# If low-fidelity, noisy, inaccurate, or otherwise low-quality upstream data is provided to the architect, the system may suffer from a sub-optimal architecture.
# Communications, cross-checking, and other data gathering and verification approaches can and should be used to ascertain the quality of data being used to design the system architecture.
# Good inter-personal communications, cross-checking, and other data gathering and verification approaches (e.g., the use of prototypes) can and should be used to ascertain the ''quality'' of data being used to design the system architecture.
:: ''See also [[GIGO]].''
# Inspired by the corresponding computer science [http://en.wikipedia.org/wiki/Garbage_in,_garbage_out principle].


=== Principle 15: Between the Idea and Reality Falls a Shadow ===
=== Principle 15: Between the Idea and Reality Falls a Shadow ===
Line 110: Line 77:


=== Principle 16: Must Do To Learn ===
=== Principle 16: Must Do To Learn ===

# No class or homework is sufficient for one to become a good system architect.
# No class or homework is sufficient for one to become a good system architect.
# A well-designed course, such as [[MIT]]'s ESD.34 System Architecture offering, teaches the important concepts, provides examples, and most of all, attempts to instill in the student a way of thinking appropriately about systems and system architecture.
# A well-designed course, such as [[MIT]]'s ESD.34 System Architecture offering, teaches the important concepts, provides examples, and most of all, attempts to instill in the student a way of thinking appropriately about systems and system architecture.
Line 119: Line 85:


=== Principle 17: Systemic Uncertainty ===
=== Principle 17: Systemic Uncertainty ===

# Decisions are almost always based on uncertain information and almost always depend on future things happening, future technologies, future values...
# Decisions are almost always based on uncertain information and almost always depend on future things happening, future technologies, future values...
# Accordingly, these decisions are best made using appropriately weighted systemic uncertainty measures.
# Accordingly, these decisions are best made using appropriately weighted systemic uncertainty measures.
Line 125: Line 90:


=== Principle 18: Standardized Process Improvement ===
=== Principle 18: Standardized Process Improvement ===

# A process should be standardized before it's improved, for maximum effect. If a process is not standardized the benefit from improvement will be reduced.
# A process should be standardized before it's improved, for maximum effect. If a process is not standardized the benefit from improvement will be reduced.
# Inspired by Thomas Speller, an MIT PhD student as of [[2005]], during a discussion for MIT's ESD.34 System Architecture course.
# Inspired by Thomas Speller, an MIT PhD student as of [[2005]], during a discussion for MIT's ESD.34 System Architecture course.


=== Principle 19: Early Defect Elimination ===
=== Principle 19: Early Defect Elimination ===

# Defects should be identified and eliminated as early as possible in the product development process.
# Defects should be identified and eliminated as early as possible in the product development process.
# The later you are in the process, the more expensive and/or difficult it is to fix defects appropriately.
# The later you are in the process, the more expensive and/or difficult it is to fix defects appropriately.
Line 136: Line 99:


=== Principle 20: Value is Identified Outside ===
=== Principle 20: Value is Identified Outside ===

# Most often, customers judge the value of a product, system, or service by looking at its external interfaces and their function and form. They frequently treat the product/system as a black box for their use and for their value.
# Most often, customers judge the value of a product, system, or service by looking at its external interfaces and their function and form. They frequently treat the product/system as a black box for their use and for their value.
# The architect should keep this mind, and maximize the perceived value of the system by focusing on its external interfaces, external form, and externally-delivered function. Of course, the architect must also keep the internal modules and sub-systems in mind.
# The architect should keep this mind, and maximize the perceived value of the system by focusing on its external interfaces, external form, and externally-delivered function. Of course, the architect must also keep the internal modules and sub-systems in mind.
# Inspired by the common proverb [http://www.bartleby.com/59/3/dontjudgeabo.html|"Don't judge a book by its cover"] which unfortunately many people do -- that's why the proverb is a proverb ;)
# Inspired by the common proverb [http://www.bartleby.com/59/3/dontjudgeabo.html|"Don't judge a book by its cover"] which unfortunately many people do -- that's why the proverb is a proverb ;)

== See also ==
*[[Systems architecture]] / [[Systems architect]]
*[[Software architecture]] / [[Software architect]]
*[[Hardware architecture]] / [[Hardware architect]]
*[[Systems engineering]] / [[Systems engineer]]
*[[Software engineering]] / [[Software engineer]]
*[[Requirements analysis]] / [[Requirements engineer]]
*[[Systems design]]
* [[DODAF]]
* [[FEAF]]
* [[MODAF]]
* [[TOGAF]]
* [[Zachman framework]]

Latest revision as of 19:42, 1 April 2007

This article lists several principles of system architecture. For each principle, a short description is provided, along with longer normative and descriptive explanations, and in some cases an example.

Principle 1: What Is Good Architecture?

[edit]
  1. A good architecture is one that meets the needs of the stakeholders (especially the users) to their satisfaction, does not violate established principles of system architecture, and takes into account the relevant ilities by allowing for maintenance, evolution, further development, embedding, etc. as the customer requires.
  2. Really good architectures are also elegant (intellectually clean of unnecessary complexities or 'exceptions'), can direct a builder to cost-effective structures that can be completed within a reasonable time frame, conceptually pleasing to all stakeholders (especially the user), and provide some special advantage (such as a competitive advantage) or utility to the customer.

Principle 2: Robust Functionality Drives Essential Complexity

[edit]
  1. Essential complexity is that which is essential to deliver functionality before gratuitous complexity slips in.
  2. Functionality drives complexity in any given concept.
  3. But “Functionality” is often defined as a surrogate for a much broader set of functions for which the product will actually be used.
  4. Therefore, it is the (often implicit) robust functionality which drives essential complexity.

Principle 3: Every System Consists of Subsystems

[edit]
  1. Every system consists of subsystems.
  2. Alternatively, every system can be viewed as a part of another system, up to the whole universe.
  3. The interfaces between subsystems are a place of key leverage for the architect.
  4. Therefore, the architect should spend a significant chunk of his/her efforts on designing and clearly specifying these interfaces.

Principle 4: All Design Processes Should Involve Iteration

[edit]
  1. All design processes can and should involve iteration.
  2. Many systems are too complex, and many architects are not competent enough, to do a perfect job on the first pass.
  3. Many data points only become available later in the architecture or design process.
  4. Therefore, every architecture design process should involve iteration: the process should be designed to be conducted over and over again until a satisfactory solution is reached.

Principle 5: Local versus Global Optimality

[edit]
  1. The optimal architecture or design for a given subsystem may result in sub-optimal global functionality of the bigger system.
  2. Therefore, the architect must be cognizant of the global system when optimizing and designing subsystems.

Principle 6: Omnipresent Risk

[edit]
  1. Every system has risks associated with it.
  2. Risks can rarely be completely eliminated, but they can be noted and accommodated in the architecture.
  3. A well-designed architecture is robust to these risks, can continue to function if they materialize.

Principle 7: The Customer is the Judge of Quality

[edit]
  1. An architecture that satisfies the architect but not the customer is useless.
  2. The customer should be involved in the process as much as possible, giving frequent and honest feedback on all aspects of the system architecture.
  3. While the architect may attempt to educate the customer to their mutual benefit, in cases of difference of opinion it is the customer's opinion that matters.

Principle 8: Holistic Thinking

[edit]
  1. The architect should strive to think holistically about the system, its components, its usage contexts, and other relevant systems.
  2. Holistic thinking is important in coming up with the best possible architecture.
  3. If the architect does not think holistically, he or she may miss important factors that should influence the system architecture.

Principle 9: Modularity

[edit]
  1. One of the architect's roles is to ensure the best modularization of the system architecture, so as to allow for all the benefits of modularity: easier testing, easier accommodation of new requirements at the component level, and easier accommodation of new components at the system level.

Principle 10: KISS

[edit]
  1. The architect should strive to adhere to the KISS principle, "keep it simple, stupid." There are

Principle 11: Identity

[edit]
  1. Everything that exists have a specific set of characteristics or identity that describe what it is.
  2. A system's identity is based on the identities of its constituent parts and how they interact together. In other words, an entity is more than the sum of its parts.
  3. Because system features are parts of a system identity, system designers need to understand the decompositions and the inner interactions of these parts in a system.

Principle 12: Conceptual Brilliance Doesn't Blind the Laws of Physics

[edit]
  1. A system architecture may be elegant, but the architect must not become so enamored with his or her work so as to lose track of the basic governing laws of the usage context in which the system operates.
  2. Most of the time, the laws of physics must be obeyed: perhaps if the system is to be operated in a complete vacuum in outer space, some may be relaxed, but not all ;)
  3. Therefore, the architect and other stakeholders must not be blinded by the beauty (in their eyes) of their creation, and always review features with a pragrmatic and detail-oriented eye as well.
  4. The inspiration for this pri

Principle 13: Develop a common language for your team

[edit]
  1. Not only is the job of the architect to drive ambiguity out of the system by defining the boundaries of the system, to creating the concept of the system, by allocating functionality and defining interfaces and abstractions, but the architect needs to be able to communicate these goals completely and clearly in the deliverables. Moreover, a common language is needed for continuous communication among team members throughout the developmental process. It is the architect’s job to define the language of the system.
  2. The architect must not allow ambiguity to creep back into the system through difficulties in communication. The architect must create a basic method of communication, so that all team members can communicate clearly and accurately.
  3. On any given project, an architect has the responsibility of getting everyone on the same page so that they can speak about their system in common terms. One example from industry is the use of UML in many projects. UML provides a common language for teams to communicate about designs.

Principle 14: Garbage In, Garbage Out

[edit]
  1. The quality of a system architecture depends largely on the inputs provided to the architect.
  2. The architect is particularly responsible for ensuring high-fidelity inputs. For example, the architect must identify legitimate sources for user (and sponsor) needs appropriately (e.g., as distinguished from user— or sponsor— wants or wishes; or, sponsor constraints), and obtain user needs from them, rather than from uncertified personnel, or other indirect or secondary sources.
  3. If low-fidelity, noisy, inaccurate, or otherwise low-quality upstream data is provided to the architect, the system may suffer from a sub-optimal architecture.
  4. Good inter-personal communications, cross-checking, and other data gathering and verification approaches (e.g., the use of prototypes) can and should be used to ascertain the quality of data being used to design the system architecture.
See also GIGO.

Principle 15: Between the Idea and Reality Falls a Shadow

[edit]
  1. The ability of state an idea simply does not neccessarily or frequently lead to simplicity in execution of said idea.
  2. The architecture concept or design may seem simple or logically flow on paper, but often times in reality the challenges of cultures, technology interfaces and other real world issues prove more problematic than anticipated.
  3. The difference between espoused ideas and the action of people often do not align. This is exemplified when individuals brief plans and everything sounds great but the environment in which the plan will be executed is not considered in the planning process. This generally results in significant problems and plan changes. An example of this is the difficulty of successfully implementing the business principle of buying cheaply and selling dearly to amass great fortune.

Principle 16: Must Do To Learn

[edit]
  1. No class or homework is sufficient for one to become a good system architect.
  2. A well-designed course, such as MIT's ESD.34 System Architecture offering, teaches the important concepts, provides examples, and most of all, attempts to instill in the student a way of thinking appropriately about systems and system architecture.
  3. However, such courses are no substitute for real experience. The only way to become a good system architect is to serve in this role on multiple projects, preferably (at least initially) working under the guidance of more experience architects.
  4. Prescriptive version: to be a good system architect, one must have been properly educated and had experience in the system architect role on at least one significant real-life projct.
  5. Descriptive version: a good system architect is one who is both educated and experienced in the role.
  6. Inspired by the ancient Chinese proverb: ""I hear and I forget, I see and I remember, I do and I understand."

Principle 17: Systemic Uncertainty

[edit]
  1. Decisions are almost always based on uncertain information and almost always depend on future things happening, future technologies, future values...
  2. Accordingly, these decisions are best made using appropriately weighted systemic uncertainty measures.
  3. Inspired by Thomas Speller, an MIT PhD student as of 2005, during a discussion for MIT's ESD.34 System Architecture course.

Principle 18: Standardized Process Improvement

[edit]
  1. A process should be standardized before it's improved, for maximum effect. If a process is not standardized the benefit from improvement will be reduced.
  2. Inspired by Thomas Speller, an MIT PhD student as of 2005, during a discussion for MIT's ESD.34 System Architecture course.

Principle 19: Early Defect Elimination

[edit]
  1. Defects should be identified and eliminated as early as possible in the product development process.
  2. The later you are in the process, the more expensive and/or difficult it is to fix defects appropriately.
  3. Inspired by Thomas Speller, an MIT PhD student as of 2005, during a discussion for MIT's ESD.34 System Architecture course.

Principle 20: Value is Identified Outside

[edit]
  1. Most often, customers judge the value of a product, system, or service by looking at its external interfaces and their function and form. They frequently treat the product/system as a black box for their use and for their value.
  2. The architect should keep this mind, and maximize the perceived value of the system by focusing on its external interfaces, external form, and externally-delivered function. Of course, the architect must also keep the internal modules and sub-systems in mind.
  3. Inspired by the common proverb "Don't judge a book by its cover" which unfortunately many people do -- that's why the proverb is a proverb ;)

See also

[edit]