您的位置:軟件測(cè)試 > 軟件項(xiàng)目管理 > 項(xiàng)目計(jì)劃 >
基于用例的工作量估計(jì)
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2013/5/10 14:54:36 ] 推薦標(biāo)簽:

從這些考慮中可以看到,數(shù)據(jù)是否不夠健康是顯而易見(jiàn)的--例如:如果 Delphi 估計(jì)是 60 萬(wàn)行代碼(或者等價(jià)的功能點(diǎn)),并且?guī)缀鯖](méi)有什么構(gòu)架方面的工作,那么對(duì)于系統(tǒng)結(jié)構(gòu)方面知道得并不多--圖 3 表明用例的數(shù)量應(yīng)該在 2(所有的第四層)和 14(所有的第三層)。如果實(shí)際上用例數(shù)量是 100,那么用例可能已經(jīng)提前進(jìn)行了分解,或者 Delphi 的估計(jì)嚴(yán)重出軌。

繼續(xù)分析這個(gè)例子:如果實(shí)際的用例的數(shù)量是 20,并且評(píng)估者決定它們都在 L3;更進(jìn)一步講,用例的長(zhǎng)度平均7頁(yè),并且系統(tǒng)是一種復(fù)雜的業(yè)務(wù)系統(tǒng),每個(gè)用例的小時(shí)數(shù)(從圖 2 中得到)是20,000。為了降低復(fù)雜度,要乘以 7/9(基于用例的長(zhǎng)度)。所以根據(jù)這種方法計(jì)算的工作量是 20×20000×(7/9) = ~310,000 人-小時(shí),或者 2050 人月。根據(jù) Estimate Professional,對(duì)于業(yè)務(wù)系統(tǒng)而言,60 萬(wàn)行的 C++代碼需要 1928 人月。因此,在這個(gè)設(shè)計(jì)的例子中,充分體現(xiàn)了這一點(diǎn)。

如果實(shí)際的用例的數(shù)量是 5,并且評(píng)估者決定將 1 個(gè)用例分配到 L4,其他 4 個(gè)分配到第三層。更進(jìn)一步 L4 用例是 12 頁(yè),L3 用例平均是 10 頁(yè),然后計(jì)算工作量將是 1×250,000×12/9+4×21000×(10/9) = ~2800 人月。這表明 Delphi 的估計(jì)需要重新進(jìn)行修訂,盡管假設(shè)系統(tǒng)的主要部分看起來(lái)仍然在很高的層次上,但總之在邊界上有很大的錯(cuò)誤。

如果原來(lái)的 Delphi 估計(jì)是 10 萬(wàn)行 C++代碼,圖 3 表明用例應(yīng)該在 L2 并且應(yīng)該有 18 個(gè)。如果實(shí)際上有 20 個(gè),如同前面的例子一樣,如果 Delphi 估計(jì)很糟糕的話,那么是因?yàn)椴豢紤]實(shí)際用例層次而應(yīng)用該方法將得出一個(gè)不正確的結(jié)果。

因此,估計(jì)者必須檢查用例是否在建議的抽象的層次上(L2)并且可以通過(guò)子系統(tǒng)的協(xié)作來(lái)實(shí)現(xiàn),以及用例并不完全在 L3 上--盡管 Wideband Delphi 方法并不是經(jīng)常那么糟糕(例如,預(yù)計(jì) 10 萬(wàn),而實(shí)際上是接近 60 萬(wàn))。問(wèn)題是這種評(píng)估方法在使用時(shí)使人缺乏自信,沒(méi)有額定的或者概念上的構(gòu)架,而這些構(gòu)架正是和用例的層次相匹配的。對(duì)于一個(gè)在該領(lǐng)域非常有經(jīng)驗(yàn)的評(píng)估者來(lái)說(shuō),模型可以是一個(gè)能夠判斷形成哪一層的想象中模型,而對(duì)于一個(gè)經(jīng)驗(yàn)比較少的評(píng)估者或者團(tuán)隊(duì)來(lái)說(shuō),做一些構(gòu)架建模來(lái)觀察一下在一個(gè)特殊的層次上用例實(shí)現(xiàn)得如何,不失為一種明智之舉。

對(duì)于復(fù)合表達(dá)的用例(也是說(shuō),層次 N 和層次 N+1的混合)應(yīng)該計(jì)算為 n=8(l隔開(kāi)兩層的部分) ,得出用例在較低一層的數(shù)量。因此,一個(gè)用例假設(shè) 50%在 L1 并且 50% 在 L2,那么應(yīng)該計(jì)算為 80.5 = 3 個(gè) L1 用例,一個(gè)用例假設(shè)在 L2 和 L3 之間的 30%,那么應(yīng)該計(jì)算為80.3 L2 用例= 2 個(gè) L2 用例。一個(gè)用例在 L2 和 L3 之間的 90%,那么應(yīng)該計(jì)算為 80.9 = 7 個(gè) L2 用例。

表的規(guī)模調(diào)整
實(shí)際上考慮總的工作量規(guī)模時(shí),需要對(duì)個(gè)別用例的小時(shí)數(shù)做進(jìn)一步調(diào)整――工作量的數(shù)字只適合于在該規(guī)模系統(tǒng)的上下文中的每一個(gè)層次上。因此,在表 1 中的 L1 層,當(dāng)構(gòu)建一個(gè) 7000 slocs 的系統(tǒng)時(shí),將采用每一個(gè)用例 55 小時(shí)。實(shí)際的數(shù)字將取決于總的系統(tǒng)規(guī)模――所以如果要構(gòu)建的系統(tǒng)的規(guī)模是 40,000 slocs 并且使用 57 個(gè) 1 層的用例來(lái)描述它,那么對(duì)于一個(gè)簡(jiǎn)單的業(yè)務(wù)系統(tǒng)來(lái)說(shuō)工作量不是55×57 小時(shí),而是(40/7)0.11 × 55 = 66 小時(shí)/用例。這是基于規(guī)模和工作量的 COCOMO 2 關(guān)系。根據(jù) COCOMO 模型,工作量=A × (size)1.11,其中

    size 的單位為 ksloc
    A 為成本驅(qū)動(dòng)因子
    項(xiàng)目比例因子為額定值(將 1.11 用作指數(shù))

注意這些計(jì)算可以作為因子用到諸如 Estimate Professional這樣的工具中,從而減輕計(jì)算負(fù)擔(dān);此處完整列出了它們。

因此每 ksloc 的工作量或者每單元工作量等于 A× (Size)1.11/Size,從中推出 A× (Size)0.11,因此,每單元的工作量在 size 為 S1 到 S2 的比率為(S1/S2)0.11。

對(duì) Delphi 估計(jì)還要說(shuō)明一點(diǎn),系統(tǒng)的規(guī)模可以從各個(gè)層上用例的數(shù)量來(lái)粗略地計(jì)算出來(lái):如果在第一層有 N1 個(gè)用例,在第二層有 N2 個(gè),第三層有 N3 個(gè),第四層上有 N4 個(gè),那么總的規(guī)模是[(N1/10)×7 + (N2/10)×56 + (N3/10)×448 + (N4/10)×3584] ksloc。因此,我們可以計(jì)算工作量乘上表 1 中的每個(gè)用例的工作量,然后將總的規(guī)模除以表1中第一列中列出的每一層的規(guī)模(單位是 ksloc)。

因此, 在第一層, (0.1×N1 + 0.8×N2 + 6.4×N3 + 51.2×N4)0.11。
第二層 (0.0125×N1 + 0.1×N2 + 0.8×N3 + 6.4×N4)0.11。
第三層, (0.00156×N1 + 0.0125×N2 + 0.1×N3 + 0.8×N4)0.11。
第四層, (0.00002×N1 + 0.00156×N2 + 0.0125× N3 + 0.1×N4)0.11。

顯然,以第四層為例,與第三層或第四層的用例數(shù)量相比,第一層用例的數(shù)量的影響微乎其微。

結(jié)束語(yǔ)
本文描述了基于用例進(jìn)行評(píng)估的一個(gè)框架。為了使描述更加具體,本文為框架的參數(shù)選擇了一些值,盡管這些值有待于論證,但它們并不總是錯(cuò)誤的。像往常一樣,隨著數(shù)據(jù)的搜集,這種估計(jì)應(yīng)該根據(jù)實(shí)際情況和重新估計(jì)的參數(shù)值進(jìn)行測(cè)試。這種框架對(duì)于不同種類的系統(tǒng)考慮了用例層次、規(guī)模和復(fù)雜度等思想,并且不再采取細(xì)粒度的功能分解。為減輕計(jì)算的負(fù)擔(dān),對(duì)于諸如 Estimate Professional 這樣的工具,可以構(gòu)建一個(gè)前端,從而提供一種基于用例的規(guī)模輸入的不同的方法。

對(duì)本白皮書(shū)的評(píng)論以及反饋意見(jiàn),請(qǐng)通過(guò)電子郵件 jsmith@rational.com與 John Smith 取得聯(lián)系。

參考資料

您可以參閱本文在 developerWorks 全球站點(diǎn)上的 英文原文。

1. Armour96: Experiences Measuring Object Oriented System Size with Use Cases, F. Armour, B. Catherwood, et al., Proc. ESCOM, Wilmslow, UK, 1996

2. Boehm81: Software Engineering Economics, Barry W. Boehm, Prentice-Hall, 1981

3. Booch98: The Unified Modeling Language User Guide, Grady Booch, James Rumbaugh, Ivar Jacobson, Addison-Wesley, 1998

4. Cockburn97: Structuring Use Cases with Goals, Alistair Cockburn, Journal of Object-Oriented Programming, Sept-Oct 1997 and Nov-Dec 1997

5. Douglass99: Doing Hard Time, Bruce Powel Douglass, Addison Wesley, 1999

6. Fetcke97: Mapping the OO-Jacobson Approach into Function Point Analysis, T. Fetcke, A. Abran, et al., Proc. TOOLS USA 97, Santa Barbara, California, 1997.

7. Graham95: Migrating to Object Technology, Ian Graham, Addison-Wesley, 1995

8. Graham98: Requirements Engineering and Rapid Development, Ian Graham, Addison-Wesley, 1998

9. Henderson-Sellers96: Object-Oriented Metrics, Brian Henderson-Sellers, Prentice Hall, 1996

10. Hurlbut97: A Survey of Approaches For Describing and Formalizing Use Cases, Russell R. Hurlbut, Technical Report: XPT-TR-97-03, http://www.iit.edu/~rhurlbut/xpt-tr-97-03.pdf

11. Jacobson97: Software Reuse - Architecture, Process and Organization for Business Success, Ivar Jacobson, Martin Griss, Patrik Jonsson, Addison-Wesley/ACM Press, 1997

12. Jones91: Applied Software Measurement, Capers Jones, McGraw-Hill, 1991

13. Karner93: Use Case Points - Resource Estimation for Objectory Projects, Gustav Karner, Objective Systems SF AB (copyright owned by Rational Software), 1993

14. Lorentz94: Object-Oriented Software Metrics, Mark Lorentz, Jeff Kidd, Prentice Hall, 1994

15. Major98: A Qualitative Analysis of Two Requirements Capturing Techniques for Estimating the Size of Object-Oriented Software Projects, Melissa Major and John D. McGregor, Dept. of Computer Science Technical Report 98-002, Clemson University, 1998

16. Minkiewicz96: Estimating Size for Object-Oriented Software, Arlene F. Minkiewicz, http://www.pricesystems.com/foresight/arlepops.htm, 1996

17. Pehrson96: Software Development for the Boeing 777, Ron J. Pehrson, CrossTalk, January 1996

18. Putnam92: Measures for Excellence, Lawrence H. Putnam, Ware Myers, Yourdon Press, 1992

19. Rechtin91: Systems Architecting, Creating & Building Complex Systems, E. Rechtin, Prentice-Hall, 1991

20. Royce98: Software Project Management, Walker Royce, Addison Wesley, 1998

21. RUP99: Rational Unified Process, Rational Software, 1999

22. Stevens98: Systems Engineering - Coping with Complexity, R. Stevens, P. Brook, et al., Prentice Hall, 1998

23. Thomson94: Project Estimation Using an Adaptation of Function Points and Use Cases for OO Projects, N. Thomson, R. Johnson, et al., Proc. Workshop on Pragmatic and Theoretical Directions in Object-Oriented Software Metrics, OOPSLA '94, 1994

上一頁(yè)12345下一頁(yè)
軟件測(cè)試工具 | 聯(lián)系我們 | 投訴建議 | 誠(chéng)聘英才 | 申請(qǐng)使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd