软件成本估算课件

上传人:沈*** 文档编号:241809894 上传时间:2024-07-26 格式:PPT 页数:57 大小:419.50KB
返回 下载 相关 举报
软件成本估算课件_第1页
第1页 / 共57页
软件成本估算课件_第2页
第2页 / 共57页
软件成本估算课件_第3页
第3页 / 共57页
点击查看更多>>
资源描述
目标v软件成本计算和软件报价的基本原理以及在它们之间存在的复杂关系。v对软件生产率评估的度量。v在对软件成本和进度安排进行评估时应当使用一系列不同的技术。v用于算法成本估算的COCOMO 2模型的原理内容v生产率v估算技术v算法成本建模v项目的工期和人员配备估算的基本问题v完成一项活动需要多少工作量?v完成一项活动需要多少时间?v一项活动的总成本是多少?v项目估算和进度安排是交叉进行的管理活动软件成本构成v硬件和软件成本v差旅费和培训费用v工作成本(大多数项目中是主要成本)项目中投入的工程师的工资社会和保险费用v工作成本还要计入办公场所、供热和照面费用网络和通信费用共用设施的费用(e.g 图书馆,员工餐厅,etc.)成本和报价v估算是为了得到承包商开发一个软件的成本v在成本和报价之间没有一个简单的关系 价格成本利润v广泛的因素包括机构的、经济的和商务上的考虑会影响报价影响软件报价的因素因素因素描述描述市场机遇开发机构为了便于进入一个新的软件市场,可能会提出一个低报价。成本估算的不确定性如果机构对成本估算没有把握,它会提高报价,在正常利润之上增加某些意外费用。合同条款客户可能愿意让开发者保有程序源代码的所有权,以便可以在未来的开发项目中复用。这时的要价就会比移交源代码的情况低得多。需求易变性如果需求很有可能发生变化,机构就会降低报价以赢得合同,当得到合同之后,一旦需求有所变更,机构就会乘机抬高报价。经济状况当开发者处于资金短缺阶段时,为得到合同而作出较低报价,少获点例甚至收支相抵总比破产强。v软件开发工程师生产软件和相关文档的效率的度量v不是面向质量的,虽然质量保证是生产率评估的一个因素v本质上,我们是想度量单位时间里生产的有用功能程序员的生产率v面向规模的度量 这种方法是根据活动输出的量来衡量。可能是提交的源代码行数,目标代码说明书的长度或者系统文档的页数等。v面向功能的度量 这种方法是看移交软件总的功能有多少。功能点和对象点方法是最常用的方法。生产率的度量v估算软件规模v估算总的程序员人月数v估算分包商生产率,并且合并到总的估算中度量的问题v什么是一个代码行?当程序打印在卡片上时代开始就使用的度量方法,一行一张卡片代码行如何跟语句对应起来,一个语句可能占几行,一行也可能有几个语句。v什么程序应该算作系统的一部分?v假设在系统大小和源代码大小之间有着线性关系代码行v编程语言越低级,计算出来的生产率越高同样的功能,低级语言需要更多代码v程序员的代码越冗长,计算出来的生产率越高生产率计算是基于程序员所写的代码量的生产率比较的问题高级和低级语言系统开发时间功能点v基于程序特性的组合外部输入输出用户交互外部接口系统使用的文件v每一项都有一个复杂性权值(315)v功能点计数就是将每项功能点数乘以权值,然后求和的结果。功能点v功能点计数由项目复杂性修正v根据给定语言的每功能点平均代码行数,功能点计数可以用来计算代码行数LOC=AVC*FPs AVC 是基于语言的因子,汇编语言200-300,4GL则2-40v功能点计数是非常主观的,依赖于估算者。自动功能点计数是不可能的。对象点v当使用高级语言(特别是4GL)开发时,作为另一个功能相关方法,对象点方法可以代替功能点方法v对象点不同于对象类v 程序的对象点是下列内容的加权估算:独立的显示屏幕数生成的报表数为辅助4GL代码而必须开发的3GL模块数对象点估算v对象点估算比功能点容易,因为它只关心屏幕数、报告数和3GL模块数v可以在开发过程的很早期使用,这时要估计系统的代码行还很困难。v实时嵌入式系统,40-160 LOC/人月v系统程序,150-400 LOC/人月v商业应用,200-800 LOC/人月v在对象点方法中,随支持工具和开发者能力不同,生产率在 450对象点/人月生产率估算影响生产率的因素因素因素描述描述应用领域经验应用领域知识是有效的软件开发的根本。已经对领域有充分了解的工程人员很可能是生产率最高的。过程质量所用的开发过程对生产率有极大的影响。项目规模项目规模越大,团队之间的交流和沟通就越花时间,真正有用的时间就会减少,因而,个人生产率就会降低。技术支持好的支持技术和CASE工具、配置管理系统等有助于提高生产率。工作环境一个好的工作环境有助于提高生产率。v所有基于单位时间内产量的做法都有问题,因为没有考虑质量v以质量为代价,通常都能提高生产率v还不清楚生产率和质量之间的关系v变更不断的情况下,使用代码行生产率计算是没有意义的。质量和生产率估算技术v没有一个简单的方法可以精确估算软件开发所需的资源初始估算是基于用户需求定义中不充分的信息软件可能是运行于不熟悉的计算机系统或者使用新的技术项目中的开发人员不了解v项目成本估算可能是自己设定的用来确定项目预算和调整软件产品以保证预算不被突破估算技术v算法成本建模v专家判定v类比估计vParkinson定律v根据客户预算报价算法成本建模v所建立的模型利用有关历史信息来估计需要的工作量,用到的历史信息是有关某些软件度量(例如规模)与项目成本之间的关系v本章后续讨论专家判定v多位软件开发和应用领域方面的专家用他们的经验预测软件成本。反复进行直到达成一致。v优点:相对廉价的估算方法。如果专家具有相似系统的直接经验的话,可以比较精确。v缺点:如果没有专家的话,将非常不精确。类比估计v将项目和一个同样应用领域里的类似项目作比较,从而计算出成本。v优点:如果项目数据具备的话比较精确v缺点:如果没有可比的项目,则不可能应用。需要系统性维护的成本数据库Parkinson定律v工作占满所有可用的时间。成本决定于所有可用的资源而不是客观的估算。v优点:不会超支v缺点:系统经常完不成根据客户预算报价v将客户对项目的预算作为软件的成本v优点:得到了合同v缺点:成本无法精确反映工作所需。自上而下和自下而上的估算v以上的方法都可以是自上而下或自下而上的v自上而下从系统层面开始,评估系统的总体功能以及如何通过子系统间的交互完成的。v自下而上从组件层面开始,估算每个组件所需的工作量。将这些工作量加在一起得到最后的估算。自上而下的估算v无需系统体系结构以及组件的知识就可应用v成本考虑集成、配置管理和文档等v可能会低估解决低层技术难题的成本自下而上的估算v当体系结构和组件识别已知的情况下使用v如果系统已经得到详细设计时是比较精确的方法v可能会低估系统级活动的成本,如集成和文档等估算方法v每个方法都有优缺点v估算应该基于多种方法v如果得到的结果相差甚远,意味着信息不够充分v为了得到更精确的估算,需要额外采取行动v有时候根据客户预算报价是唯一可用的方法。基于经验的估算v从根本上说估算是基于经验的v然而,一些新的方法和技术导致基于不精确的经验的估算面向对象开发而非面向功能的开发客户机/服务器系统而非基于主机的系统使用现成的软件组件基于组件的可复用的软件工程使用CASE工具和程序生成器根据客户预算报价v这个方法看似不道德的而且是不实事求是的v然而,当详细信息缺乏的时候,它可能是唯一合适的策略v项目成本基于开发大纲而定,成本是开发的限制因素。v开发商和客户之间通过协商建立详细的项目描述,或者使用一个进化式开发方法。算法成本建模v通过对项目规模、程序员数量以及其他过程和产品因素的估算,用一个数学共识来估算项目的成本。工作量=A SizeB MA 是反映机构情况的常数因子,B 反映了大型项目工作量的非线性因子,M 是一个乘数因子,反映了不同过程、产品及开发特征的混合因素。v最常用的产品特性是代码规模v大多数模型都是相似的,只是A,B和M的值不同估算的精度v只有系统完成后才能精确知道软件的规模v一些因素影响最后的规模使用现货产品和组件编程语言系统的分布v随着开发过程的进展,代码规模的估算变得更加精确估算的不确定性COCOMO模型v是一个基于项目经验的经验模型v是一个独立的模型,不限于特定的软件开发商v有较长的历史,初始版本发布于1981年(COCOMO-81),不断改进得到了 COCOMO 2vCOCOMO 2考虑了不同的软件开发方法COCOMO 81COCOMO 2 的分层vCOCOMO 2 是一个3层模型,随着开发进展允许有日益具体的估算v早期原型层规模估算是基于对象点的,使用一个简单的规模/生产率计算公式估算所需工作量v早期设计层估算基于功能点,然后把这些功能点转换成源代码行数v后体系结构层估算基于源代码行数早期原型层v支持原型开发项目和大量复用的项目v基于开发者每月对象点生产率的标准估算v考虑了CASE工具的使用v估算公式:PM=(NOP (1-%reuse/100)/PRODPM 是每人月工作量,NOP 对象点数,PROD是生产率,reuse是所期望的复用率对象点生产率早期设计层v需求确定后就可以做早期设计层的估算v基于算法模型的标准公式PM=A SizeB M+PMm 其中M=PERSRCPXRUSEPDIFPREXFCILSCEDPMm=(ASLOC(AT/100)/ATPRODA=2.5,Size用KLOC表示,B根据项目的新颖程度、开发灵活性、风险管理方法和过程成熟度的不同从1.11.24不等乘法因子v乘法因子反映了开发者的能力、非功能需求、对开发平台的熟悉程度等。RCPX 产品的可靠性和复杂性RUSE 要求的复用性PDIF 平台的难度PREX 个人经验PERS 个人能力SCED 要求的进度FCIL 团队支撑设施vPM 反映了自动生产代码的总量后体系结构层v使用和早期设计层同样的公式v对代码行数的估算要考虑以下修正因素需求的易变性。对需求变更的返工工作量进行估算。可能的复用程度。复用是非线性的,其相应的成本不能通过简单的减少单位时间内的LOCESLOC=ASLOC(AA+SU+0.4DM+0.3CM+0.3IM)/100vESLOC是新的代码行数。ASLOC是必须修改的复用代码行数。DM是设计修改的百分比。CM是代码修改的百分比。IM是集成复用软件所需的最初费用的百分比。vSU 是一个反映理解软件难易的因子,AA反映为确定软件是否可复用所做的初始评估费用。v依赖于5个比例因子(见下一页).它们的和除以100再加上1.01就是该指数项的取值了v举例先例的援引 新项目-取值为“低”(4)开发的灵活性 没有客户介入 取值为“非常高”(1)体系结构/风险解决 没有风险分析“非常低”(5)团队凝聚力 新团队 “一般”(3)过程成熟度 有一些过程控制 “一般”(3)v所以比例因子是 1.17指数因子指数比例因子比例因子比例因子解释解释先例的援引反映机构对这个类型项目的经验。“非常低”代表无经验,“非常高”代表机构对该领域已经彻底了解了开发的灵活性反映开发过程中的灵活性程度。“非常低”代表使用事先规定的过程,“非常高”代表客户只给出了总的目标体系结构/风险解决反映风险分析完成的程度,“非常低”代表无分析,“非常高”代表完全和彻底的风险分析团队凝聚力反映开发团队成员相互了解的程度和协作的程度。“非常低”代表交互非常困难,“非常高”代表这是一个团结高效的团队,没有沟通障碍。过程成熟度反映机构的过程成熟度。该值的计算依赖于CMM的成熟度调查问卷,对它的估算可以用5减去CMM过程成熟度等级得到v产品属性关于所要开发的软件产品的要求特性v计算机属性硬件平台的约束v人员属性考虑开发人员的经验和能力v项目属性关于软件开发项目的特征乘数因子项目成本形成因素成本形成因素对工作量估算的影响v算法成本模型为项目计划提供了基础,因为不同的算法成本模型提供了可供比较的不同的策略,以减少项目成本v举例:嵌入式太空船控制系统必须可靠必须最小化重量(芯片的数量)可靠性和计算机约束的乘法因子 1v成本构成目标硬件开发平台所需工作量项目计划管理选项管理选项的成本选项的选择v选项D(使用更多有经验的人员)似乎是最好的选择然而,它有个高风险因数,因为有经验的人员难以找到v选项C(只升级存储器)节省成本较少但是风险很低v总之,这个模型显示了软件开发中人员经验的重要性。项目工期和人员配备v在估算工作量的同时,管理者必须估计一个项目的开发周期,以及人员要在什么时候到位v项目所需的日立时间可以用COCOMO 2公式计算TDEV=3(PM)(0.33+0.2*(B-1.01)PM 是工作量计算值,B是上面所计算的指数项(对于早期原型模型,B=1)。通过这个计算预计了项目的名义进度。v所需时间不依赖于项目中的工作人员数人员要求v要求的人员不能单纯用所需工作量除以开发时间来计算。v项目不同时期,投入的工作人员数量是变化的v项目中的人员越多,往往要求的总工作量越大v草率的配置人员往往导致项目进度的拖延要点v影响生产率的因素包括个人能力、领域经验、开发过程、项目规模、工具支持和工作环境。v应使用多种软件成本估算技术,如果结果相差较大,则说明估算信息不充分。v软件通常是先有合同金额,然后再据此调整相应的功能。要点v算法成本估算是困难的,因为需要估计将要完成产品的特征。vCOCOMO模型预测成本时,要考虑项目、产品、人员和硬件的因素。v算法成本模型支持量化的选项分析。v完成一个项目所需要的时间和参加项目的人数不成比例。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!