Jump to content

Chaos model: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m Deleted merge tag
Citation bot (talk | contribs)
Alter: title. | Use this bot. Report bugs. | Suggested by BrownHairedGirl | #UCB_webform 1320/2011
 
(27 intermediate revisions by 22 users not shown)
Line 1: Line 1:
In [[computing]], the '''Chaos model''' is a structure of [[software development]]. Its creator, L.B.S. Raccoon, noted that project management models such as the [[spiral model]] and [[waterfall model]], while good at managing schedules and staff, didn't provide methods to fix bugs or solve other technical programs. At the same time, programming methodologies, while effective at fixing bugs and solving technical problems, do not help in managing deadlines or responding to customer requests. The structure attempts to bridge this gap. [[Chaos theory]] was used as a tool to help understand these issues.<ref>[[http://portal.acm.org/citation.cfm?id=225914]]</ref>.
In [[computing]], the '''chaos model''' is a structure of [[software development]]. Its creator, who used the pseudonym L.B.S. Raccoon,<ref>{{cite web |url=http://tech.dir.groups.yahoo.com/group/scrumdevelopment/message/33620 |title=Scrumdevelopment : Message: Re: &#91;scrumdevelopment&#93; Re: Agile triangulation |accessdate=2013-02-08 |url-status=dead |archiveurl=https://archive.today/20130412054525/http://tech.dir.groups.yahoo.com/group/scrumdevelopment/message/33620 |archivedate=2013-04-12 }}</ref> noted that project management models such as the [[spiral model]] and [[waterfall model]], while good at managing schedules and staff, didn't provide methods to fix bugs or solve other technical problems. At the same time, programming methodologies, while effective at fixing bugs and solving technical problems, do not help in managing deadlines or responding to customer requests. The structure attempts to bridge this gap. [[Chaos theory]] was used as a tool to help understand these issues.<ref>ACM Digital Library, [http://portal.acm.org/citation.cfm?id=225914 The chaos model and the chaos cycle], ACM SIGSOFT Software Engineering Notes, Volume 20 Issue 1, Jan. 1995</ref>


==Software development life cycle==
==Software development life cycle==
Line 12: Line 12:
One important change in perspective is whether projects can be thought of as whole units, or must be thought of in pieces. Nobody writes tens of thousands of lines of code in one sitting. They write small pieces, one line at a time, verifying that the small pieces work. Then they build up from there. The behavior of a complex system emerges from the combined behavior of the smaller building blocks.
One important change in perspective is whether projects can be thought of as whole units, or must be thought of in pieces. Nobody writes tens of thousands of lines of code in one sitting. They write small pieces, one line at a time, verifying that the small pieces work. Then they build up from there. The behavior of a complex system emerges from the combined behavior of the smaller building blocks.


==Chaos Strategy==
==Chaos strategy==
The chaos strategy is a strategy of software development based on the chaos model. The main rule is ''always resolve the most important issue first''.
The chaos strategy is a strategy of software development based on the chaos model. The main rule is ''always resolve the most important issue first''.


Line 19: Line 19:
** ''Big'' issues provide value to users as working functionality.
** ''Big'' issues provide value to users as working functionality.
** ''Urgent'' issues are timely in that they would otherwise hold up other work.
** ''Urgent'' issues are timely in that they would otherwise hold up other work.
** ''Robust'' issues are trusted and tested. Developers can then safely focus their attention elsewhere.
** ''Robust'' issues are trusted and tested when resolved. Developers can then safely focus their attention elsewhere.
* To ''resolve'' means to bring it to a point of stability.
* To ''resolve'' means to bring it to a point of stability.


Line 25: Line 25:
way to do the work.
way to do the work.


The chaos strategy was inspired by [[Go (board game)|Go]] strategy.
The chaos strategy was inspired by [[Go (board game)|Go]] strategy.{{Citation needed|date=October 2020}}


==Connections with Chaos theory==
==Connections with chaos theory==
There are several tie-ins with [[chaos theory]].
There are several tie-ins with [[chaos theory]].


* The chaos model may help explain why software tends to be so unpredictable.
* The chaos model may help explain why software tends to be so unpredictable.
* It explains why high-level concepts like [[Computer_architecture|architecture]] cannot be treated independently of low-level lines of code.
* It explains why high-level concepts like [[software architecture|architecture]] cannot be treated independently of low-level lines of code.
* It provides a hook for explaining what to do next, in terms of the [[chaos strategy]].
* It provides a hook for explaining what to do next, in terms of the chaos strategy.


==See also==
==See also==
Line 40: Line 40:
==References==
==References==
{{reflist}}
{{reflist}}

===Further reading===
==Further reading==
* Roger Pressman (1997) Software Engineering: A Practitioner's Approach 4th edition, pages 29-30, McGraw Hill.
* Roger Pressman (1997) Software Engineering: A Practitioner's Approach 4th edition, pages 29–30, McGraw Hill.
* Raccoon (1995) [http://www.swcp.com/raccoon/papers/chaos93.wpd The Chaos Model and the Chaos Life Cycle], in ACM Software Engineering Notes, Volume 20, Number 1, Pages 55 to 66, January 1995, ACM Press.
* Raccoon (1995) [http://www.swcp.com/raccoon/papers/chaos93.wpd The Chaos Model and the Chaos Life Cycle], in ACM Software Engineering Notes, Volume 20, Number 1, Pages 55 to 66, January 1995, ACM Press.


{{DEFAULTSORT:Chaos Model}}

{{soft-eng-stub}}

[[Category:Software development process]]
[[Category:Software development process]]

Latest revision as of 12:25, 20 August 2022

In computing, the chaos model is a structure of software development. Its creator, who used the pseudonym L.B.S. Raccoon,[1] noted that project management models such as the spiral model and waterfall model, while good at managing schedules and staff, didn't provide methods to fix bugs or solve other technical problems. At the same time, programming methodologies, while effective at fixing bugs and solving technical problems, do not help in managing deadlines or responding to customer requests. The structure attempts to bridge this gap. Chaos theory was used as a tool to help understand these issues.[2]

Software development life cycle

[edit]

The chaos model notes that the phases of the life cycle apply to all levels of projects, from the whole project to individual lines of code.

  • The whole project must be defined, implemented, and integrated.
  • Systems must be defined, implemented, and integrated.
  • Modules must be defined, implemented, and integrated.
  • Functions must be defined, implemented, and integrated.
  • Lines of code are defined, implemented and integrated.

One important change in perspective is whether projects can be thought of as whole units, or must be thought of in pieces. Nobody writes tens of thousands of lines of code in one sitting. They write small pieces, one line at a time, verifying that the small pieces work. Then they build up from there. The behavior of a complex system emerges from the combined behavior of the smaller building blocks.

Chaos strategy

[edit]

The chaos strategy is a strategy of software development based on the chaos model. The main rule is always resolve the most important issue first.

  • An issue is an incomplete programming task.
  • The most important issue is a combination of big, urgent, and robust.
    • Big issues provide value to users as working functionality.
    • Urgent issues are timely in that they would otherwise hold up other work.
    • Robust issues are trusted and tested when resolved. Developers can then safely focus their attention elsewhere.
  • To resolve means to bring it to a point of stability.

The chaos strategy resembles the way that programmers work toward the end of a project, when they have a list of bugs to fix and features to create. Usually someone prioritizes the remaining tasks, and the programmers fix them one at a time. The chaos strategy states that this is the only valid way to do the work.

The chaos strategy was inspired by Go strategy.[citation needed]

Connections with chaos theory

[edit]

There are several tie-ins with chaos theory.

  • The chaos model may help explain why software tends to be so unpredictable.
  • It explains why high-level concepts like architecture cannot be treated independently of low-level lines of code.
  • It provides a hook for explaining what to do next, in terms of the chaos strategy.

See also

[edit]

References

[edit]
  1. ^ "Scrumdevelopment : Message: Re: [scrumdevelopment] Re: Agile triangulation". Archived from the original on 2013-04-12. Retrieved 2013-02-08.
  2. ^ ACM Digital Library, The chaos model and the chaos cycle, ACM SIGSOFT Software Engineering Notes, Volume 20 Issue 1, Jan. 1995

Further reading

[edit]
  • Roger Pressman (1997) Software Engineering: A Practitioner's Approach 4th edition, pages 29–30, McGraw Hill.
  • Raccoon (1995) The Chaos Model and the Chaos Life Cycle, in ACM Software Engineering Notes, Volume 20, Number 1, Pages 55 to 66, January 1995, ACM Press.