Misplaced Pages

COCOMO: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 09:24, 30 January 2018 edit117.232.96.253 (talk) History← Previous edit Latest revision as of 05:22, 6 November 2023 edit undoInternetArchiveBot (talk | contribs)Bots, Pending changes reviewers5,388,326 edits Rescuing 1 sources and tagging 0 as dead.) #IABot (v2.0.9.5 
(56 intermediate revisions by 42 users not shown)
Line 1: Line 1:
{{Short description|Software cost estimation model}}
{{distinguish|Kokomo (disambiguation){{!}}Kokomo}}
{{distinguish|Kokomo (disambiguation){{!}}Kokomo|Docomo}}
{{refimprove|date=October 2015}} {{refimprove|date=October 2015}}


The '''Constructive Cost Model''' ('''COCOMO''') is a procedural ] developed by ]. The model parameters are derived from fitting a ] formula using data from historical projects (61 projects for COCOMO 81 and 163 projects for COCOMO II). The '''Constructive Cost Model''' ('''COCOMO''') is a procedural ] developed by ]. The model parameters are derived from fitting a ] formula using data from historical projects (63 projects for COCOMO 81 and 163 projects for COCOMO II).


== History ==
COCOMO is used to estimate size, effort and duration based on the cost of the software.


The constructive cost model was developed by Barry W. Boehm in the late 1970s<ref>{{cite web
== History == mukesh mukesh mukesh
|url=http://ece.arizona.edu/~ece473/readings/14-Software%20Estimating%20Technology.doc

The constructive cost model was developed by Barry W. Boehm in the late 1970s<ref>{{cite web
|url=http://ece.arizona.edu/~ece473/readings/14-Software%20Estimating%20Technology.doc
|title=Software Estimating Technology: A Survey |title=Software Estimating Technology: A Survey
|last=Stutzke |last=Stutzke
|first=Richard |first=Richard
|accessdate=9 Oct 2016 |accessdate=9 Oct 2016
|archive-date=28 March 2020
}}{{DOClink}}</ref> and published in Boehm's 1981 book ''Software Engineering Economics''<ref>{{cite book
|archive-url=https://web.archive.org/web/20200328141813/https://uweb.engr.arizona.edu/~ece473/readings/14-Software%20Estimating%20Technology.doc
|url-status=dead
}}{{DOClink}}</ref> and published in Boehm's 1981 book ''Software Engineering Economics''<ref>{{cite book
|title = Software Engineering Economics |title = Software Engineering Economics
|url = https://archive.org/details/softwareengineer0000boeh
|url-access = registration
|last = Boehm |last = Boehm
|first = Barry |first = Barry
Line 22: Line 26:
|isbn = 0-13-822122-7}}</ref> as a model for estimating effort, cost, and schedule for software projects. It drew on a study of 63 projects at ] Aerospace where Boehm was Director of Software Research and Technology. The study examined projects ranging in size from 2,000 to 100,000 ], and programming languages ranging from ] to ]. These projects were based on the ] of software development which was the prevalent software development process in 1981. |isbn = 0-13-822122-7}}</ref> as a model for estimating effort, cost, and schedule for software projects. It drew on a study of 63 projects at ] Aerospace where Boehm was Director of Software Research and Technology. The study examined projects ranging in size from 2,000 to 100,000 ], and programming languages ranging from ] to ]. These projects were based on the ] of software development which was the prevalent software development process in 1981.


References to this model typically call it ''COCOMO 81''. In 1995 ''COCOMO II'' was developed and finally published in 2000 in the book ''Software Cost Estimation with COCOMO II''.<ref name="cocomo2">], Chris Abts, A. Winsor Brown, Sunita Chulani, Bradford K. Clark, Ellis Horowitz, Ray Madachy, Donald J. Reifer, and Bert Steece. '']'' (with CD-ROM). Englewood Cliffs, NJ:Prentice-Hall, 2000. {{ISBN|0-13-026692-2}}</ref> COCOMO II is the successor of COCOMO 81 and is claimed to be better suited for estimating modern software development projects; providing support for more recent ]es and was tuned using a larger database of 161 projects. The need for the new model came as software development technology moved from mainframe and overnight batch processing to desktop development, code reusability, and the use of off-the-shelf software components. This article refers to ''COCOMO 81''. References to this model typically call it ''COCOMO 81''. In 1995 ''COCOMO II'' was developed and finally published in 2000 in the book ''Software Cost Estimation with COCOMO II''.<ref name="cocomo2">], Chris Abts, A. Winsor Brown, Sunita Chulani, Bradford K. Clark, Ellis Horowitz, Ray Madachy, Donald J. Reifer, and Bert Steece. '']'' (with CD-ROM). Englewood Cliffs, NJ:Prentice-Hall, 2000. {{ISBN|0-13-026692-2}}</ref> COCOMO II is the successor of COCOMO 81 and is claimed to be better suited for estimating modern software development projects; providing support for more recent ]es and was tuned using a larger database of 161 projects. The need for the new model came as software development technology moved from mainframe and overnight batch processing to desktop development, code reusability, and the use of off-the-shelf software components.


COCOMO consists of a hierarchy of three increasingly detailed and accurate forms. The first level, ''Basic COCOMO'' is good for quick, early, rough order of magnitude estimates of software costs, but its accuracy is limited due to its lack of factors to account for difference in project attributes (''Cost Drivers''). ''Intermediate COCOMO'' takes these Cost Drivers into account and ''Detailed COCOMO'' additionally accounts for the influence of individual project phases. COCOMO consists of a hierarchy of three increasingly detailed and accurate forms. The first level, ''Basic COCOMO'' is good for quick, early, rough order of magnitude estimates of software costs, but its accuracy is limited due to its lack of factors to account for difference in project attributes (''Cost Drivers''). ''Intermediate COCOMO'' takes these Cost Drivers into account and ''Detailed COCOMO'' additionally accounts for the influence of individual project phases.
Last one is Complete COCOMO model which addresses the shortcomings of both basic & intermediate.


== Basic COCOMO == == Intermediate COCOMOs ==
''Intermediate COCOMO'' computes software development effort as function of program size and a set of "cost drivers" that include subjective assessment of product, hardware, personnel and project attributes. This extension considers a set of four "cost drivers", each with a number of subsidiary attributes:-


* Product attributes
Basic COCOMO compute software development effort (and cost) as a function of program size. Program size is expressed in estimated thousands of source lines of code (], ]).
** Required software reliability extent
** Size of application database
** Complexity of the product
* Hardware attributes
** Run-time performance constraints
** Memory constraints
** Volatility of the virtual machine environment
** Required turnabout time
* Personnel attributes
** Analyst capability
** Software engineering capability
** Applications experience
** Virtual machine experience
** Programming language experience
* Project attributes
** Use of software tools
** Application of software engineering methods
** Required development schedule


Each of the 15 attributes receives a rating on a six-point scale that ranges from "very low" to "extra high" (in importance or value). An effort multiplier from the table below applies to the rating. The product of all effort multipliers results in an ''effort adjustment factor (EAF)''. Typical values for EAF range from 0.9 to 1.4.
COCOMO applies to three classes of software projects:
* Organic projects - "small" teams with "good" experience working with "less than rigid" requirements
* Semi-detached projects - "medium" teams with mixed experience working with a mix of rigid and less than rigid requirements
* Embedded projects - developed within a set of "tight" constraints. It is also combination of organic and semi-detached projects.(hardware, software, operational, ...)


{| class="wikitable"
The basic COCOMO equations take the form
! rowspan="2" style="vertical-align:bottom" |Cost&nbsp;Drivers
:Effort Applied (E) = a<sub>b</sub>(KLOC)<sup>b<sub>b</sub></sup> ]s ]
!colspan="6"|Ratings
:Development Time (D) = c<sub>b</sub>(Effort Applied)<sup>d<sub>b</sub></sup>
:People required (P) = Effort Applied / Development Time
where,
KLOC is the estimated number of delivered lines (expressed in thousands ) of code for project. The coefficients ''a<sub>b</sub>'', ''b<sub>b</sub>'', ''c<sub>b</sub>'' and ''d<sub>b</sub>'' are given in the following table (note: the values listed below are from the original analysis, with a modern reanalysis<ref>{{cite web|url=http://shape-of-code.coding-guidelines.com/2016/05/19/cocomo-how-not-to-fit-a-model-to-data/|title=COCOMO: Not worth serious attention|publisher=The Shape of Code|date=19 May 2016|accessdate=4 November 2016}}</ref> producing different values):

{| class="wikitable" mukesh mukesh mukesh
! Software project
! ''a''<sub>''b''</sub>
! ''b''<sub>''b''</sub>
! ''c''<sub>''b''</sub>
! ''d''<sub>''b''</sub>
|- |-
|align="center" valign="bottom" width="10%"|Very Low
| Organic
|align="center" valign="bottom" width="10%"|Low
| 2.4
| 1.05
| 2.5
| 0.38
|-
| Semi-detached
| 3.0
| 1.12
| 2.5
| 0.35
|-
| Embedded
| 3.6
| 1.20
| 2.5
| 0.32
|}

Basic COCOMO is good for quick estimate of software costs. However it does not account for differences in hardware constraints, personnel quality and experience, use of modern tools and techniques, and so on.

==
|align="center" valign="bottom" width="10%"|Nominal |align="center" valign="bottom" width="10%"|Nominal
|align="center" valign="bottom" width="10%"|High |align="center" valign="bottom" width="10%"|High
Line 76: Line 67:
|align="center" valign="bottom" width="10%"|Extra High |align="center" valign="bottom" width="10%"|Extra High
|- |-
!align="left"|Product&nbsp;attributes ! {{rh}} colspan=7 |Product&nbsp;attributes
|- |-
|Required&nbsp;software&nbsp;reliability | Required&nbsp;software&nbsp;reliability
|align="center"|0.75 |align="center"|0.75
|align="center"|0.88 |align="center"|0.88
Line 86: Line 77:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Size&nbsp;of&nbsp;application&nbsp;database | Size&nbsp;of&nbsp;application&nbsp;database
|align="center"|&nbsp; |align="center"|&nbsp;
|align="center"|0.94 |align="center"|0.94
Line 94: Line 85:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Complexity&nbsp;of&nbsp;the&nbsp;product | Complexity&nbsp;of&nbsp;the&nbsp;product
|align="center"|0.70 |align="center"|0.70
|align="center"|0.85 |align="center"|0.85
Line 102: Line 93:
|align="center"|1.65 |align="center"|1.65
|- |-
!align="left"|Hardware&nbsp;attributes ! {{rh}} colspan=7 |Hardware&nbsp;attributes
|- |-
|Run-time&nbsp;performance&nbsp;constraints | Run-time&nbsp;performance&nbsp;constraints
|align="center"|&nbsp; |align="center"|&nbsp;
|align="center"|&nbsp; |align="center"|&nbsp;
Line 112: Line 103:
|align="center"|1.66 |align="center"|1.66
|- |-
|Memory&nbsp;constraints | Memory&nbsp;constraints
|align="center"|&nbsp; |align="center"|&nbsp;
|align="center"|&nbsp; |align="center"|&nbsp;
Line 120: Line 111:
|align="center"|1.56 |align="center"|1.56
|- |-
|Volatility&nbsp;of&nbsp;the&nbsp;virtual&nbsp;machine&nbsp;environment | Volatility&nbsp;of&nbsp;the&nbsp;virtual&nbsp;machine&nbsp;environment
|align="center"|&nbsp; |align="center"|&nbsp;
|align="center"|0.87 |align="center"|0.87
Line 128: Line 119:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Required&nbsp;turnabout&nbsp;time | Required&nbsp;turnabout&nbsp;time
|align="center"|&nbsp; |align="center"|&nbsp;
|align="center"|0.87 |align="center"|0.87
Line 136: Line 127:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
!align="left"|Personnel&nbsp;attributes ! {{rh}} colspan=7 |Personnel&nbsp;attributes
|- |-
|Analyst capability | Analyst capability
|align="center"|1.46 |align="center"|1.46
|align="center"|1.19 |align="center"|1.19
Line 146: Line 137:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Applications&nbsp;experience | Applications&nbsp;experience
|align="center"|1.29 |align="center"|1.29
|align="center"|1.13 |align="center"|1.13
Line 154: Line 145:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Software&nbsp;engineer&nbsp;capability | Software&nbsp;engineer&nbsp;capability
|align="center"|1.42 |align="center"|1.42
|align="center"|1.17 |align="center"|1.17
Line 162: Line 153:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Virtual&nbsp;machine&nbsp;experience | Virtual&nbsp;machine&nbsp;experience
|align="center"|1.21 |align="center"|1.21
|align="center"|1.10 |align="center"|1.10
Line 170: Line 161:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Programming&nbsp;language&nbsp;experience | Programming&nbsp;language&nbsp;experience
|align="center"|1.14 |align="center"|1.14
|align="center"|1.07 |align="center"|1.07
Line 178: Line 169:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
!align="left"|Project&nbsp;attributes ! {{rh}} colspan=7 |Project&nbsp;attributes
|- |-
|Application&nbsp;of&nbsp;software&nbsp;engineering&nbsp;methods | Application&nbsp;of&nbsp;software&nbsp;engineering&nbsp;methods
|align="center"|1.24 |align="center"|1.24
|align="center"|1.10 |align="center"|1.10
Line 188: Line 179:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Use&nbsp;of&nbsp;software&nbsp;tools | Use&nbsp;of&nbsp;software&nbsp;tools
|align="center"|1.24 |align="center"|1.24
|align="center"|1.10 |align="center"|1.10
Line 196: Line 187:
|align="center"|&nbsp; |align="center"|&nbsp;
|- |-
|Required&nbsp;development&nbsp;schedule | Required&nbsp;development&nbsp;schedule
|align="center"|1.23 |align="center"|1.23
|align="center"|1.08 |align="center"|1.08
Line 207: Line 198:
The Intermediate Cocomo formula now takes the form: The Intermediate Cocomo formula now takes the form:


:'''E=''a''<sub>''i''</sub>(KLoC)<sup>''(b''<sub>''i''</sub>'')''</sup>(EAF)''' :{{math|1=''E'' = {{abbr|''a''<sub>''i''</sub>|coefficient}}(KLoC){{sup|{{abbr|''b''{{sub|''i''}}|exponent}}}}(EAF)}}


where E is the effort applied in person-months, '''KLoC''' is the estimated number of thousands of delivered lines of code for the project, and '''EAF''' is the factor calculated above. The coefficient '''a<sub>i</sub>''' and the exponent '''b<sub>i</sub>''' are given in the next table. where ''E'' is the effort applied in person-months, '''KLoC''' is the estimated number of thousands of delivered lines of code for the project, and '''EAF''' is the factor calculated above. The coefficient ''a<sub>i</sub>'' and the exponent ''b<sub>i</sub>'' are given in the next table.


:{| class="wikitable" :{| class="wikitable"
Line 215: Line 206:
!width="20%"|a<sub>i</sub> !width="20%"|a<sub>i</sub>
!width="20%"|b<sub>i</sub> !width="20%"|b<sub>i</sub>
!width="20%"|c<sub>i</sub>
|- |-
|Organic ! Organic
|align="center"|3.2 |align="center"|3.2
|align="center"|1.05 |align="center"|1.05
|align="center"|0.38
|- |-
|Semi-detached ! Semi-detached
|align="center"|3.0 |align="center"|3.0
|align="center"|1.12 |align="center"|1.12
|align="center"|0.35
|- |-
|Embedded ! Embedded
|align="center"|2.8 |align="center"|2.8
|align="center"|1.20 |align="center"|1.20
|align="center"|0.32
|} |}


The Development time '''D''' calculation uses '''E''' in the same way as in the Basic COCOMO. The Development time ''D'' and also the most effective number of Persons ''P'' calculation uses ''E'' in the same way as in the Basic COCOMO:


:{{math|1=''D'' = 2.5 ''E''{{sup|''c''{{sub|''i''}}}}}}
== Detailed COCOMO ==
:{{tmath|1=P = E/D}}


Note that in addition to the EAF, the parameter ''a<sub>i</sub>'' is different in ''Intermediate COCOMO'' from the Basic model:
Detailed COCOMO incorporates all characteristics of the intermediate version with an assessment of the cost driver's impact on each step (analysis, design, etc.) of the software engineering process.


:{| class="wikitable"
The detailed model uses different effort multipliers for each cost driver attribute. These '''Phase Sensitive''' effort multipliers are each to determine the amount of effort required to complete each phase.
!Software&nbsp;project
In detailed cocomo, the whole software is divided into different modules and then we apply COCOMO in different modules to estimate effort and then sum the effort.
!width="20%"|''a<sub>b</sub>''

|-
The effort is calculated as a function of program size and a set of cost drivers are given according to each phase of the software life cycle.
! Organic

|align="center"|2.4
A Detailed project schedule is never static.
|-
! Semi-detached
|align="center"|3.0
|-
! Embedded
|align="center"|3.6
|}


The parameters ''b'' and ''c'' are the same in both models.
The Six phases of detailed COCOMO are:-
* planning and requirements
* system design
* detailed design
* module code and test
* integration and test
* Cost Constructive model


== See also == == See also ==
Line 261: Line 258:
* ] * ]
* ] * ]
* ]
*


== References == == References ==
Line 283: Line 280:
== External links == == External links ==
<!-- Do not add links to commercial products here - it will be deleted as SPAM --> <!-- Do not add links to commercial products here - it will be deleted as SPAM -->
* on tera-PROMISE * on tera-PROMISE
* obtains a different value for the Organic exponent. * obtains a different value for the Organic exponent.



Latest revision as of 05:22, 6 November 2023

Software cost estimation model Not to be confused with Kokomo or Docomo.
This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "COCOMO" – news · newspapers · books · scholar · JSTOR (October 2015) (Learn how and when to remove this message)

The Constructive Cost Model (COCOMO) is a procedural software cost estimation model developed by Barry W. Boehm. The model parameters are derived from fitting a regression formula using data from historical projects (63 projects for COCOMO 81 and 163 projects for COCOMO II).

History

The constructive cost model was developed by Barry W. Boehm in the late 1970s and published in Boehm's 1981 book Software Engineering Economics as a model for estimating effort, cost, and schedule for software projects. It drew on a study of 63 projects at TRW Aerospace where Boehm was Director of Software Research and Technology. The study examined projects ranging in size from 2,000 to 100,000 lines of code, and programming languages ranging from assembly to PL/I. These projects were based on the waterfall model of software development which was the prevalent software development process in 1981.

References to this model typically call it COCOMO 81. In 1995 COCOMO II was developed and finally published in 2000 in the book Software Cost Estimation with COCOMO II. COCOMO II is the successor of COCOMO 81 and is claimed to be better suited for estimating modern software development projects; providing support for more recent software development processes and was tuned using a larger database of 161 projects. The need for the new model came as software development technology moved from mainframe and overnight batch processing to desktop development, code reusability, and the use of off-the-shelf software components.

COCOMO consists of a hierarchy of three increasingly detailed and accurate forms. The first level, Basic COCOMO is good for quick, early, rough order of magnitude estimates of software costs, but its accuracy is limited due to its lack of factors to account for difference in project attributes (Cost Drivers). Intermediate COCOMO takes these Cost Drivers into account and Detailed COCOMO additionally accounts for the influence of individual project phases. Last one is Complete COCOMO model which addresses the shortcomings of both basic & intermediate.

Intermediate COCOMOs

Intermediate COCOMO computes software development effort as function of program size and a set of "cost drivers" that include subjective assessment of product, hardware, personnel and project attributes. This extension considers a set of four "cost drivers", each with a number of subsidiary attributes:-

  • Product attributes
    • Required software reliability extent
    • Size of application database
    • Complexity of the product
  • Hardware attributes
    • Run-time performance constraints
    • Memory constraints
    • Volatility of the virtual machine environment
    • Required turnabout time
  • Personnel attributes
    • Analyst capability
    • Software engineering capability
    • Applications experience
    • Virtual machine experience
    • Programming language experience
  • Project attributes
    • Use of software tools
    • Application of software engineering methods
    • Required development schedule

Each of the 15 attributes receives a rating on a six-point scale that ranges from "very low" to "extra high" (in importance or value). An effort multiplier from the table below applies to the rating. The product of all effort multipliers results in an effort adjustment factor (EAF). Typical values for EAF range from 0.9 to 1.4.

Cost Drivers Ratings
Very Low Low Nominal High Very High Extra High
Product attributes
Required software reliability 0.75 0.88 1.00 1.15 1.40  
Size of application database   0.94 1.00 1.08 1.16  
Complexity of the product 0.70 0.85 1.00 1.15 1.30 1.65
Hardware attributes
Run-time performance constraints     1.00 1.11 1.30 1.66
Memory constraints     1.00 1.06 1.21 1.56
Volatility of the virtual machine environment   0.87 1.00 1.15 1.30  
Required turnabout time   0.87 1.00 1.07 1.15  
Personnel attributes
Analyst capability 1.46 1.19 1.00 0.86 0.71  
Applications experience 1.29 1.13 1.00 0.91 0.82  
Software engineer capability 1.42 1.17 1.00 0.86 0.70  
Virtual machine experience 1.21 1.10 1.00 0.90    
Programming language experience 1.14 1.07 1.00 0.95    
Project attributes
Application of software engineering methods 1.24 1.10 1.00 0.91 0.82  
Use of software tools 1.24 1.10 1.00 0.91 0.83  
Required development schedule 1.23 1.08 1.00 1.04 1.10  

The Intermediate Cocomo formula now takes the form:

E = ai(KLoC)(EAF)

where E is the effort applied in person-months, KLoC is the estimated number of thousands of delivered lines of code for the project, and EAF is the factor calculated above. The coefficient ai and the exponent bi are given in the next table.

Software project ai bi ci
Organic 3.2 1.05 0.38
Semi-detached 3.0 1.12 0.35
Embedded 2.8 1.20 0.32

The Development time D and also the most effective number of Persons P calculation uses E in the same way as in the Basic COCOMO:

D = 2.5 E
P = E / D {\displaystyle P=E/D}

Note that in addition to the EAF, the parameter ai is different in Intermediate COCOMO from the Basic model:

Software project ab
Organic 2.4
Semi-detached 3.0
Embedded 3.6

The parameters b and c are the same in both models.

See also

References

  1. Stutzke, Richard. "Software Estimating Technology: A Survey". Archived from the original on 28 March 2020. Retrieved 9 Oct 2016.DOC
  2. Boehm, Barry (1981). Software Engineering Economics. Prentice-Hall. ISBN 0-13-822122-7.
  3. Barry Boehm, Chris Abts, A. Winsor Brown, Sunita Chulani, Bradford K. Clark, Ellis Horowitz, Ray Madachy, Donald J. Reifer, and Bert Steece. Software Cost Estimation with COCOMO II (with CD-ROM). Englewood Cliffs, NJ:Prentice-Hall, 2000. ISBN 0-13-026692-2

Further reading

External links


Category:
COCOMO: Difference between revisions Add topic