Software design explained

Software design is the process of conceptualizing how a software system will work before it is implemented or modified. [1] Software design also refers to the direct result of the design process the concepts of how the software will work which consists of both design documentation and undocumented concepts.

Software design usually is directed by goals for the resulting system and involves problem-solving and planning including both high-level software architecture and low-level component and algorithm design.

In terms of the waterfall development process, software design is the activity of following requirements specification and before coding.[2]

General process

The design process enables a designer to model various aspects of a software system before it exists.

Creativity, past experience, a sense of what makes "good" software, and a commitment to quality are success factors for a competent design. However, the design process is not always a straightforward procedure.

The software design model can be compared to an architected plan for a house. High-level plans represent the totality of the house (e.g., a three-dimensional rendering of the house). Lower-level plans provide guidance for constructing each detail (e.g., the plumbing lay). Similarly, the software design model provides a variety of views of the proposed software solution.

Value

Software design documentation may be reviewed or presented to allow constraints, specifications and even requirements to be adjusted prior to coding. Redesign may occur after a review of a programmed simulation or prototype. It is possible to design software in the process of coding, without a plan or requirement analysis,[3] but for more complex projects this is less feasible. A separate design prior to coding allows for multidisciplinary designers and subject-matter experts (SMEs) to collaborate with programmers in order to produce software that is useful and technically sound.

Requirements analysis

One component of software design is software requirements analysis (SRA). SRA is a part of the software development process that lists specifications used in software engineering.

The output of the analysis is smaller problems to solve.In contrast, the design focuses on capabilities, and thus multiple designs for the same problem can exist. Depending on the environment, the design often varies, whether it is created from reliable frameworks or implemented with suitable design patterns.

Artifacts

A design process may include the production of artifacts such as flow chart, use case, Pseudocode, Unified Modeling Language model and other Fundamental modeling concepts. For user centered software, design may involve user experience design yielding a storyboard to help determine those specifications.

Sometimes the output of a design process is design documentation.

Design principles

Basic design principles enable a software engineer to navigate the design process. Davis[4] suggests a set of principles for software design, which have been adapted and extended in the following list:

Design concepts

Design concepts provide a designer with a foundation from which more sophisticated methods can be applied. A set of design concepts has evolved including:

In his object model, Grady Booch mentions Abstraction, Encapsulation, Modularisation, and Hierarchy as fundamental software design principles.[5] The acronym PHAME (Principles of Hierarchy, Abstraction, Modularisation, and Encapsulation) is sometimes used to refer to these four fundamental principles.[6]

Design considerations

There are many aspects to consider in the design of a piece of software. The importance of each consideration should reflect the goals and expectations that the software is being created to meet. Some of these aspects are:

Modeling language

A modeling language can be used to express information, knowledge or systems in a structure that is defined by a consistent set of rules. These rules are used for interpretation of the components within the structure. A modeling language can be graphical or textual. Examples of graphical modeling languages for software design include:

Design patterns

A software designer may identify a design aspect which has been visited and perhaps even solved by others in the past. A template or pattern describing a solution to a common problem is known as a design pattern. The reuse of such patterns can increase software development velocity.[10]

Code as design

The difficulty of using the term "design" in relation to software is that in some senses, the source code of a program is the design for the program that it produces. To the extent that this is true, "software design" refers to the design of the design. Edsger W. Dijkstra referred to this layering of semantic levels as the "radical novelty" of computer programming,[11] and Donald Knuth used his experience writing TeX to describe the futility of attempting to design a program prior to implementing it:

See also

References

^Book: Roger S. Pressman . Software engineering: a practitioner's approach . 2001 . McGraw-Hill . 0-07-365578-3 .

Notes and References

  1. Ralph, P. and Wand, Y. (2009). A proposal for a formal definition of the design concept. In Lyytinen, K., Loucopoulos, P., Mylopoulos, J., and Robinson, W., editors, Design Requirements Workshop (LNBIP 14), pp. 103–136. Springer-Verlag, p. 109 .
  2. Freeman. Peter. David Hart . 14331332. A Science of design for software-intensive systems. Communications of the ACM. 2004. 47. 8. 19–21 [20]. 10.1145/1012037.1012054 .
  3. Ralph, P., and Wand, Y. A Proposal for a Formal Definition of the Design Concept. In, Lyytinen, K., Loucopoulos, P., Mylopoulos, J., and Robinson, W., (eds.), Design Requirements Engineering: A Ten-Year Perspective: Springer-Verlag, 2009, pp. 103-136
  4. Davis, A:"201 Principles of Software Development", McGraw Hill, 1995.
  5. Book: Booch. Grady. Object-Oriented Analysis and Design with Applications. 2004. Addison Wesley. MA, US. 0-201-89551-X. 3rd. 30 January 2015. etal.
  6. Book: Suryanarayana. Girish. Refactoring for Software Design Smells. November 2014. Morgan Kaufmann. 978-0128013977. 258.
  7. Book: Carroll. John. Scenario-Based Design: Envisioning Work and Technology in System Development. 1995. John Wiley & Sons. New York. 0471076597.
  8. Book: Building Serverless Applications on Knative . O'Reilly Media . 9781098142049.
  9. Book: Bell, Michael. Service-Oriented Modeling: Service Analysis, Design, and Architecture. 2008 . Wiley & Sons. 978-0-470-14111-3 . Introduction to Service-Oriented Modeling.
  10. Web site: C# 3.0 Design Patterns: Use the Power of C# 3.0 to Solve Real-World Problems . Judith Bishop . C# Books from O'Reilly Media . If you want to speed up the development of your .NET applications, you're ready for C# design patterns -- elegant, accepted and proven ways to tackle common programming problems. . 2012-05-15.
  11. Web site: On the cruelty of really teaching computing science. Dijkstra. E. W.. Edsger_Dijkstra. 1988. 2014-01-10.