JP2006085663A - Evaluation device for software development manhour cost - Google Patents

Evaluation device for software development manhour cost Download PDF

Info

Publication number
JP2006085663A
JP2006085663A JP2004354147A JP2004354147A JP2006085663A JP 2006085663 A JP2006085663 A JP 2006085663A JP 2004354147 A JP2004354147 A JP 2004354147A JP 2004354147 A JP2004354147 A JP 2004354147A JP 2006085663 A JP2006085663 A JP 2006085663A
Authority
JP
Japan
Prior art keywords
development
software
work
productivity
inputting
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP2004354147A
Other languages
Japanese (ja)
Inventor
Kinfuku Ryu
錦福 劉
Yoshihiro Nakano
義弘 中野
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
TEIKOKU DATABANK Ltd
Original Assignee
TEIKOKU DATABANK Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by TEIKOKU DATABANK Ltd filed Critical TEIKOKU DATABANK Ltd
Priority to JP2004354147A priority Critical patent/JP2006085663A/en
Priority to KR1020050035151A priority patent/KR20060047546A/en
Publication of JP2006085663A publication Critical patent/JP2006085663A/en
Pending legal-status Critical Current

Links

Images

Abstract

<P>PROBLEM TO BE SOLVED: To provide an evaluation method of a software development manhour cost capable of evaluating the software development manhour cost with an objective and fair technique. <P>SOLUTION: The estimation and evaluation of a development cost of software is carried out by dividing a functional scale (function points) of the software by a productivity coefficient expressed by multiplication of a development language-based productivity value, a productivity adjustment coefficient, a process-based order rate, a work sharing rate and a repair rate, and by multiplying an additional value of the division value thereof and additional work manhours by a system engineer unit cost. <P>COPYRIGHT: (C)2006,JPO&NCIPI

Description

本発明は、コンピュータシステム、ネットワーク等を構成するソフトウェアの開発工数費用の価格(見積り額)を、できるだけ客観的にかつ合理性をもって評価するためのソフトウェア開発工数費用見積りプログラム及びソフトウェア開発工数費用見積りプログラムを記憶した記憶媒体に関する。   The present invention relates to a software development man-hour cost estimation program and a software development man-hour cost estimation program for objectively and rationally evaluating the price (estimated amount) of software development man-hour cost of software constituting a computer system, a network, etc. It relates to the storage medium which memorize | stored.

情報システムが業務や社会の隅々まで浸透し、それに伴う情報システムの投資が膨大になってきており、その中でもソフトウェア開発費が大きな割合を占めている。しかしながら、ソフトウェア開発費(評価)の見積りプロセスが構造化されていないため、ベンダーから提示された見積りは往々にして明確な根拠が示されないまま、発注・システム構築等の業務が遂行されてしまうのが実情である。   Information systems have permeated every corner of business and society, and the investment in information systems has become enormous, and software development costs account for a large percentage. However, because the software development cost (evaluation) estimation process is not structured, the estimates provided by vendors often carry out tasks such as ordering and system construction without showing a clear basis. Is the actual situation.

従来コンピュータシステムを構成するソフトウェアの開発工数費用を見積る場合、ソフトウェアの規模や作業内容を考慮して開発工数費用を算出することが一般的である。そのため、ソフトウェア開発工数費用の見積りや評価作業は、ソフトウェア開発作業を永年従事したエキスパートと称されるような特定な人の経験と勘に依存することが多い。   Conventionally, when estimating the development man-hour cost of software constituting a computer system, it is common to calculate the development man-hour cost in consideration of the size of the software and the work contents. For this reason, estimation and evaluation work for software development man-hours often depend on the experience and intuition of a specific person such as an expert who has been engaged in software development work for many years.

ソフトウェア開発工数費用を見積ったり評価する手法として、LOC(Lines of Code:プログラム行数)法が存在するが、1990年代からIT技術の進歩に伴い、システム構成と開発手法の多様化と複雑化が進み、もはやプログラム行数の量と開発工数、費用との相関関係が崩れ、LOC法で培ってきた経験や勘に基づいて見積ることに限界が来ている。そこで、LOC法の代わりにFP(Function Point:機能規模)法が注目されるようになった。FP法はソフトウェアが持つ機能の量を計測する手法であり、図1に示すようにシステム仕様書から規模を定量的に計測してソフトウェア機能規模を計るものである。ソフトウェアの開発工数や費用を算定する際に使用されているFPに対する評価額は、一般的に図2に示すような2次関数となっている。   The LOC (Lines of Code) method exists as a method for estimating and evaluating software development man-hour costs, but with the advancement of IT technology since the 1990s, system configuration and development methods have become diversified and complicated. The correlation between the number of program lines and the development man-hours and costs has broken, and there is a limit to estimate based on experience and intuition cultivated by the LOC method. In view of this, the FP (Function Point) function has attracted attention instead of the LOC method. The FP method is a technique for measuring the amount of functions of software, and measures the scale of software functions by quantitatively measuring the scale from a system specification as shown in FIG. The evaluation value for the FP used when calculating the software development man-hours and costs is generally a quadratic function as shown in FIG.

また、特開2002−222080(特許文献1)のソフトウェア見積りシステムでは、ソフトウェアの機能情報が記憶された機能情報記憶部と、この機能情報記憶部に記憶された機能情報から開発するソフトウェアプロジェクトの機能情報を選択する機能情報選択部と、この機能情報選択部によって選択された機能情報を用いて上記ソフトウェアプロジェクトの機能量を計算する機能量計算部とを設けている。業務分野と規模を開発費用の見積りに利用している。   In addition, in the software estimation system disclosed in Japanese Patent Application Laid-Open No. 2002-222080 (Patent Document 1), a function information storage unit storing software function information and a function of a software project developed from the function information stored in the function information storage unit A function information selection unit that selects information and a function amount calculation unit that calculates the function amount of the software project using the function information selected by the function information selection unit are provided. Business area and scale are used to estimate development costs.

特開2003−263320(特許文献2)の見積り作業支援システムは、開発対象システムの見積り作業を支援する見積り作業支援システムであり、開発対象システムのソフトウェア規模を見積るための規模見積り条件を入力し、規模見積り条件に基づいてソフトウェア規模を見積るソフトウェア規模見積り手段と、開発工数を見積るための工数見積り条件を入力し、工数見積り条件に基づいて開発工数を見積る開発工数見積り手段と、開発コストを見積るためのコスト見積り条件を入力し、コスト見積り条件に基づいて開発コストを見積る開発コスト見積り手段と、ソフトウェア規模の見積り結果、開発工数の見積り結果、および開発コストの見積り結果を、見積り作業を行う作業者に提示する見積り結果提示手段とを設けている。開発費用の見積りは、工数に対する単金の乗算値に間接費用を加算している。   An estimation work support system disclosed in Japanese Patent Application Laid-Open No. 2003-263320 (Patent Document 2) is an estimation work support system that supports an estimation work of a development target system, and inputs a scale estimation condition for estimating a software scale of the development target system. To input software size estimation means for estimating the software scale based on the size estimation conditions, to input the man-hour estimation conditions for estimating the development man-hours, and to estimate the development man-hours for estimating the development man-hours based on the man-hour estimation conditions The person who inputs the cost estimation conditions for the development cost, the development cost estimation means that estimates the development cost based on the cost estimation conditions, and the person who estimates the software scale estimation result, the development man-hour estimation result, and the development cost estimation result And an estimation result presenting means for presenting to the above. In the estimation of development costs, indirect costs are added to the multiplication value of man-hours for man-hours.

更に、特開2003−308449(特許文献3)のシステム開発見積支援システムは、開発対象となるシステムの規模の情報であるシステム規模情報を算出するための規模算出情報と、システム開発に要する人員や期間である開発工数情報を算出するための開発工数算出情報とをクライアントマシンから受信する情報受信手段と、前記情報受信手段によって受信した前記規模算出情報及び前記開発工数算出情報を記憶する記憶手段と、前記記憶手段に記憶された前記規模算出情報に基づいてシステム規模情報を算出するための規模算出関数情報と、前記開発工数算出情報に基づいて開発工数情報を算出するための開発工数算出関数情報とを記憶する算出関数情報記憶手段と、前記開発工数情報を算出する見積算出手段と、前記見積算出手段によって算出された開発工数情報と前記規模算出情報とを関連付けて記憶する開発工数情報記憶手段と、前記開発工数情報記憶手段に記憶された前記開発工数情報を前記クライアントマシンに送信する情報送信手段と、これら各手段の動作を制御する処理装置とを備えたシステム開発見積支援システムであって、前記処理装置は、前記見積算出手段に、前記算出関数情報記憶手段に記憶された前記規模算出関数情報と前記記憶手段に記憶された前記規模算出情報とを取得させ、これら情報に基づいてシステム規模情報を算出させ、前記算出関数情報記憶手段に記憶された前記開発工数算出関数情報と、算出された前記システム規模情報と、前記記憶手段に記憶された前記開発工数算出情報とを取得させ、これら情報に基づいて前記開発工数情報を算出させるものである。
特開2002−222080 特開2003−263320 特開2003−308449
Furthermore, the system development estimation support system disclosed in Japanese Patent Application Laid-Open No. 2003-308449 (Patent Document 3) includes scale calculation information for calculating system scale information, which is information on the scale of a system to be developed, personnel required for system development, Information receiving means for receiving development man-hour calculation information for calculating development man-hour information that is a period from a client machine, and storage means for storing the scale calculation information and the development man-hour calculation information received by the information receiving means , Scale calculation function information for calculating system scale information based on the scale calculation information stored in the storage means, and development manhour calculation function information for calculating development manhour information based on the development manhour calculation information Calculation function information storage means for storing, estimate calculation means for calculating the development man-hour information, and the estimate calculation means Therefore, development man-hour information storage means for storing the calculated development man-hour information and the scale calculation information in association with each other, and information transmission means for transmitting the development man-hour information stored in the development man-hour information storage means to the client machine; A system development estimation support system comprising a processing device for controlling the operation of each of the means, wherein the processing device stores the scale calculation function information stored in the calculation function information storage means in the estimate calculation means. And the scale calculation information stored in the storage means, the system scale information is calculated based on the information, the development manhour calculation function information stored in the calculation function information storage means, and The system scale information and the development man-hour calculation information stored in the storage means are acquired, and the development man-hour information is obtained based on the information. It is intended to be calculated.
JP2002-2222080 JP 2003-263320 A JP 2003-308449 A

上述のように従来の一般的評価方法ではその評価値に客観的で合理的な根拠がなく、果たして適正な評価額であるか否かが問題であり、ソフトウェア開発工数費用の評価を客観的に合理性をもって実行できることを、発注者側及び受注側共に強く望んでいた。FP値を用いた評価法も同様である。   As described above, in the conventional general evaluation method, there is no objective and rational basis for the evaluation value, and it is a question whether it is an appropriate evaluation amount. The evaluation of the software development man-hour cost is objective. Both the orderer and the ordering party strongly wanted to be able to execute with reasonableness. The same applies to the evaluation method using the FP value.

特許文献1に記載のソフトウェア見積りシステムでは、開発分野毎にFP算出に必要な情報を予め準備しておき、それらを呼び出してソフトウェア見積りに利用するようにしており、情報管理が煩雑であるという問題がある。開発言語別生産性は考慮されておらず、生産性調整も不可であり、費用見積りが不完全である。   In the software estimation system described in Patent Document 1, information necessary for FP calculation is prepared in advance for each development field, and the information is called up and used for software estimation, and information management is complicated. There is. Productivity by development language is not considered, productivity adjustment is impossible, and cost estimation is incomplete.

また、特許文献2に記載の見積り作業支援システムは開発工数の見積り及び開発コストの見積りという一連の見積り作業全体を支援できるようにしているが、開発対象システムのソフトウェア規模を見積もるための規模見積り条件を入力し、規模見積り条件に基づいてソフトウェア規模を見積り、開発工数を見積もるための工数見積り条件を入力し、工数見積り条件に基づいて開発工数を見積り、開発コストを見積もるためのコスト見積り条件を入力し、コスト見積り条件に基づいて開発コストを見積もるようにしているので、開発コストを迅速に得ることができない。開発言語別生産性値は考慮されておらず、生産性調整係数が提供側向けであり、調達側が利用できない問題がある。   In addition, the estimation work support system described in Patent Document 2 can support the entire series of estimation work of estimating the development man-hours and the development cost, but the size estimation condition for estimating the software scale of the development target system Enter the cost estimation conditions to estimate the software scale based on the scale estimation conditions, enter the effort estimation conditions to estimate the development man-hours, estimate the development man-hours based on the man-hour estimation conditions, and enter the development costs However, since the development cost is estimated based on the cost estimation condition, the development cost cannot be obtained quickly. There is a problem that productivity values by development language are not taken into account, and the productivity adjustment factor is for the providing side, and the procurement side cannot use it.

特許文献3は調整係数に提供側(開発業者)向けの観点が強く、調達側(ユーザ企業)の観点と異なっている問題がある。例えば提供側の開発言語経験年数、リーダのプロジェクト管理経験、開発支援ツールへの習熟度など、提供側の努力事項を開発工数費用の見積りに反映してしまうと、これは提供側から調達側へのコスト転嫁ということになる。特許文献3に記載のシステム開発見積支援システムでは、開発言語別生産性値は考慮されていない。また、調整係数を主観的に設定し、かつ調整係数の設定が煩雑であり、実務上もっと簡便で、誰からも設定方法を見れば同じ結果が設定されるような客観的な設定方法が求められている。   Patent Document 3 has a problem that the adjustment coefficient has a strong viewpoint for the provider (developer) and is different from the viewpoint of the procurement side (user company). For example, if the provider's efforts such as the development language experience of the provider, the project management experience of the leader, and the proficiency level of the development support tool are reflected in the estimation of the development man-hour cost, this will be transferred from the provider to the procurement side. It will be a cost pass-through. In the system development estimation support system described in Patent Document 3, the productivity value for each development language is not considered. Also, there is a need for an objective setting method in which the adjustment factor is set subjectively, and the adjustment factor setting is complicated, simpler in practice, and the same result can be set by anyone. It has been.

更に、上記特許文献1乃至3に記載のものは、いずれも新規案件についての見積りであり、改修案件への対応ができない問題がある。実務上システム案件の60〜80%程度が保守案件であると言われ、これに対応できなければビジネス効果が半減してしまう。   Furthermore, all of those described in Patent Documents 1 to 3 are estimates for new projects, and there is a problem that it is impossible to deal with repair projects. In practice, it is said that about 60 to 80% of system projects are maintenance projects, and if this cannot be handled, the business effect will be halved.

本発明は上述のような事情よりなされたものであり、本発明の目的は、ソフトウェア開発工数費用の評価を客観的にかつ公正な手法で、しかも簡易なシステムで合理性をもって行い得るソフトウェア開発工数費用の評価方法、評価値算出装置及びプログラムを提供することにある。即ち、本発明は、多様な環境や種々の開発言語に対応可能であり、多数の企業に利用され、客観的に比較・検証可能であり、実装に左右されずに論理的視点に立ち、関係者の納得と理解が得られ、システム構築の早期段階での計測が可能で、属人性を排除したアプローチが可能なソフトウェア開発工数費用見積りプログラム及びソフトウェア開発工数費用見積りプログラムを記憶した記憶媒体を提供することを目的とする。   The present invention has been made under the circumstances as described above, and an object of the present invention is to provide software development man-hours that can be used to evaluate software development man-hour costs in an objective and fair manner and with a simple system with reasonableness. An object is to provide a cost evaluation method, an evaluation value calculation device, and a program. In other words, the present invention is compatible with various environments and various development languages, is used by many companies, can be objectively compared and verified, has a logical viewpoint, and is not affected by the implementation. Software development man-hour cost estimation program that can be understood and understood by the user, can be measured at an early stage of system construction, and can be approached without personality, and a storage medium that stores the software development man-hour cost estimation program The purpose is to do.

本発明はソフトウェア開発工数費用の評価方法に関し、本発明の上記目的は、ソフトウェアの開発工数費用の見積りを行うためにコンピュータを、前記ソフトウェアの機能規模(ファンクションポイント)をFP値として入力する手段、一人月単位の開発可能規模を開発言語別生産性値として入力する手段、前記開発言語別生産性値を調整する生産性調整係数を入力する手段、基本設計、詳細設計、プログラム設計・製造、ソフトウェエアテスト及びシステムテストの各工程における工程別発注率を入力する手段、作業分担割合を作業分担率として入力する手段、前記ソフトウェアの前記各工程に対する改修割合を開発改修率として入力する手段、前記各工程における前記開発言語別生産性値、前記生産性調整係数、前記工程別発注率、前記作業分担率及び前記開発改修率をそれぞれ乗算して一人月当たりの生産性値を生産性係数として算出する手段、前記各工程における前記FP値を前記生産性係数で除算して標準開発工数を算出する手段、付帯作業工数を入力する手段、システムエンジニア単価金額を入力する手段、前記各工程における前記標準開発工数と前記付帯作業工数の和に前記システムエンジニア単価金額を乗算して開発費用を算出する手段、として機能させることによって達成される。   The present invention relates to a software development man-hour cost evaluation method, and the above object of the present invention is to provide a computer for estimating software development man-hour cost, and means for inputting a function scale of the software as a FP value. Means to input the development possible scale per month as the productivity value by development language, Means to input the productivity adjustment coefficient to adjust the productivity value by development language, basic design, detailed design, program design / manufacturing, software Means for inputting an order rate for each process in the air test and system test, means for inputting a work sharing ratio as a work sharing ratio, means for inputting a repair ratio for each process of the software as a development repair ratio, Productivity value by development language in each process, productivity adjustment factor, order rate by process, A means for calculating the productivity value per month as a productivity coefficient by multiplying the work sharing rate and the development and repair rate, respectively, and calculating the standard development man-hour by dividing the FP value in each process by the productivity coefficient Means for inputting an incidental work man-hour, means for inputting an amount of system engineer unit price, and calculating a development cost by multiplying the sum of the standard development man-hour and the incidental operation man-hour in each step by the system engineer unit price. This is achieved by functioning as a means.

また、本発明の上記目的は、ソフトウェアの開発工数費用の見積りを行うためにコンピュータを、前記ソフトウェアの機能規模(ファンクションポイント)をFP値として入力する手段、一人月単位の開発可能規模を開発言語別生産性値として入力する手段、前記開発言語別生産性値を調整する生産性調整係数を入力する手段、基本設計、詳細設計、プログラム設計・製造、ソフトウェアテスト及びシステムテストの各工程における工程別発注率を入力する手段、作業分担割合を作業分担率として入力する手段、前記基本設計、前記詳細設計及び前記プログラム設計・製造の各開発工程における前記ソフトウェアの開発改修割合を開発改修率として入力する手段、前記ソフトウェアテスト及び前記システムテストの各テスト工程における前記ソフトウェアのテスト改修割合をテスト改修率として入力する手段、前記各工程における前記開発言語別生産性値、前記生産性調整係数、前記工程別発注率、前記作業分担率及び前記開発改修率または前記テスト改修率をそれぞれ乗算して一人月当たりの生産性値を生産性係数として算出する手段、前記各工程における前記FP値を前記生産性係数で除算して標準開発工数を算出する手段、付帯作業工数を入力する手段、システムエンジニア単価金額を入力する手段、前記各工程における前記標準開発工数と前記付帯作業工数の和に前記システムエンジニア単価金額を乗算して開発費用を算出する手段、として機能させることによって達成される。   The above object of the present invention is to provide a computer for estimating the software development man-hour cost, a means for inputting the function scale of the software as an FP value, Means for inputting as a separate productivity value, means for inputting a productivity adjustment coefficient for adjusting the productivity value for each development language, and each process in basic design, detailed design, program design / manufacturing, software test and system test Means for inputting the order rate, means for inputting the work sharing ratio as the work sharing ratio, and inputting the development and repair ratio of the software in each development process of the basic design, the detailed design, and the program design / manufacturing as the development repair ratio Means in each test step of means, software test and system test Means for inputting a software test repair rate as a test repair rate, the productivity value for each development language in each step, the productivity adjustment factor, the ordering rate for each step, the work sharing rate and the development repair rate or the test Means for calculating the productivity value per month by multiplying the repair rate as a productivity coefficient; means for calculating the standard development man-hour by dividing the FP value in each process by the productivity coefficient; , Means for inputting the system engineer unit price, and means for calculating the development cost by multiplying the sum of the standard development man-hour and the incidental work man-hour in each step by the system engineer unit price. Achieved by:

また、本発明の上記目的は、入力される前記開発言語別生産性値について前記コンピュータを、1または複数の利用する開発言語を入力する手段、前記開発言語ごとに利用割合を入力する手段、予め各開発言語ごとに一人月当たりの生産性値を記憶しておく開発言語別生産性値テーブル記憶手段、前記開発言語別生産性値テーブルから入力された前記開発言語に対応する生産性値を読み出し、前記生産性値と前記生産性値に対応する前記利用割合とを乗算し、その総和を前記開発言語別生産性値として算出する手段、として機能させることにより、或いは入力される前記生産性調整係数を算出するためにコンピュータを、システム環境係数を入力するシステム手段、システム規模係数を入力するシステム手段、処理負荷係数を入力する手段、品質要求係数を入力する手段、ドキュメント係数を入力する手段、予め前記システム環境係数、前記システム規模係数、前記処理負荷係数及び前記品質要求係数の各項目について係数値を記録しておく生産性調整テーブル記憶手段、前記システム環境係数、前記システム規模係数、前記処理負荷係数及び前記品質要求係数のそれぞれ対応する各係数値を読み出して乗算し前記生産性調整係数を算出する手段、として機能させることにより、或いは入力される前記開発改修率についてコンピュータを、前記ソフトウェアの既存行数を改修前母体行数として入力する手段、前記ソフトウェアを利用した既存システムの改変行数を入力する手段、前記既存システムとは別に追加される外付け追加機能行数を入力する手段、前記改修前母体行数に前記ソフトウェアの改修後の前記改修前母体行数に対する確認作業で行われる作業割合をR1%として乗算し第一作業率を算出する手段、前記改修行数に前記ソフトウェア改修後の前記改修行数に対する確認作業で行われる作業割合をR2%として乗算し第二作業率を算出する手段、前記第一作業率乗算手段、前記第二作業率乗算手段及び前記外付け追加機能行数を加算して開発作業率を算出する手段、前記ソフトウェアの改修後の行数を改修後母体行数として入力する手段、前記開発作業率を前記改修後母体行数により除算し前記開発改修率を算出する手段、として機能させることにより、或いは入力される前記開発改修率についてコンピュータを、前記ソフトウェアのデータ項目種別数を改修前母体DET数として入力する手段、前記改修前母体DET数に改修後の前記改修前母体DET数に対する確認作業で行われる作業割合をR3%として乗算し第三作業率を算出する手段、前記ソフトウェアに対して改変を行う改変データ項目種別数を改変DET数として入力する手段、前記第三作業率と前記改変DET数の和を開発作業率として算出する手段、前記ソフトウェアの改修後のデータ項目種別数を改修後母体DET数として入力する手段、前記開発作業率を前記改修後母体DET数で除算して前記開発改修率を算出する手段、として機能させることより、或いは入力される前記テスト改修率についてコンピュータを、前記ソフトウェアの新規開発時のテスト項目数を改修前母体・新規開発時のテスト項目数として入力する手段、前記改修前母体・新規開発時のテスト項目数に改修後の前記改修前母体・新規開発時のテスト項目数に対する確認作業で行われる作業割合をR4%として乗算し第一テスト作業率として算出する手段、改修時に行われるテスト項目数を入力する手段、前記第一テスト作業率と前記テスト項目数を加算し全体テスト作業率を算出する手段、前記ソフトウェアが改修された後の新規開発時のテスト項目数を改修後母体・新規開発時のテスト項目数として入力する手段、前記全体テスト作業率を前記改修後母体・新規開発時のテスト項目数で除算して前記テスト改修率を算出する手段、として機能させることにより、或いはソフトウェア開発工数費用の見積りを行うためにコンピュータを、前記各工程における工程別発注率の総和を総発注率として算出する手段、として機能させることにより、或いはソフトウェアの開発工数費用の見積りを行うためにコンピュータを、前記各工程における開発費用の総和を総開発費用として算出する手段、として機能させることにより、或いはソフトウェア開発工数費用の見積りを行うためにコンピュータを、前記各工程における前記ソフトウェアの改修を依頼した依頼業者から提供される業者提示価格を入力する手段、前記各工程における前記業者提示価格の総和を総業者提示価格として算出する手段、前記各工程おける前記業者提示価格を前記開発費用で除算して価格格差率を算出する手段、前記総業者提示価格を前記総開発費用で除算して総価格格差率を算出する手段、として機能させることによって、より効果的に達成される。   Further, the above object of the present invention is to provide means for inputting one or a plurality of development languages for using the computer for the input productivity value for each development language, means for inputting a utilization ratio for each development language, Productivity value table storage means for each development language that stores the productivity value per month for each development language, and the productivity value corresponding to the development language input from the productivity value table for each development language is read out , Multiplying the productivity value by the utilization ratio corresponding to the productivity value, and calculating the sum as a productivity value for each development language, or by inputting the productivity adjustment A computer for calculating a coefficient, a system means for inputting a system environment coefficient, a system means for inputting a system scale coefficient, a means for inputting a processing load coefficient, Means for inputting quality requirement coefficient, means for inputting document coefficient, productivity adjustment table in which coefficient values are recorded in advance for each item of the system environment coefficient, the system scale factor, the processing load coefficient, and the quality requirement coefficient By functioning as a storage means, a means for calculating the productivity adjustment coefficient by reading and multiplying the corresponding coefficient values of the system environment coefficient, the system scale coefficient, the processing load coefficient, and the quality requirement coefficient, Alternatively, with respect to the development and renovation rate that is input, means for inputting the number of existing lines of the software as the number of parent lines before modification, means for inputting the number of modified lines of an existing system using the software, and the existing system Means for inputting the number of externally added function lines to be added separately, and Means for calculating the first work rate by multiplying the work ratio performed in the confirmation work for the number of parent lines before renovation after software renovation as R1%, and confirming the number of renovation lines after the software refurbishment The development work by adding the means for calculating the second work rate by multiplying the work ratio performed in the work as R2%, the first work rate multiplication means, the second work rate multiplication means, and the number of externally added function rows A means for calculating a rate, a means for inputting the number of modified lines of the software as a number of parent lines after modification, and a means for calculating the development / repair rate by dividing the development work rate by the number of modified mother lines Or a means for inputting the number of data item types of the software as the number of parent DETs before the modification, the number of parent DETs before the modification, A means for calculating the third work rate by multiplying the work ratio performed in the confirmation work on the number of parent DETs before repair after the repair as R3%, and the number of modified data item types for modifying the software as the modified DET number Means for inputting, means for calculating the sum of the third work rate and the number of modified DETs as a development work rate, means for inputting the number of data item types after modification of the software as the number of parent DETs after modification, the development work rate Is divided by the post-repair matrix DET number to calculate the development refurbishment rate, or the computer is renewed for the test renovation rate inputted, and the number of test items at the time of new development of the software is refurbished Means to input as the number of test items at the time of previous development / new development, the number of test items at the time of previous development / new development Means for multiplying the work ratio performed in the confirmation work with respect to the number of test items at the time of occurrence as R4% and calculating as a first test work ratio, means for inputting the number of test items performed at the time of repair, the first test work ratio and the Means for calculating the total test work rate by adding the number of test items; means for inputting the number of test items at the time of new development after the software has been renovated; By functioning as a means for calculating the test renovation rate by dividing the work rate by the number of test items at the time of the remodeling base / new development, or for estimating the software development man-hour cost, the computer By making it function as a means to calculate the total order rate by process in the process as the total order rate, or software development man-hours In order to estimate the software development man-hours, or to cause the computer to estimate the software development man-hour cost Means for inputting a contractor-provided price provided by a client who requested the software modification in the above, means for calculating a sum of the contractor-presented prices in each step as a total contractor-presented price, and the contractor-provided price in each step Is more effectively achieved by functioning as a means for calculating the price disparity ratio by dividing the development cost and a means for calculating the total price disparity ratio by dividing the total contractor presented price by the total development cost. Is done.

また、本発明の上記目的は、上述のソフトウェア開発工数費用見積りプログラムを記憶したコンピュータ読み取り可能な記憶媒体の提供によって達成される。 The above object of the present invention is achieved by providing a computer readable storage medium storing the above software development man-hour cost estimation program.

本発明によれば、比較的簡易なシステムであると共に、ソフトウェア開発工数費用の開発や環境を考慮した要素を評価の条件として合理的に入力するようにしているので、ソフトウェア開発工数費用の評価を客観的かつ公正な手法で行い得る。また、本発明によれば、新規案件のみならず、改修案件についてもソフトウェア機能規模の定量化を通して見積り価格の曖昧さを排除でき、評価の合理性、妥当性、透明性を高めることができる。   According to the present invention, it is a relatively simple system, and the development of the software development man-hour cost and the factors considering the environment are rationally input as the evaluation conditions, so the software development man-hour cost can be evaluated. It can be done in an objective and fair manner. Further, according to the present invention, it is possible to eliminate the ambiguity of the estimated price through quantification of the software function scale not only for a new case but also for a repair case, and improve the rationality, validity, and transparency of evaluation.

本発明はFP(ファンクションポイント)をソフトウェア評価の基本とし、ソフトウェアの開発状況やシステム環境を考慮した要素を評価の条件として重み付けを行って評価値演算に利用しており、また、評価のための入力条件が合理的な理由を有しているので、個人的な経験や勘に頼ることなく、客観性のある公正なソフトウェア開発費用の評価を得ることができる。   The present invention uses FP (function point) as a basis for software evaluation, weights the factors considering the software development status and system environment as evaluation conditions, and uses them for evaluation value calculation. Since the input conditions have a reasonable reason, an objective and fair evaluation of software development costs can be obtained without resorting to personal experience or intuition.

本発明は新規及び改修のいずれのソフトウェア開発案件を対象としているが、ハードウェア、ネットワーク、ミドルウェアなどの設計、導入作業費などは評価の対象としていない。また、システム開発プロセスのうち、SLCP(Software Life Cycle Process: ソフトウェアを中心としたシステム開発及び取引の明確化を目的に、ソフトウェア又はシステムの構想から運用や保守に至るまでのソフトウェアライフサイクルプロセスを可視化し、共通の枠組みを規定したもので、「共通フレーム」と呼ばれる)開発プロセス(開発プロセス開始の準備〜ソフトウェア受入れ支援)の見積りをFP法見積り評価の対象範囲とする。それ以外の企画や立案などのコンサルタント業務、データ移行や運用支援業務などの付帯作業の見積りは、作業積み上げ方式で評価するが、FP評価の対象としない。更に、本発明では、新規案件と改修案件のいずれも開発費用評価の対象としている。   The present invention targets both new and modified software development projects, but does not include hardware, network, middleware design, and installation work costs. In addition, among the system development processes, SLCP (Software Life Cycle Process: Visualization of software life cycle processes from conception of software or system to operation and maintenance for the purpose of clarifying system development and transactions centering on software. In addition, an estimation of a development process (preparation for starting a development process to support for software acceptance), which defines a common framework and is called a “common frame”, is the target of FP method estimation evaluation. Other consulting work such as planning and drafting, estimation of incidental work such as data migration and operation support work is evaluated by the work accumulation method, but is not subject to FP evaluation. Further, in the present invention, both new projects and repair projects are targeted for development cost evaluation.

見積りの前提が基本設計完了前の場合の見積り入力情報は、要件定義書及び伝票、帳票、画面、マスタファイル一覧であり、NESMA提案の概算法で見積りを行う。即ち、マスタファイル一覧を基に要件定義書の内容を参考にし、業務的な観点からILF(Internal Logical File: 計測対象システムである自システムが維持管理している論理マスタ)とEIF(External Interface File: 自システムが参照する他システム(計測対象システムと関連するシステム)の維持管理している論理マスタ)を特定し、FP規模を算出する。なお、NESMAはポーランドのFP法推進団体であり、NESMAがIFPUG法を改良してシステム開発の早期段階に適用できる概算法を提案した。   Estimated input information when the premise of the estimation is before the completion of the basic design is a requirement definition document, a slip, a form, a screen, and a master file list, and the estimation is performed by the NESMA proposed approximate method. That is, referring to the contents of the requirement definition document based on the master file list, ILF (Internal Logical File: logical master maintained by the local system that is the measurement target system) and EIF (External Interface File) from a business viewpoint : Identify the other system (logical master that maintains and manages the system related to the measurement target system) referenced by the own system, and calculate the FP scale. NESMA is a FP law promotion organization in Poland, and NESMA proposed an approximate method that can be applied to the early stages of system development by improving the IFPUG method.

また、見積りの前提が基本設計完了後の場合の見積り入力情報は、要求仕様書及び基本設計書、画面一覧及び画面仕様、帳票一覧及び帳票仕様、マスタファイル一覧及びマスタファイル仕様、インタフェースファイル一覧及びインタフェースファイル仕様である。そして、見積り方法はIFPUG(International Function Point Users Group)法でファンクションを洗い出し、各ファンクション毎の複雑さを評価し、未調整の機能規模(FP)を算出するようにしている。   Estimate input information when the premise of the estimate is after the completion of the basic design is the required specifications and basic design document, screen list and screen specification, form list and form specification, master file list and master file specification, interface file list and Interface file specification. As an estimation method, functions are identified by an IFPUG (International Function Point Users Group) method, the complexity of each function is evaluated, and an unadjusted function scale (FP) is calculated.

企業のビジネス業務の自動化(コンピュータ化)が一巡し、現在システム化案件のうち、新規開発案件(20〜40%)が少なく、殆どは保守案件(60〜80%)である。そのため、保守費用の見積り評価が重要な業務となっている。しかし、FP法(IFPUG法)では、保守案件における規模計測は保守の母体(追加・変更・削除する対象機能)しか計測できないため、同じシステムに対する保守であっても、軽微な保守と作り直しに近い保守などによってかかる手間が大きく異なる。かかる保守の度合いを明確に計って保守費用を見積り、また調達側がそれを評価することが不可欠となっている。このため、本発明では新規案件のみならず、改修案件をも評価の対象としている。   Automating business operations (computerization) of companies has been completed, and currently there are few newly developed projects (20-40%) among the systemized projects, most of which are maintenance projects (60-80%). For this reason, estimating and estimating maintenance costs is an important task. However, in the FP method (IFPUG method), the scale measurement in the maintenance project can only measure the base of maintenance (target function to be added, changed, or deleted), so even for maintenance on the same system, it is close to minor maintenance and remake The time required for maintenance varies greatly. It is indispensable that the maintenance cost is estimated by clearly measuring the degree of such maintenance, and the procurement side evaluates it. For this reason, in the present invention, not only new projects but also repair projects are targeted for evaluation.

以下に、本発明の実施の形態を、図面を参照して説明する。   Embodiments of the present invention will be described below with reference to the drawings.

図3は本発明の原理を模式的に示しており、所定の手法で求められたFP値に対して生産性モデルから生産性に関する情報を与え、次いで開発工数の人月単価(システムエンジニア単価金額)を入力し、所定演算式に従ってソフトウェア開発工数費用を算出する。生産性モデルに基づく生産性に関する情報をFP値に加味して開発工数等を算出するため、客観的で公正な評価を行い得る。   FIG. 3 schematically shows the principle of the present invention. Information on productivity is given from the productivity model to the FP value obtained by a predetermined method, and then the man-month unit price (system engineer unit price of the development man-hour). ) And calculate the software development man-hour cost according to a predetermined arithmetic expression. Since the development man-hours are calculated by adding productivity information based on the productivity model to the FP value, an objective and fair evaluation can be performed.

なお、生産性は、1人月当り“xxFP”のシステムを開発できるという指標を示しており、生産性モデルについては後述するが、(開発言語別生産性値×システム環境係数×システム規模係数×処理負荷係数×品質要求係数×ドキュメント係数×工程別発注率×作業分担率×改修率)のことを示している。   Productivity is an indicator that a system of “xxFP” can be developed per person per month, and the productivity model will be described later. (Production value by development language × system environment coefficient × system scale coefficient × (Processing load coefficient x Quality requirement coefficient x Document coefficient x Order rate by process x Work sharing rate x Repair rate).

図4は、本発明の評価値算出装置(コンピュータ)の構成例を示しており、コンピュータが有する入力手段より別途算出されたFPが数値で入力されると共に、システム開発状況やシステム環境等を考慮して選定されたシステム環境係数、システム規模係数、処理負荷係数、品質要求係数、ドキュメント係数、工程別発注率、作業分担率、改修率等の条件データ(C〜C)が入力され、さらにシステム評価のための評価用データが評価用データテーブルとして入力される。演算部10は入力されたFP、各条件データ及び評価用データテーブルに基づいて評価値(見積り)を算出して表示若しくは印字出力する。算出された評価値は、FPを基に各条件データ及び評価用データテーブルを加味して算出されているため、客観的で公正な評価値となっている。なお、評価用データテーブルは後述する開発言語別生産性値テーブル、生産性調整係数テーブル、開発工程別標準配分率テーブル、標準テスト項目件数テーブル等のデータである。 FIG. 4 shows an example of the configuration of the evaluation value calculation apparatus (computer) of the present invention. FP separately calculated from the input means of the computer is numerically input, and the system development status and system environment are taken into consideration. System environment factor, system scale factor, processing load factor, quality requirement factor, document factor, process-specific order rate, work sharing rate, repair rate, etc. (C 1 to C n ) Further, evaluation data for system evaluation is input as an evaluation data table. The calculation unit 10 calculates an evaluation value (estimation) based on the input FP, each condition data, and the evaluation data table, and displays or prints out the evaluation value. The calculated evaluation value is an objective and fair evaluation value because it is calculated by adding each condition data and the evaluation data table based on the FP. The evaluation data table is data such as a development language-specific productivity value table, a productivity adjustment coefficient table, a development process-specific standard distribution ratio table, and a standard test item number table, which will be described later.

図5はコンピュータの詳細な構成例を示しており、全体の制御や演算を実行する演算部(CPU)10には動作プログラムを格納したROM102と、各種データ入力が行われる入力手段110と、開発言語別生産性値テーブル記憶手段1031、生産性調整係数テーブル記憶手段1032、開発工程別配分率テーブル記憶手段1033、標準テスト項目件数テーブル記憶手段1034及びシステムエンジニア単価金額(SE単金)テーブル記憶手段1035を内部に含むRAM103と、データ等を表示する表示手段120と、データ等を印字出力する印刷手段121とから構成されている。   FIG. 5 shows a detailed configuration example of a computer. A calculation unit (CPU) 10 that executes overall control and calculation includes a ROM 102 that stores an operation program, an input unit 110 that inputs various data, and development. Productivity value table storage unit 1031 for each language, productivity adjustment coefficient table storage unit 1032, distribution ratio table storage unit 1033 for each development process, standard test item number table storage unit 1034, and system engineer unit price (SE unit price) table storage unit The RAM 103 includes 1035, the display unit 120 that displays data and the like, and the printing unit 121 that prints out data and the like.

開発言語別生産性値テーブル記憶手段1031には、利用される言語毎に設定された一人月当たりの生産性値が記憶される。生産性調整係数テーブル記憶手段1032には、後述するシステム規模係数、システム環境係数、処理負荷係数、品質要求係数及びドキュメント係数のそれぞれの入力値に対応する生産値が記憶される。開発工程別配分率テーブル記憶手段1033には、基本設計、詳細設計、プログラム設計・製造、ソフトウェアテスト及びシステムテストの各工程について一般的経験則に基づいた発注率が記憶される。標準テスト項目件数テーブル記憶手段1034には、ソフトウェアテスト及びシステムテストの各工程において行われるテスト項目件数について一般的経験則に基づく件数が記憶される。 The development language-specific productivity value table storage unit 1031 stores a productivity value per month set for each language used. The productivity adjustment coefficient table storage unit 1032 stores production values corresponding to input values of a system scale coefficient, a system environment coefficient, a processing load coefficient, a quality requirement coefficient, and a document coefficient, which will be described later. The distribution ratio table storage unit 1033 for each development process stores an order ratio based on general empirical rules for each process of basic design, detailed design, program design / manufacturing, software test, and system test. In the standard test item number table storage means 1034, the number of test items performed in each step of the software test and the system test is stored based on a general rule of thumb.

なお、一般的に経験則に基づいた発注率は、それぞれ16%、20%、36%、15%及び13%であるが、ソフトウェアの改修状況に基づいて入力手段110から入力されても構わない。また、一般的に経験則に基づいたテスト項目件数は通常、ソフトウェアテストの基準項目数がFP値×2.0件、システムテストの基準項目数がFP値×0.5件であるが、そのソフトウェア分野によっても異なる場合があるため、後述するソフトウェアテスト項目件数の適用にはそれぞれR5及びR6の代数を用いて表現している。また、これらのテーブル記憶手段は、演算部10が制御プログラムの指令を受けて予め作成される。もちろん、入力部110を動作させてこれらのテーブルに記憶されたテーブル値を入力された値に変化させることも可能である。   In general, the ordering rates based on empirical rules are 16%, 20%, 36%, 15%, and 13%, respectively, but they may be input from the input means 110 based on the software modification status. . In general, the number of test items based on empirical rules is usually that the number of standard items for software testing is FP value x 2.0 and the number of standard items for system test is FP value x 0.5. Since it may differ depending on the software field, the application of the number of software test items described later is expressed using algebra of R5 and R6, respectively. Further, these table storage means are created in advance when the arithmetic unit 10 receives a command from the control program. Of course, the input unit 110 can be operated to change the table values stored in these tables to the input values.

このような構成において、その動作を図6のフローチャートを参照して説明する。なお、以下の各ステップは、演算部10がROM102に記憶された制御プログラムの指令を受けて動作する。   In such a configuration, the operation will be described with reference to the flowchart of FIG. In the following steps, the calculation unit 10 operates in response to a command from a control program stored in the ROM 102.

先ず別途求められたFPが入力手段110より入力され(ステップS1)、次いで対象とするシステムが使用する言語に基づいて、言語別生産性値入力手段110より言語別生産性値、開発言語別生産性値が入力されると共に(ステップS2)、入力手段110より生産性調整係数が入力される(ステップS4)。生産性調整係数を算出するパラメータとして本発明では、生産性調整係数としてのシステムのプラットフォームを示すシステム環境係数、評価対象アプリケーションの規模を示すシステム規模係数、プロセスの形態(集中、分散)を示す処理負荷係数、システムの品質要求の度合い(レビュー、テスト、評価作業)を示す品質要求係数、作成するドキュメントの種類や数量を示すドキュメント係数が入力されて算出されても構わない。生産成長性係数のこれらパラメータからの算出の詳細は後述する。   First, the separately obtained FP is input from the input means 110 (step S1), and then based on the language used by the target system, the language-specific productivity value input means 110 and the language-specific productivity values are produced. A sex value is input (step S2), and a productivity adjustment coefficient is input from the input means 110 (step S4). In the present invention, as parameters for calculating the productivity adjustment coefficient, the system environment coefficient indicating the system platform as the productivity adjustment coefficient, the system scale coefficient indicating the scale of the application to be evaluated, and the process indicating the process form (concentration, distribution) The load coefficient, the quality requirement coefficient indicating the degree of system quality requirement (review, test, evaluation work), and the document coefficient indicating the type and quantity of documents to be created may be input and calculated. Details of the calculation of the production growth factor from these parameters will be described later.

さらに、開発プロセス(工程)の一部を自製したり、1案件を複数段階に分割して(工程別)発注したり、1案件を複数のベンダーに分割して(工程別)発注したりする場合の発注比率を示す工程別発注率(ステップS4A)、発注側(調達側)と受注側(提供側)との作業比率を示す作業分担率(ステップS4B)、機能改造の場合の改修率(ステップS4C)が設定され、入力される。なお、これらの入力順序は任意でもよい。   Furthermore, a part of the development process (process) is manufactured in-house, one item is divided into multiple stages (by process), and one item is divided into multiple vendors (by process). Order rate by process (step S4A) indicating the order ratio in the case, work sharing rate (step S4B) indicating the work ratio between the ordering side (procurement side) and the order receiving side (providing side), and the repair rate in the case of functional remodeling ( Step S4C) is set and entered. These input orders may be arbitrary.

上述のようにして演算のための条件とそのデータが入力されると、演算部101はROM102内に格納されたプログラムに従って演算を実行し(ステップS5)、その後に入力手段110より付帯作業工数が入力され(ステップS6)、所定の演算が実行される(ステップS7)。そして、入力手段110よりシステムエンジニア単価金額が入力され(ステップS8)、所定の演算を実行して終了する(ステップS9)。これにより、ソフトウェア開発工数費用の評価を数値で得ることができ、表示手段120で結果を見ることができると共に、印刷手段121で印字することができる。   When the condition for calculation and its data are input as described above, the calculation unit 101 executes the calculation according to the program stored in the ROM 102 (step S5), and then the incident work man-hours are input from the input means 110. Input (step S6), and a predetermined calculation is executed (step S7). Then, the system engineer unit price is input from the input means 110 (step S8), a predetermined calculation is executed, and the process ends (step S9). Thereby, the evaluation of the software development man-hour cost can be obtained as a numerical value, the result can be seen on the display means 120, and the printing means 121 can be printed.

なお、ステップS4Aの工程別発注率が入力されない場合もある。この場合、開発工程別標準配分率テーブル記憶手段1033に記憶された標準配分率(標準発注率)のデータを読み出して、工程別発注率として演算が行われる。   Note that the order rate for each process in step S4A may not be input. In this case, the data of the standard distribution rate (standard order rate) stored in the standard distribution rate table storage unit 1033 for each development process is read, and calculation is performed as the order rate for each process.

上述の例ではデータ入力毎に演算しているが、図7に示すように全てのデータを入力してから演算を行うようにしても良い。この場合、FP、開発言語別生産性値、生産性調整係数、工程別発注率、作業分担率、改修率、付帯作業工数及びSE単金の入力の順番は任意である。   In the above example, the calculation is performed every time the data is input, but the calculation may be performed after all the data is input as shown in FIG. In this case, the order of inputting FP, productivity value by development language, productivity adjustment coefficient, ordering rate by process, work sharing rate, repair rate, incidental work man-hours, and SE unit money is arbitrary.

図8は、本発明による新規開発案件及び改修案件の開発規模、工数、費用のコンピュータでの算出方法の流れを詳細に示しており、先ずソフトウェア規模(FP)の算出を行ってデータ入力を行うが、本発明ではIFPUG法、概算法、論理ファイル推定法又はステップ逆算法のいずれかを使用する。IFPUG法は、ILF(Internal Logical File)+EIF(External Interface File)+EI(External Input)+EO(External Output)+EQ(External Inquiry)で各機能の重み付けがあり、VAFの調整はなしとなっており、概算法は、ILF+EIF+EI+EO+EQで各機能の重み付けはなく、VAFの調整もなしとなっている。VAF(Value Adjusted Factor)とは、IFPUG法で提示されている調整要因(生産性調整係数)である。また、論理ファイル推定法はILF数×35+EIF数×15であり、ステップ逆算法は言語別ステップ数÷言語別FP当りステップ数である。   FIG. 8 shows in detail the flow of a computer-based calculation method for the development scale, man-hours, and costs of a new development project and a repair project according to the present invention. First, the software scale (FP) is calculated and data is input. However, in the present invention, any of the IFPUG method, the approximate method, the logical file estimation method, or the step back calculation method is used. The IFPUG method has ILF (Internal Logical File) + EIF (External Interface File) + EI (External Input) + EO (External Output) + EQ (External Inquiry), and there is no adjustment of VAF. Is ILF + EIF + EI + EO + EQ, each function is not weighted, and VAF is not adjusted. VAF (Value Adjusted Factor) is an adjustment factor (productivity adjustment factor) presented by the IFPUG method. Further, the logical file estimation method is ILF number × 35 + EIF number × 15, and the step inverse calculation method is language step number / language step number per FP.

上述のようにして計算されたFPが演算部10に入力されると、開発言語別生産性値及び生産性係数の入力を行う。つまり、開発言語別生産性値、生産性調整係数(システム規模係数、システム環境係数、処理負荷係数、品質要求係数、ドキュメント係数)、工程別発注率、作業分担率及び改修率の入力を行う。ソフトウェア言語としては、COBOL85、Microfocus COBOL、C、C++、Visual C++、JAVA/JAVA Script、ABAP/4、Oracle Developer/2000、Access、EXCEL、PL/SQL等があるが、ソフトウェア言語によって人月生産性が異なる。そのため使用言語に対する人月生産性を予め開発言語別生産性値テーブル1031に設定しておき、当該開発システムの使用言語に基づいてデータを読み出して人月生産性を入力する。例えばCOBOL85やCは人月生産性が低く、Visual Basic, C++などは人月生産性が高い。なお、同一ソフトウェアの開発に複数の言語を採用した場合、それぞれの割合を算出して全体の開発言語別生産性値を合算する。   When the FP calculated as described above is input to the arithmetic unit 10, the productivity value and productivity coefficient for each development language are input. In other words, the productivity value for each development language, the productivity adjustment factor (system scale factor, system environment factor, processing load factor, quality requirement factor, document factor), ordering rate for each process, work sharing rate, and repair rate are input. Software languages include COBOL85, Microfocus COBOL, C, C ++, Visual C ++, JAVA / JAVA Script, ABAP / 4, Oracle Developer / 2000, Access, EXCEL, PL / SQL, etc. Is different. Therefore, the man-month productivity for the language used is set in advance in the productivity value table 1031 for each development language, data is read based on the language used for the development system, and the man-month productivity is input. For example, COBOL85 and C have low man-month productivity, and Visual Basic, C ++, etc. have high man-month productivity. In addition, when a plurality of languages are adopted for the development of the same software, the respective ratios are calculated, and the total productivity values for each development language are added up.

また、生産性調整係数内のシステム環境係数はPCスタンドアロン形態、ホスト集中形態、単一プラットフォーム構成(ALL UNIX又はALL Windows)、複式プラットフォーム構成(UNIX、Windows、LINUX)によって生産性が相違するため、システム環境に基づいた係数を設定する。システム規模係数はFPの値によって判断し、規模の大小によって係数値を変える。処理負荷係数はプロセスの形態によって判断し、単一部門/拠点で少人数利用の場合(例えばローカル系や部門内小規模システム)、単一部門/拠点で多人数利用の場合(例えばプロセス集中処理、ホスト系)、複数部門/拠点で多人数利用の場合(例えばプロセス分散処理、基幹系)で生産性が相違するため、各場合によって係数値を変える。品質要求係数はユーザからの品質要求が特にない場合(動作確認程度)、ユーザからの品質要求が普通である場合(マスタ状態確認)、ユーザからの品質要求が厳しい場合(大規模トランザクション/データ性能確認)であるかによって生産性が相違するため、各場合によって係数値を変える。ドキュメント係数に関しては、例えばSLCP例示ドキュメントのうち作成されたものが50%未満である場合、SLCP例示ドキュメントのうち作成されるものが51%〜100%程度である場合、SLCP例示ドキュメントのうち作成されるものが100%を超える場合で生産性が相違するため、各場合によって係数値を変える。なお、生産性調整係数は生産性調整係数テーブル1032に格納されている。   In addition, the system environment factor within the productivity adjustment factor is different in productivity depending on the PC stand-alone form, host centralized form, single platform configuration (ALL UNIX or ALL Windows), and dual platform configuration (UNIX, Windows, LINUX). Set the coefficient based on the system environment. The system scale factor is determined by the value of FP, and the coefficient value is changed according to the size of the scale. The processing load coefficient is determined according to the form of the process. When a small number of people are used in a single department / base (for example, a local system or a small-scale system within a department), or when a large number of people are used at a single department / base (for example, process intensive processing) , Host system), and multiple departments / bases using a large number of people (for example, distributed process, basic system), the productivity differs, so the coefficient value is changed in each case. The quality requirement coefficient is when there is no quality requirement from the user (operation confirmation level), when the quality requirement from the user is normal (master status confirmation), when the quality requirement from the user is severe (large-scale transaction / data performance) Since the productivity differs depending on whether the confirmation is), the coefficient value is changed in each case. Regarding the document coefficient, for example, when the SLCP example document created is less than 50%, when the SLCP example document created is about 51% to 100%, the SLCP example document is created. Since the productivity differs when the amount exceeds 100%, the coefficient value is changed in each case. Note that the productivity adjustment coefficient is stored in the productivity adjustment coefficient table 1032.

工程別発注率は、開発プロセスの一部を自製する場合、1案件を複数段階に分割して発注する場合、1案件を複数の提供者に分割して発注する場合等で生産性が相違するため、開発プロセス全体を一まとめにして提供者に発注する場合の比率を100%とし、各場合の比率を入力する。作業分担率は、開発プロセスの一部作業を自製したり、1案件を複数の提供者に分割して発注する場合があり、このような場合、双方の作業分担の度合い(原則は工数ベース)を勘案して作業分担率を設定することが有効である。開発プロセスの全ての作業を提供者に発注する場合(完全請負)の作業分担率を100%とする。改修は既存システムに対して機能を追加、変更、削除することをいい、改修案件の見積り評価は、既存母体システム(対象システム)を新規で開発した場合の改修率を100%とし、既存母体システムに対する追加、変更、削除の割合を定量化して、改修案件工数の見積りを評価する。改修規模は下記(1)式で定義される。

改修規模=改修母体規模×改修率 …(1)

開発言語別生産性値及び生産性調整係数並びに工程別発注率、作業分担率、改修率が入力された後、演算部10はこれら入力されたFP、開発言語別生産性値及び生産性調整係数並びに工程別発注率、作業分担率、改修率に対して、下記(2)式に従って標準開発作業工数Aの演算を行う。

標準開発作業工数A= FP÷生産性係数
=FP÷(開発言語別生産性値×生産性調整係数×工程別発注率
×作業分担率×改修率)
=FP÷{開発言語別生産性値×システム規模係数k1×システム
環境係数k2×処理負荷係数k3×品質要求係数k4×
ドキュメント係数k5×工程別発注率×作業分担率×改修率}
…(2)
なお、k1〜k5は図15に示す生産性調整テーブル記憶手段1032に記憶された調整値である。入力手段110からの入力に基づいて、各調整値が適用されることを表す。

その後、入力手段110より付帯作業工数を入力し、下記(3)式の演算を行う。「付帯作業」とは、上記標準開発作業以外に発注者から提供者に委託した作業を指し、これらの作業を遂行するために発生する費用を「付帯作業工数」と定義する。そして、下記(3)式を演算する。

開発工数B=標準開発作業工数A+付帯作業工数 …(3)

その後、更に入力手段110よりシステムエンジニア単価金額テーブル記憶手段1035からデータを読み出してシステムエンジニア単価金額を入力し、下記(4)式の演算を行う。これにより、ソフトウェア開発費用(C=開発工数×SE単金)が得られる。

開発費用C=開発工数B×システムエンジニア単価金額 …(4)

即ち、ソフトウェア開発費用の演算式は下記(5)式となる。

開発費用={機能規模FP÷(開発言語別生産性値×生産性調整係数×工程別発注率
×作業分担率×改修率)+付帯作業工数}×システムエンジニア単価金額
…(5)

一方、開発言語別生産性値は例えば下記(6)式によって計算され、予め開発言語別生産性値テーブル記憶手段1031に格納されている。この場合、各開発言語別の生産性(7.5FP/人月〜40FP/人月)が開発言語別生産性値テーブル記憶手段1031に格納され、利用者が開発言語を選択し、それぞれの利用割合(開発する機能の多さ)を入力することによって言語の生産性が自動的に付与される。

開発言語別生産性値=(開発言語#1の生産性値×利用割合m1)
+(開発言語#2の生産性値×利用割合m2)
+(開発言語#3の生産性値×利用割合m3)
+(開発言語#4の生産性値×利用割合m4)
+(開発言語#5の生産性値×利用割合m5)
…(6)

また、生産性調整係数は下記(7)式に基づいて計算される。なお、各係数は0.80〜1.20の範囲で設定され、表示手段120の入力画面を参照して所定の調整係数が選択入力されることによって、その値が一意的に付与される。

生産性調整係数=システム規模係数k1×システム環境係数k2×
処理負荷係数k3×品質要求係数k4×
ドキュメント係数k5 …(7)

なお、図6では開発言語別生産性値及び生産性調整係数等を入力後に(2)式の演算、付帯作業工数の入力後に(3)式の演算、システムエンジニア単価金額の入力後に(4)式の演算を行うようになっているが、図7に示すように開発言語別生産性値、生産性調整係数等、付帯作業工数及びシステムエンジニア単価金額の入力後に続けて(2)〜(4)式を連続的に演算するようにしても良い。

以下、本発明の具体例を説明する。
The order rate for each process differs in productivity depending on cases such as when a part of the development process is manufactured in-house, one item is divided into multiple stages, and one item is divided into multiple providers. Therefore, the entire development process is put together and the ratio when placing an order with the provider is 100%, and the ratio in each case is input. The work sharing rate may be that some work in the development process is made in-house, or one project is divided into multiple providers and placed in order. In such cases, the degree of work sharing between the two (in principle, man-hour basis) It is effective to set the work sharing rate taking this into consideration. The work sharing rate is 100% when all work in the development process is ordered from the provider (complete contract). Refurbishment means adding, changing, or deleting functions from an existing system. Estimating and evaluating a renovation project assumes that the existing parent system (target system) is newly developed and the repair rate is 100%. Quantify the rate of additions, changes, and deletions to and evaluate the estimated number of repair project man-hours. The scale of renovation is defined by the following formula (1).

Repair scale = repair base scale x repair rate (1)

After inputting the productivity value and productivity adjustment coefficient by development language, and the order rate, work sharing ratio, and repair rate by process, the calculation unit 10 inputs these input FP, productivity value by productivity language, and productivity adjustment coefficient. In addition, the standard development work man-hour A is calculated according to the following equation (2) with respect to the order-by-process rate, work sharing rate, and repair rate.

Standard development man-hours A = FP / productivity factor
= FP ÷ (Production value by development language x Productivity adjustment factor x Order rate by process
(Work share rate x repair rate)
= FP ÷ {Production value by development language x System scale factor k1 x System
Environmental coefficient k2 x processing load coefficient k3 x quality requirement coefficient k4 x
Document factor k5 x order rate by process x work share rate x repair rate}
... (2)
Note that k1 to k5 are adjustment values stored in the productivity adjustment table storage unit 1032 shown in FIG. It represents that each adjustment value is applied based on the input from the input means 110.

Thereafter, the incidental work man-hours are input from the input means 110, and the following equation (3) is calculated. “Ancillary work” refers to work commissioned by the orderer to the provider in addition to the standard development work, and the cost incurred for performing these work is defined as “additional work man-hour”. Then, the following equation (3) is calculated.

Development man-hour B = Standard development work man-hour A + incidental work man-hours (3)

Thereafter, the data is further read from the system engineer unit price table storage unit 1035 from the input unit 110, the system engineer unit price is input, and the following equation (4) is calculated. As a result, software development costs (C = development man-hours × SE simple money) are obtained.

Development cost C = Development man-hour B x System engineer unit price ... (4)

That is, the calculation formula of the software development cost is the following formula (5).

Development cost = {Function scale FP ÷ (Production value by development language x Productivity adjustment factor x Order rate by process
X work sharing rate x renovation rate) + incidental man-hours} x system engineer unit price
... (5)

On the other hand, the productivity value for each development language is calculated by, for example, the following expression (6) and stored in advance in the productivity value table storage unit 1031 for each development language. In this case, the productivity (7.5 FP / person month to 40 FP / person month) for each development language is stored in the productivity value table storage means 1031 for each development language, the user selects the development language, and each usage ratio By inputting (the number of functions to be developed), language productivity is automatically given.

Productivity value by development language = (Production value of development language # 1 x usage rate m1)
+ (Development language # 2 productivity value x usage rate m2)
+ (Productivity value of development language # 3 x usage rate m3)
+ (Production value of development language # 4 x usage rate m4)
+ (Production value of development language # 5 x usage rate m5)
(6)

Further, the productivity adjustment coefficient is calculated based on the following equation (7). Each coefficient is set in a range of 0.80 to 1.20, and a predetermined adjustment coefficient is selected and input with reference to the input screen of the display unit 120, whereby the value is uniquely given.

Productivity adjustment factor = system scale factor k1 × system environment factor k2 ×
Processing load coefficient k3 × quality requirement coefficient k4 ×
Document coefficient k5 (7)

In FIG. 6, after inputting the productivity value and productivity adjustment coefficient for each development language, the calculation of formula (2), the calculation of formula (3) after the input of the incidental man-hours, and the input of the system engineer unit price (4) As shown in FIG. 7, (2) to (4) after the input of the productivity value for each development language, the productivity adjustment coefficient, etc., the incidental work man-hours and the system engineer unit price, as shown in FIG. ) Equation may be calculated continuously.

Hereinafter, specific examples of the present invention will be described.

本発明はソフトウェア開発(改修)案件を対象とし、ハードウェア、ネットワーク、ミドルウェアなどの設計、導入作業費などは評価の対象とせず、システム開発プロセスのうち、SLCP開発プロセス(開発プロセス開始の準備〜ソフトウェア受入れ支援)の見積りをFP法見積り評価の対象範囲としている。それ以外の企画や立案などのコンサルタント業務、データ移行や運用支援業務などの付帯作業の見積りは「作業積み上げ方式」で評価するが、FP評価の対象としない。本発明は、新規案件と改修案件を対象とする点に特徴がある。   The present invention targets software development (renovation) projects, and does not evaluate hardware, network, middleware, etc. design and installation work costs. Among the system development processes, the SLCP development process (preparation for starting the development process) Software reception support) is the target of FP method estimation evaluation. Other work such as consulting work such as planning and drafting, and estimation of incidental work such as data migration and operation support work are evaluated by the “work accumulation method”, but are not subject to FP evaluation. The present invention is characterized in that it deals with new projects and repair projects.

FP法はソフトウェア規模を測定するための手法(尺度)の1つであり、ソフトウェアのデータや機能の数と複雑度を計測することで、そのソフトウェアの機能規模(FP値)を算出する。図9は、本発明で採用するFP法の概略を示している。   The FP method is one of the methods (scales) for measuring the software scale, and the software function scale (FP value) is calculated by measuring the number and complexity of the software data and functions. FIG. 9 shows an outline of the FP method employed in the present invention.

ファンクションの種別はILF、EIF、EI、EO、EQであり、ILFはユーザが識別でき自システム(計測対象システム)が維持管理している論理データのまとまりであり、EIFはユーザが識別でき他システム(計測対象システムと関連するシステム)が維持管理し、自システムが参照している論理データのまとまりである。また、EIはシステム境界外からデータを投入して、ILFを維持管理(登録、更新、削除)する機能であり、EOはILFやEIFを参照してユーザや他システムへ情報を提供する機能で、情報提供に計算式や導出データが含まれ、EQはILFやEIFを参照してユーザや他システムへ情報を提供する機能で、情報提供に計算式や導出データは含まれていない。   Function types are ILF, EIF, EI, EO, EQ, ILF is a set of logical data that can be identified by the user and maintained by the own system (measurement target system), and EIF can be identified by the user to other systems It is a collection of logical data maintained and managed by the system related to the measurement target system and referenced by the own system. EI is a function that inputs data from outside the system boundary and maintains and manages (registers, updates, deletes) the ILF. EO refers to a function that provides information to users and other systems by referring to the ILF and EIF. The provision of information includes calculation formulas and derived data, and EQ is a function of providing information to users and other systems by referring to the ILF and EIF, and the information provision does not include calculation formulas or derived data.

ソフトウェアの機能規模がそのソフトウェア開発工数、費用と強い相関が見られることから、FP値を使用して開発工数、費用を見積もることが考えられる。例えば、1人当り10FPの生産性で1000FPのシステムを開発するのに100人月かかる。更に、1人月のSE単金が90万円の場合、開発費用が9000万円となる。発注側が独自でFP値を計測して開発工数費用を算出し、提供者から徴収した見積りの妥当性を評価するものとし、本発明では上記FPを用いて、前記(5)式を使ってシステム開発費を見積もる。   Since the function scale of software has a strong correlation with the software development man-hours and costs, it is conceivable to estimate the development man-hours and costs using the FP value. For example, it takes 100 man-months to develop a 1000 FP system with a productivity of 10 FP per person. In addition, if the cost per person per month is 900,000 yen, the development cost will be 90 million yen. The ordering side independently measures the FP value, calculates the development man-hour cost, and evaluates the validity of the estimate collected from the provider. In the present invention, the above FP is used and the system using the formula (5) is used. Estimate development costs.

かかるシステム開発費見積りの精度を上げるため、FP値を正確に計測する必要がある。仮に提供側からFPを取得した場合、提供者が提示したFP値が正しいか否か、発注側が自ら検証しなければならない。   In order to increase the accuracy of such system development cost estimation, it is necessary to accurately measure the FP value. If the FP is acquired from the providing side, the ordering side must verify whether or not the FP value presented by the provider is correct.

図10は、開発規模(FP)算出のための入力情報と算出方法を示している。即ち、見積りの前提として企画立案完了#1、企画立案完了#2、要件定義完了、基本設計完了があり、企画立案完了#1はステップ逆算法で見積もるために既存システム言語別プログラム行数、ソースコード及びシステム企画内容を入力する。企画立案完了#2は論理ファイル推定法で見積るためにER一覧、マスタデータ一覧及びシステム企画内容を入力し、要件定義完了は概算法で見積もるために機能要件全体概要、現行業務の流れ、システム化計画、システム機能概要及び機能・画面帳票・DB一覧を入力し、基本設計完了はIFPUG法で見積もるために機能要件、現行業務の流れ、システム化計画、システム機能概要、システム機能詳細及び機能・画面帳票・DB一覧とレイアウトを入力する。   FIG. 10 shows input information and a calculation method for calculating the development scale (FP). In other words, as the premise of the estimation, there is planning completion # 1, planning completion # 2, requirement definition completion, basic design completion, and planning planning completion # 1 is the number of program lines for each existing system language and source for estimation by the step inverse calculation method Enter the code and system planning details. Plan planning completion # 2 inputs ER list, master data list and system planning contents to estimate by logical file estimation method, and completes functional requirements, current work flow, systematization to estimate requirement definition by estimation method Enter the plan, system function overview and function / screen form / DB list, and the basic design completion can be estimated by the IFPUG method, functional requirements, current work flow, systemization plan, system function overview, system function details and function / screen Enter the form / DB list and layout.

本発明ではFP法を活用したシステム開発費見積り評価を行うが、本発明では特に下記4点に留意している。
(1)可能な限りIFPUG法に準拠して計測する。
FP法はIFPUGの他にも、複数の手法が存在する。これらは概ね同様なコンセプ
トに基づいているが、それぞれの着眼点が違うため、計測されたFP値の意味も異な
ってくる。本発明では、FPの計測方法やその粒度は、「IFPUG法(国際標準規
格ISO20926:2003:IFPUG法)」に準拠する。IFPUG法以外の
手法を適用して算出したFP値とIFPUG法のFP値との関連を明確にする必要が
ある。
なお、「国際標準規格ISO20926:2003:IFPUG法」で「機能要件
と品質技術要件と分離する」との解釈に従い、本発明では、FPは未調整FPとす
る。即ち、ータファンクションとトランザクションファンクションの規模をFPと
し、14項目の般システム特性を用いた調整は行わない。そのシステムの品質、技
術要件はシステム特性調整係数で評価し、システム開発工数費用に反映される。
(2)複数手法の併用を推奨する。
IFPUG法を適用してFPを計測する場合、システムの基本設計が完了し、かつ
計測で必要な入力情報が揃っていることを前提とする。しかし、実務ではもっと早い
時期に見積りが行われることがよくある。例えば要件定義完了時点での費用の推定な
どである。このような早期段階でFPを計測する場合、計測者が入手できる入力情報
(仕様書)の種類や詳細度が限られているため、いくつかの簡易計測法が考案されて
いる。ここで強調したいことは、(a)可能な限りIFPUG法に近付ける方法を適
用すること、(b)簡易法を利用した場合、可能な限り複数の手法を実施し、検証を
行うことである。
(3)見積り評価の目的はコスト適正化である。
本発明で提案しているシステム開発費用の見積り評価方法は、開発プロセスの標準
業を対象としている。実務でのシステム開発案件は、開発プロセスの一部しか発注
しないか、又は開発プロセス以外の作業も発注している場合がよく見受けられるこ
のことを念頭において、システム開発費用の見積り評価に臨まなければならない。本
発明のシステム開発作業が受注側と発注側との協同作業であって、両者が同じゴール
を目指さなければ上手くいかないことに着眼し、見積り評価業務は提供者の開発費用
見積りを安く叩くことではなく、双方で確認、納得できる適性コストに対する客観的
な根拠(目安)を示すことに立脚する。
(4)可能な限り定量化を図る。
見積り評価作業の客観性を保つには、評価の根拠を可能な限り定量化する必要があ
る。特に改修案件について、世間ではシステム開発費用の60%以上をシステム改修
に充てているにも拘わらず、今まで有効な見積り評価方法が提唱されていない。この
実状を勘案すると、改修案件の見積評価に注力しなければ、情報システム部門が経営
者や利用部門への説明義務が果たせない。従って、本発明では改修度合いを定量化し
、改修案件の見積評価にも確実に対応している。
In the present invention, the system development cost estimation evaluation utilizing the FP method is performed. In the present invention, the following four points are particularly noted.
(1) Measure according to the IFPUG method as much as possible.
In addition to the IFPUG, there are a plurality of methods for the FP method. These are generally based on the same concept, but each observing point is different, so the meaning of the measured FP value is also different. In the present invention, the FP measurement method and its granularity conform to the “IFPUG method (international standard ISO 20926: 2003: IFPUG method)”. It is necessary to clarify the relationship between the FP value calculated by applying a method other than the IFPUG method and the FP value of the IFPUG method.
According to the interpretation of “separate from functional requirements and quality technical requirements” in “International Standard ISO 20926: 2003: IFPUG method”, in the present invention, FP is an unadjusted FP. In other words, the scale of the data function and transaction function is FP, and no adjustment is made using the 14 general system characteristics. The quality and technical requirements of the system are evaluated by the system characteristic adjustment factor and reflected in the system development man-hour cost.
(2) Use of multiple methods is recommended.
When measuring the FP by applying the IFPUG method, it is assumed that the basic design of the system has been completed and the input information necessary for measurement is available. In practice, however, estimates are often made earlier. For example, cost estimation at the time of requirement definition completion. When measuring FP at such an early stage, the types and details of the input information (specifications) available to the measurer are limited, and several simple measurement methods have been devised. What we want to emphasize here is (a) applying a method that is as close as possible to the IFPUG method, and (b) using the simplified method to implement and verify as many methods as possible. .
(3) The purpose of estimation evaluation is cost optimization.
The system development cost estimation and evaluation method proposed in the present invention targets the standard industry of the development process. In practical system development projects, it is often necessary to place an order for only a part of the development process, or to order work other than the development process. I must. Focusing on the fact that the system development work of the present invention is a collaborative work between the order-receiving side and the ordering side, and if both do not aim at the same goal, it will not work, and the estimation evaluation work will hit the development cost estimate of the provider cheaply Rather, it is based on providing an objective basis (guideline) for aptitude costs that can be confirmed and understood by both parties.
(4) Quantify as much as possible.
In order to maintain the objectivity of the estimation evaluation work, it is necessary to quantify the basis of evaluation as much as possible. In particular, for renovation projects, no effective estimation evaluation method has been proposed so far, despite the fact that more than 60% of system development costs have been devoted to system renovation. Considering this situation, the information system department cannot fulfill its obligation to explain to the managers and user departments without focusing on the estimation of the renovation project. Therefore, in the present invention, the degree of repair is quantified and the estimated evaluation of the repair project is also dealt with reliably.

ここにおいて、システム開発工数、費用の見積り評価で最も重要なことは、1)精度の高いFP値を得ること、2)精度の高い生産性係数を入力すること、3)明確で双方(発注側、受注側)が認識、合意できるスコープ(作業範囲)であること、4)改修案件の改修率の定量化が可能なこと、である。これら4つの要素に関して弛まぬ努力で精度の向上を念頭におき、独自の実績データを蓄積し、見積り評価で適用する各種係数の精度向上を追求する必要がある。本発明はかかる要求を満たすものである。   Here, the most important points in estimating and evaluating system development man-hours and costs are 1) obtaining a highly accurate FP value, 2) inputting a highly accurate productivity factor, and 3) clear and bilateral (ordering side) The scope (working range) that the ordering party) can recognize and agree on, and 4) The repair rate of the repair project can be quantified. With these four factors in mind, it is necessary to keep in mind the improvement of accuracy, accumulate original performance data, and seek to improve the accuracy of various coefficients applied in estimation evaluation. The present invention satisfies this need.

システム開発費用見積りの結果として、開発費用が算出される。上記(5)式で算出された開発費用は発注者が自ら見積もったもので、いわゆる評価用標準価格的なものである。これに対して、受注者から取得した見積りは業者提示価格と定義され、評価用標準価格と業者提示価格とを比較して差異の有無を検証するが、この比較行為が見積りの評価ということになる。   The development cost is calculated as a result of the system development cost estimate. The development cost calculated by the above equation (5) is estimated by the orderer himself and is a so-called standard price for evaluation. On the other hand, the estimate obtained from the contractor is defined as the contractor-provided price, and the standard price for evaluation is compared with the contractor-provided price to verify whether there is a difference. Become.

図11はシステム開発費用の構成を示しており、システム開発費用にはハードウェア費用、ミドルウェア及びシステム開発費用が含まれるが、本発明ではそのうちのシステム開発費用内のソフトウェア開発費用のみを評価の対象とする。本発明におけるソフトウェア開発はSLCPの開発プロセスを指し、開発プロセスの範囲は図12に示すようになっている。即ち、開発プロセスの範囲としては企画プロセス、開発プロセス、運用プロセス及び保守プロセスがあり、本発明はそのうちの開発プロセスを対象とし、プロセス開始の準備、システム要求分析、システム方式設計、業務詳細設計、ソフトウェア要求分析、ソフトウェア方式設計、ソフトウェア詳細設計、ソフトウェアコード作成及びテスト、ソフトウェア結合、ソフトウェア適合性確認テスト、システム結合、システム適合性確認テスト、ソフトウェア導入、ソフトウェア受入れ支援について評価する。なお、図11における安定稼動システムの運営と維持管理業務は、月間基準勤務時間が160h/月(150h/月〜170h/月)であり、開発工数は開発プロセス工程作業を対象とし、付帯作業は開発プロセス工程以外の作業を対象としている。   FIG. 11 shows the composition of system development costs. The system development costs include hardware costs, middleware, and system development costs. In the present invention, only software development costs within the system development costs are evaluated. And Software development in the present invention refers to the SLCP development process, and the scope of the development process is as shown in FIG. In other words, the scope of the development process includes a planning process, a development process, an operation process, and a maintenance process, and the present invention targets those development processes, preparing for process start, system requirements analysis, system method design, detailed operation design, Software requirements analysis, software method design, detailed software design, software code creation and testing, software integration, software compatibility verification test, system integration, system compatibility verification test, software installation, software acceptance support are evaluated. In addition, the operation and maintenance work of the stable operation system in FIG. 11 has a monthly standard working time of 160 h / month (150 h / month to 170 h / month), the development man-hours are targeted for the development process process work, and the incidental work is It is intended for work other than the development process.

また、本発明では開発工程を基本設計、詳細設計、プログラム設計・製造、ソフトウェアテスト、システムテストの5工程に分け、それぞれのSLCPアクティビティとの対応関係は図13に示すようになっている。即ち、基本設計としてプロセス開始の準備、システム要求分析、システム方式設計、ソフトウェア要求分析及びソフトウェア方式設計があり、詳細設計として業務詳細設計及びソフトウェア詳細設計がある。プログラム設計・製造はソフトウェアコード作成及びテストであり、ソフトウェアテストはソフトウェア結合及びソフトウェア適合性確認テストであり、システムテストとしてシステム結合、システム適合性確認テスト、ソフトウェア導入及びソフトウェア受入れ支援がある。   In the present invention, the development process is divided into five processes of basic design, detailed design, program design / manufacturing, software test, and system test, and the correspondence with each SLCP activity is as shown in FIG. In other words, the basic design includes process start preparation, system requirement analysis, system method design, software requirement analysis, and software method design, and detailed design includes business detail design and software detail design. Program design / manufacturing is software code creation and test, software test is software combination and software compatibility check test, and system test includes system connection, system compatibility check test, software introduction and software acceptance support.

ここにおいて、システム開発作業の中で、実装工程(詳細設計〜ソフトウェアテスト)が全開発工数の60%以上を占めている。開発言語(コード自動生成などの中下流開発支援ツールを含む)の選定が実装工程の作業工数、費用に大きな影響を与えている。従って、システム開発の生産性を設定する際には、開発言語の生産性に留意する必要がある。開発言語別生産性値の例を図14に示すが、本例は1人月当り生産性の前提として、1人月を160時間とし、SLCP開発プロセスを作業範囲としている。なお、一部の工程しか発注しない場合、その割合を勘案して生産性を調整する必要がある。   Here, in the system development work, the mounting process (detailed design to software test) accounts for 60% or more of the total development man-hours. The selection of development languages (including middle and downstream development support tools such as automatic code generation) has a great impact on the work man-hours and costs of the mounting process. Therefore, it is necessary to pay attention to the productivity of the development language when setting the productivity of system development. FIG. 14 shows an example of productivity values by development language. In this example, assuming that the productivity per person-month is 160 hours per person-month, the SLCP development process is the work range. When only a part of the process is ordered, it is necessary to adjust the productivity in consideration of the ratio.

前述の開発言語別生産性値以外に、開発生産性に影響を与える要素は多い。例えば対象システムの固有属性(規模、システム構成など)、発注側の要求度合い(品質要求度合い、ドキュメント要求度合いなど)、受注側の業務遂行能力、成熟度(類似システム構築経験、開発者熟練度、プロジェクト管理成熟度など)、数十若しくは百以上の要素が挙げられる。本発明では見積り評価の精度を保ちながら、業務の簡便性、迅速性を失わないように各種コスト誘因の中から、システム開発工数に影響の大きい非機能要件(品質要件、技術要件)、並びに調達側(発注側)が特に重視すべく要素を中心に、コストドライバーを設定している。   There are many factors that affect development productivity in addition to the above-mentioned productivity values by language. For example, specific attributes of the target system (scale, system configuration, etc.), order-side requirements (quality requirements, document requirements, etc.), order-side business performance, maturity (similar system construction experience, developer skill, Project management maturity), and dozens or hundreds of elements. In the present invention, non-functional requirements (quality requirements, technical requirements) and procurement that greatly affect system development man-hours are selected from various cost incentives so as not to lose the convenience and speed of operations while maintaining the accuracy of estimation evaluation. The cost driver is set mainly on the elements that the side (ordering side) places particular emphasis on.

以下に、各システム特性が開発生産性に与える影響とその評価方法を示す。本発明では、下記5システムに係数を与えて評価を正確に行うようにしている。
(1)システム規模:大規模開発の場合、業務間の複雑度が増幅し、利害関係も増えるた
め、コミュニケーションオーバヘッドが発生しやすく、開発生産性が低下する。
(2)システム環境:プラットフォームが異なれば利用するOS、ミドルウェア、DBM
Sなども異なり、それに伴うシステム設計、構築の負荷が変化し、開発生産性も変
わる。
(3)処理負荷:データとプロセスの集中、分散によって、トランザクション制御、負荷
分散などシステム設計、構築の作業負荷が異なり、開発生産性が変動する。
(4)品質要求:社内のデータ確認と社外サービス課金と、品質への要求度合いが異なり
、それに伴い、システム設計観点、レビュー/テスト/品質評価への取込みによっ
て開発生産性が変動する。
(5)ドキュメント:大規模開発の場合、本稼動後の運用保守を重視する場合など、作成
するドキュメントのレベルや量が変わり、開発生産性に影響を与える。

上述のようなシステム特性に基づく生産性調整係数の例を図15に示す。システム規模係数は計測対象アプリケーションによって分類し、システム環境係数はシステムのプラットフォーム(システム環境構成)によって分類し、処理負荷係数はプロセスの形態(集中、分散)によって分類し、品質要求係数はシステムの品質要求度合い(レビュー、テスト、品質評価作業)によって分類し、ドキュメント係数は作成するドキュメントの種類、数量によって分類する。なお、係数の大小関係は、K11>K12>K13>K14>K15であり、K21>K22>K23>K24であり、K31>K32>K33であり、K41>K42>K43であり、K51>K52>K53である。
The impact of each system characteristic on development productivity and the evaluation method are shown below. In the present invention, a coefficient is given to the following five systems so that the evaluation is accurately performed.
(1) System scale: In the case of large-scale development, the complexity between operations increases and interests increase, so communication overhead tends to occur and development productivity decreases.
(2) System environment: OS, middleware, DBM to be used if the platform is different
S is also different, and the system design and construction load associated with it changes, and development productivity also changes.
(3) Processing load: Depending on the concentration and distribution of data and processes, the workload for system design and construction such as transaction control and load distribution differs, and development productivity varies.
(4) Quality requirements: In-house data confirmation and external service billing differ in the level of quality requirements, and accordingly, development productivity varies depending on the system design perspective and incorporation into review / test / quality evaluation.
(5) Documents: In the case of large-scale development, when importance is placed on operation and maintenance after production, the level and amount of documents to be created will change, affecting development productivity.

An example of the productivity adjustment coefficient based on the system characteristics as described above is shown in FIG. The system scale factor is classified according to the application to be measured, the system environment factor is classified according to the system platform (system environment configuration), the processing load factor is classified according to the process form (concentration, distribution), and the quality requirement factor is the system quality. The document coefficient is classified according to the type and quantity of documents to be created. The magnitude relationship of the coefficients is K11>K12>K13>K14> K15, K21>K22>K23> K24, K31>K32> K33, K41>K42> K43, and K51>K52>. K53.

開発プロセス全体を一まとめにして提供側に発注する場合、そのときの工程別発注率を100%とする。開発プロセスの一部を自製したり、1案件を複数段階に分割して発注したり、1案件を複数の提供者に分割して発注したりするケースが考えられる。このような場合、図16に示すような工程別発注率を参考にして、工程別発注率を設定する必要がある。また、開発プロセスの全ての作業を提供側に発注する場合(完全請負型)、そのときの作業分担率を100%とする。開発プロセスの一部作業を自製したり、1案件を複数の提供者に分割して発注したりするケースが考えられる。このような場合、双方の作業分担の度合い(原則は工数ペース)を勘案して、図17に示すような作業分担率を設定する必要がある。例えば、基本設計全作業を15人月と仮定し、そのうちの運用設計作業(1.5人月)を調達側が担当し、残りの13.5人月を提供側が担うとする。この場合、基本設計工程の提供側作業分担率を

13.5人月÷(1.5人月+13.5人月)×100%=90% …(8)

で、90%とする。ただし、下記のような元々発注側が担うべき役割は、ここでの作業分担率の対象としない。
1)仕様提示:要求事項のまとめ、提示など
2)調達管理:RFP作成、見積り評価、業者選定、契約の締結と管理、契約終了に伴
う事務処理など
3)検収作業:仕様、設計、実装結果のレビュー、承認、検証など

本発明では、改修案件の見積りを評価する場合、以下のようにしている。
1)改修率が100%を超えた場合は、改修率「100%」とする。
2)ソフトウェア改修個所とテスト範囲が大きく異なる場合があるため、改修率を開発
改修率とテスト改修率とに分ける。そして、開発改修率は基本設計からプログラミ
ング工程に適用し、テスト改修率はソフトウェアテスト工程(ソフトウェアテスト
改修率)とシステムテスト工程(システムテスト改修率)に適用する。

改修率の算出方法はステップ法を基本とし、下記(9)式で基本設計〜プログラミング工程に適用する。行数(ステップ数)はコメント行を含む物理ステップ数であり、母体(対象システム)行数のR1%は変更箇所とのインタフェースの考え方から計上する。また、改変行数は既存システムに対する「追加、変更、削除」の行数であり、外付け追加機能とは既存システムに手を入れることなく、別枠で追加する機能である。なお、定数R1%、R3%及びR4%は経験値であり、通常は6%を利用するが開発種類等によって変更することも構わない。また、改修前母体行数とは、改修対象システム(改修対象ソフトウェア)の既存行数を差し、既存システムの改変行数とは改修により改変が行われた行数を差し、改修後母体行数とは改修が行われた後の対象システム(対象ソフトウェア)の行数を差す。また、R2は改変行数にソフトウェア改修後の改変行数に対する確認作業で行われる確認倍率を示し、通常は改修前・改修後の確認を行うために2の値を適用する。

開発改修率={(改修前母体行数×R1%)+(既存システムの改変行数×R2)
+(外付け追加機能行数)}÷(改修後母体行数)
…(9)
なお、改修前母体行数×R1%を第一作業行数、既存システムの改変行数×R2を第二作業行数、第一作業行数、既存システムの改変行数及び外付け追加機能行数の和を開発作業行数と定義する。

また、ステップ方式で計測困難なケースの改修率算出方法は、下記(10)式に従う。(10)式において、DETはデータ項目種別(Data Element Type)を意味している。

開発改修率={(改修前母体DET数×R3%)+(追加・変更・削除DET数)}
÷(改修後母体DET数) …(10)

なお、改修前母体DET数×R3%を改修前作業DET数、追加・変更・削除DET数を改変DET数、改修前作業DET数と改変DET数の和を開発作業DET数と定義する。

更に、ソフトウェアテストとシステムテスト工程に適用するテスト工程での改修率の算出方法は、下記(11)式に拠る。この場合、新規開発時のテスト項目数実績データが記録されていない場合、ソフトウェアテストの基準項目数=FP値×R5件、システムテストの基準項目数=FP値×R6件の基準値を適用し、テスト改修率の提示がない場合、開発改修率と同等であるとみなす。なお、ソフトウェアテストの基準項目数及びシステムテストの基準項目数について、入力手段110から件数入力を受け付けるようにしても構わない。入力が行われない場合には、標準テスト項目件数テーブル記憶手段1034から読み出されて演算に利用される。

テスト改修率={(改修前母体・新規開発時のテスト項目数×R4%)+(改修時
のテスト項目数)}÷(改修後母体・新規開発時のテスト項目数)
…(11)

なお、改修前母体・新規開発時のテスト項目数×R4%を第一テスト作業行数、第一テスト作業行数と改修時のテスト項目数との和を全体テスト作業行数と定義する。
以下に代表的な「付帯作業」を例示する。
(1)運用テスト関連作業:運用テストとは、利用者が主体とする本稼働環境でのソフト
ウェア、システム、業務全体を確認するテストである。これに付随する環境構築、
利用者支援などの作業を付帯作業とする。
(2)移行関連作業:旧運用形態から新運用形態への切替えに伴う業務、システム、デー
タの移行作業が付帯作業とする。(ただし、移行用ツールの開発は標準開発作業の
範疇とし、FPで評価する方式を採用する。)
(3)運用関連作業:本稼働に向けての利用者教育訓練及び本稼働作業(運用監視、稼働
情報収集、改善、評価など)を付帯作業とする。
(4)開発支援作業:開発標準化(作業手順、テンプレート、基準)の策定と推進、品質
保証(契約、プロセス、要求事項、文書化の検証と妥当性確認)、リソース管理な
どを付帯作業とする。
(5)プロジェクト管理:進捗管理、問題管理、変更管理などを付帯作業とする。なお、
本発明では、付帯作業費の見積り評価はWBS精査方式で行う。

本発明ではソフトウェア開発技術者を図18に示すような4区分に分け、それぞれの役割と担当を決めている。即ち、開発技術者1は基本設計やシステムテストを主に担当し、システムの構成イメージ策定の中心的役割、システム開発計画の全体構想、プロジェクト体制の構築、後工程のプロジェクト管理指標決定等の役割を担っている。開発技術者2は基本設計、詳細設計、ソフトウェアテストやシステムテストを主に担当し、業務のモデル化、情報システム化の計画を策定したり、システムの機能設計及びシステムの具体化の中心的役割等を担っている。また、開発技術者3(設計)は詳細設計やソフトウェアテストを主に担当し、システムの基本設計を基にした詳細設計作成の中心的役割を担っており、開発技術者4(製造)はプログラム設計・製造を主に担当し、プログラミングの中心的役割、プログラムモジュールやプロセス毎のテストを担っている。
When placing an order for the entire development process together with the provider, the order rate for each process is 100%. There are cases where a part of the development process is manufactured in-house, one item is divided into a plurality of stages for ordering, or one item is divided into a plurality of providers for ordering. In such a case, it is necessary to set the order rate for each process with reference to the order rate for each process as shown in FIG. In addition, when all work of the development process is ordered from the provider side (complete contract type), the work sharing ratio at that time is set to 100%. There are cases in which part of the development process is self-made, or one item is divided into multiple providers and ordered. In such a case, it is necessary to set the work sharing rate as shown in FIG. 17 in consideration of the degree of work sharing between the two (in principle, the man-hour pace). For example, it is assumed that the total basic design work is 15 man-months, the operation design work (1.5 man-months) is handled by the procurement side, and the remaining 13.5 man-months are handled by the providing side. In this case, the work sharing ratio on the providing side of the basic design process

13.5 person months ÷ (1.5 person months + 13.5 person months) × 100% = 90%… (8)

And 90%. However, the roles that should be originally played by the ordering side, such as the following, are not subject to the work sharing rate here.
1) Specification presentation: summary of requirements, presentation, etc. 2) Procurement management: RFP creation, estimate evaluation, contractor selection, contract conclusion and management, paperwork upon contract termination, etc. 3) Inspection work: specification, design, implementation Review, approve, and verify results

In the present invention, when evaluating the estimate of a renovation item, the following is performed.
1) If the repair rate exceeds 100%, the repair rate shall be “100%”.
2) Since the software refurbishment location and test scope may differ greatly, the renovation rate is divided into the development renovation rate and the test refurbishment rate. The development improvement rate is applied from the basic design to the programming process, and the test improvement rate is applied to the software test process (software test improvement rate) and the system test process (system test improvement rate).

The method for calculating the repair rate is based on the step method, and is applied to the basic design to programming process by the following equation (9). The number of lines (number of steps) is the number of physical steps including comment lines, and R1% of the number of parent (target system) lines is counted from the viewpoint of the interface with the changed part. The number of modified lines is the number of lines “addition, change, deletion” with respect to the existing system, and the external addition function is a function that is added in a separate frame without changing the existing system. The constants R1%, R3%, and R4% are empirical values, and normally 6% is used, but it may be changed depending on the development type. In addition, the number of parent lines before renovation refers to the number of existing lines in the system to be refurbished (software to be refurbished), and the number of modified lines in the existing system refers to the number of lines that have been modified by renovation. Means the number of rows of the target system (target software) after the refurbishment. R2 indicates the number of lines to be modified, which is a confirmation magnification performed in the confirmation work for the number of modified lines after software modification. Normally, a value of 2 is applied to confirm before and after modification.

Development renovation rate = {(number of parent lines before renovation x R1%) + (number of remodeled lines in existing system x R2)
+ (Number of external additional function lines)} ÷ (number of parent lines after renovation)
... (9)
Note that the number of parent lines before refurbishment x R1% is the number of first work lines, the number of modified lines of the existing system x R2 is the number of second work lines, the number of first work lines, the number of modified lines of the existing system, and external additional function lines The sum of the numbers is defined as the number of development work lines.

In addition, the method for calculating the repair rate for cases where measurement is difficult by the step method follows the following equation (10). In equation (10), DET means a data element type.

Development renovation rate = {(number of parent DETs before renovation x R3%) + (number of DETs added / changed / deleted)}
÷ (number of parent DET after renovation) (10)

The number of base DETs before modification × R3% is defined as the number of work DETs before modification, the number of addition / change / deletion DETs is the number of modified DETs, and the sum of the number of work DETs before modification and the number of modified DETs is defined as the number of development work DETs.

Furthermore, the calculation method of the repair rate in the test process applied to the software test and the system test process is based on the following equation (11). In this case, if the actual data of the number of test items at the time of new development is not recorded, the standard value of the number of standard items of software test = FP value × R5 and the number of standard items of system test = FP value × R6 is applied. If no test renovation rate is presented, it is considered equivalent to the development renovation rate. Note that the number of items input from the input unit 110 may be received for the number of reference items for the software test and the number of reference items for the system test. When no input is made, the data is read from the standard test item number table storage means 1034 and used for calculation.

Test renovation rate = {(number of test items before renovation / number of test items at new development x R4%) + (at renovation)
Number of test items)} ÷ (number of test items at the time of repair and new development)
... (11)

Note that the number of test items before repair / new development × R4% is defined as the number of first test work lines, and the sum of the number of first test work lines and the number of test items at the time of repair is defined as the total number of test work lines.
The following is a typical “accompanying operation”.
(1) Operation test-related work: The operation test is a test that confirms the software, system, and business as a whole in a production environment that is mainly operated by the user. Environment construction accompanying this,
Work such as user support is ancillary work.
(2) Migration-related work: The work, system, and data migration work associated with switching from the old operation mode to the new operation mode is ancillary work. (However, development of transition tools is within the scope of standard development work, and a method of evaluation by FP is adopted.)
(3) Operations related to operations: User training and operations for actual operation and actual operations (operation monitoring, operation information collection, improvement, evaluation, etc.) are incidental operations.
(4) Development support work: Development standardization (work procedures, templates, standards) development and promotion, quality assurance (contracts, processes, requirements, documentation verification and validation), resource management, etc. To do.
(5) Project management: Progress management, problem management, change management, etc. are incidental work. In addition,
In the present invention, the estimated evaluation of incidental work costs is performed by the WBS scrutiny method.

In the present invention, software development engineers are divided into four categories as shown in FIG. 18, and their roles and responsibilities are determined. In other words, development engineer 1 is mainly responsible for basic design and system testing, and plays a central role in formulating the system configuration image, the overall concept of the system development plan, the construction of the project system, and the determination of project management indices in the subsequent processes. Is responsible. Development engineer 2 is mainly in charge of basic design, detailed design, software testing and system testing, and formulates business modeling and information system planning, and plays a central role in system functional design and system implementation. And so on. Development engineer 3 (design) is mainly responsible for detailed design and software testing, and plays a central role in creating detailed designs based on the basic design of the system. Development engineer 4 (manufacturing) is a program. Mainly responsible for design and manufacturing, and plays a central role in programming, testing for each program module and process.

図19は本発明の入力画面の一例を示し、図20は本発明の結果を示す表示画面の一例である。本発明においては新規案件、改修案件のいずれも評価できるようになっており、新規案件と改修案件の唯一の違いは、図20における項番4)の改修率にある。新規案件の場合は改修率が100%になり、改修案件の場合は改修率が100%未満となっている。   FIG. 19 shows an example of the input screen of the present invention, and FIG. 20 shows an example of the display screen showing the result of the present invention. In the present invention, both new projects and repair projects can be evaluated, and the only difference between the new project and the repair project is the repair rate of item number 4) in FIG. In the case of new projects, the repair rate is 100%, and in the case of repair projects, the repair rate is less than 100%.

図19の入力画面では、提供側から提示された見積りが高いか安いかを評価する業務を想定しているので、提供側見積り費用も入力すべき項目の1つとなっている。ウェブ画面をスクロールして入力作業を行う。「提供側見積り費用」の最後尾の「付帯作業工数」欄に付帯作業の数値を入力する。   In the input screen of FIG. 19, since it is assumed that the estimate presented from the provider side is high or low, the provider estimate cost is one of the items to be input. Scroll the web screen and perform input work. Enter the value of incidental work in the “Auxiliary work man-hours” column at the end of the “provider side estimated cost”.

本発明では、算出した機能規模(FP)と開発費を用いて図21のように見積りを評価する。即ち、規模が過大や過小の場合、その提供者が開発範囲を過不足に捉えていないか否か、FP明細を精査し、逆に費用が過大や過小の場合、その提供者が見積もった作業内容に過不足はないか否か、作業内容を精査する。図21では、C案件及びE案件が適性価格であることを示している。   In the present invention, the estimate is evaluated as shown in FIG. 21 using the calculated function scale (FP) and development cost. In other words, if the scale is too large or too small, the provider carefully examines the FP details to determine whether the scope of development is too large or insufficient, and conversely if the cost is too large or too small, the work estimated by the provider Examine the work contents to see if there are any excesses or deficiencies in the contents. FIG. 21 shows that the case C and the case E are appropriate prices.

図20の結果表示画面における「開発工数費用評価」欄は、ユーザ企業がFP法で算出した開発費用見積りと提供側から取得した開発費用見積りとを対比させ、提供側見積りが高過ぎないか又は安過ぎないかを判断するための情報が表示される。   The “development man-hour cost evaluation” column in the result display screen of FIG. 20 compares the development cost estimate calculated by the user company by the FP method with the development cost estimate obtained from the provider, and the provider estimate is not too high. Information for determining whether it is too cheap is displayed.

本発明はインターネットを利用したネットワークにおいても利用可能である。   The present invention can also be used in a network using the Internet.

本発明によれば、FPを基本にしてシステムの開発状況や環境を考慮した要素を条件として評価しているので、ソフトウェア開発工数費用の評価を客観的にかつ公正に行うことができ、そのためソフトウェア市場(入札や販売等)において見積の曖昧さを確実に排除することができ、ソフトウェア産業の活性化を図ることができる。   According to the present invention, since the evaluation is performed on the basis of the FP based on the conditions considering the development status and environment of the system, the software development man-hour cost can be evaluated objectively and fairly. It is possible to surely eliminate the ambiguity of estimates in the market (bidding, sales, etc.), and to activate the software industry.

FPの求め方を示す図である。It is a figure which shows how to obtain | require FP. FPと評価額との関係例を示す特性図である。It is a characteristic view which shows the example of a relationship between FP and evaluation amount. 本発明の原理を示す模式図である。It is a schematic diagram which shows the principle of this invention. 本発明の評価値算出装置を示すブロック構成図である。It is a block block diagram which shows the evaluation value calculation apparatus of this invention. 演算部の構成例を示すブロック図である。It is a block diagram which shows the structural example of a calculating part. 本発明の動作例を示すフローチャートである。It is a flowchart which shows the operation example of this invention. 本発明の他の動作例を示すフローチャートである。It is a flowchart which shows the other operation example of this invention. 本発明による新規開発及び改修案件の開発規模、工数、費用の算出方法を示す図である。It is a figure which shows the calculation method of the development scale, man-hour, and expense of the new development and renovation project by this invention. FP法の概略を示す図である。It is a figure which shows the outline of FP method. 開発規模算出のための入力情報と算出方法を示す図である。It is a figure which shows the input information and calculation method for development scale calculation. システム開発費用の構成を示す図である。It is a figure which shows the structure of system development expense. 開発プロセスの範囲を示す図である。It is a figure which shows the range of a development process. 工程区分とSLCPとの比較を示す図である。It is a figure which shows the comparison with a process division and SLCP. 開発言語別生産性値の一例を示す図である。It is a figure which shows an example of the productivity value according to development language. 開発生産性調整係数の例を示す図である。It is a figure which shows the example of a development productivity adjustment coefficient. 工程配分比率の例を示す図である。It is a figure which shows the example of a process distribution ratio. 作業分担比率の例を示す図である。It is a figure which shows the example of a work sharing ratio. ソフトウェア開発技術者の職種区分と役割を示す図である。It is a figure which shows the occupation classification and role of a software development engineer. 本発明の入力画面の一例を示す図である。It is a figure which shows an example of the input screen of this invention. 本発明の結果を示す表示画面の一例を示す図である。It is a figure which shows an example of the display screen which shows the result of this invention. FPを活用した参考価格の検証例を示す図である。It is a figure which shows the example of verification of the reference price using FP.

符号の説明Explanation of symbols

10 演算部(CPU)
102 ROM
103 RAM
110 入力手段
120 表示手段
121 印刷手段
1031 開発言語別生産性値テーブル記憶手段
1032 生産性調整係数テーブル記憶手段
1033 開発工程別標準配分率テーブル記憶手段
1034 標準テスト項目件数テーブル記憶手段
1035 システムエンジニア単価金額テーブル記憶手段
10 Calculation unit (CPU)
102 ROM
103 RAM
110 Input means 120 Display means 121 Printing means 1031 Development language-specific productivity value table storage means 1032 Productivity adjustment coefficient table storage means 1033 Standard distribution ratio table storage means 1034 by development process Standard test item number table storage means 1035 System engineer unit price Table storage means

Claims (11)

ソフトウェアの開発工数費用の見積りを行うためにコンピュータを、
前記ソフトウェアの機能規模(ファンクションポイント)をFP値として入力する手段、
一人月単位の開発可能規模を開発言語別生産性値として入力する手段、
前記開発言語別生産性値を調整する生産性調整係数を入力する手段、
基本設計、詳細設計、プログラム設計・製造、ソフトウェアテスト及びシステムテストの各工程における工程別発注率を入力する手段、
作業分担割合を作業分担率として入力する手段、
前記ソフトウェアの前記各工程に対する改修割合を開発改修率として入力する手段、
前記各工程における前記開発言語別生産性値、前記生産性調整係数、前記工程別発注率、前記作業分担率及び前記開発改修率をそれぞれ乗算して一人月当たりの生産性値を生産性係数として算出する手段、
前記各工程における前記FP値を前記生産性係数で除算して標準開発工数を算出する手段、
付帯作業工数を入力する手段、
システムエンジニア単価金額を入力する手段、
前記各工程における前記標準開発工数と前記付帯作業工数の和に前記システムエンジニア単価金額を乗算して開発費用を算出する手段、
として機能させることを特徴とするソフトウェア開発工数費用見積りプログラム。
Computer to estimate software development effort costs,
Means for inputting a function scale (function point) of the software as an FP value;
A means of inputting the development potential scale per month as a productivity value by development language,
Means for inputting a productivity adjustment coefficient for adjusting the productivity value for each development language;
Means to input order rate by process in each process of basic design, detailed design, program design / manufacturing, software test and system test,
Means for inputting the work share ratio as the work share ratio;
Means for inputting a repair ratio for each step of the software as a development repair ratio;
The productivity value per month as the productivity coefficient by multiplying the productivity value by development language, the productivity adjustment coefficient, the order rate by process, the work sharing ratio and the development / repair ratio in each process. Means for calculating,
Means for calculating a standard development man-hour by dividing the FP value in each step by the productivity coefficient;
Means to input incidental man-hours,
A means to enter the system engineer unit price,
Means for calculating the development cost by multiplying the sum of the standard development man-hours and the incidental work man-hours in the respective steps by the system engineer unit price amount;
Software development man-hour cost estimation program characterized by functioning as
ソフトウェアの開発工数費用の見積りを行うためにコンピュータを、
前記ソフトウェアの機能規模(ファンクションポイント)をFP値として入力する手段、
一人月単位の開発可能規模を開発言語別生産性値として入力する手段、
前記開発言語別生産性値を調整する生産性調整係数を入力する手段、
基本設計、詳細設計、プログラム設計・製造、ソフトウェアテスト及びシステムテストの各工程における工程別発注率を入力する手段、
作業分担割合を作業分担率として入力する手段、
前記基本設計、前記詳細設計及び前記プログラム設計・製造の各開発工程における前記ソフトウェアの開発改修割合を開発改修率として入力する手段、
前記ソフトウェアテスト及び前記システムテストの各テスト工程における前記ソフトウェアのテスト改修割合をテスト改修率として入力する手段、
前記各工程における前記開発言語別生産性値、前記生産性調整係数、前記工程別発注率、前記作業分担率及び前記開発改修率または前記テスト改修率をそれぞれ乗算して一人月当たりの生産性値を生産性係数として算出する手段、
前記各工程における前記FP値を前記生産性係数で除算して標準開発工数を算出する手段、
付帯作業工数を入力する手段、
システムエンジニア単価金額を入力する手段、
前記各工程における前記標準開発工数と前記付帯作業工数の和に前記システムエンジニア単価金額を乗算して開発費用を算出する手段、
として機能させることを特徴とするソフトウェア開発工数費用見積りプログラム。
Computer to estimate software development effort costs,
Means for inputting a function scale (function point) of the software as an FP value;
A means of inputting the development potential scale per month as a productivity value by development language,
Means for inputting a productivity adjustment coefficient for adjusting the productivity value for each development language;
Means to input order rate by process in each process of basic design, detailed design, program design / manufacturing, software test and system test,
Means for inputting the work share ratio as the work share ratio;
Means for inputting a development / repair rate of the software in each development process of the basic design, the detailed design and the program design / manufacturing as a development / repair rate;
Means for inputting a test repair ratio of the software in each test step of the software test and the system test as a test repair ratio;
Productivity value per month by multiplying the productivity value by development language, the productivity adjustment factor, the order rate by process, the work sharing rate and the development repair rate or the test repair rate in each process Means for calculating as a productivity factor,
Means for calculating a standard development man-hour by dividing the FP value in each step by the productivity coefficient;
Means to input incidental man-hours,
A means to enter the system engineer unit price,
Means for calculating the development cost by multiplying the sum of the standard development man-hours and the incidental work man-hours in the respective steps by the system engineer unit price amount;
Software development man-hour cost estimation program characterized by functioning as
入力される前記開発言語別生産性値について前記コンピュータを、
1または複数の利用する開発言語を入力する手段、
前記開発言語ごとに利用割合を入力する手段、
予め各開発言語ごとに一人月当たりの生産性値を記憶しておく開発言語別生産性値テーブル記憶手段、
前記開発言語別生産性値テーブルから入力された前記開発言語に対応する生産性値を読み出し、前記生産性値と前記生産性値に対応する前記利用割合とを乗算し、その総和を前記開発言語別生産性値として算出する手段、
として機能させる請求項1または2に記載のソフトウェア開発工数費用見積りプログラム。
The computer for the input productivity value for each development language,
Means for inputting one or more development languages to be used;
Means for inputting a utilization ratio for each development language;
Development value-specific productivity value table storage means for storing the productivity value per person for each development language in advance,
A productivity value corresponding to the development language input from the productivity value table for each development language is read out, the productivity value is multiplied by the utilization ratio corresponding to the productivity value, and the sum is calculated as the development language. Means for calculating as another productivity value,
The software development man-hour cost estimation program according to claim 1 or 2, which is functioned as
入力される前記生産性調整係数を算出するためにコンピュータを、
システム環境係数を入力するシステム手段、
システム規模係数を入力するシステム手段、
処理負荷係数を入力する手段、
品質要求係数を入力する手段、
ドキュメント係数を入力する手段、
予め前記システム環境係数、前記システム規模係数、前記処理負荷係数及び前記品質要求係数の各項目について係数値を記録しておく生産性調整テーブル記憶手段、
前記システム環境係数、前記システム規模係数、前記処理負荷係数及び前記品質要求係数のそれぞれ対応する各係数値を読み出して乗算し前記生産性調整係数を算出する手段、
として機能させるための請求項1乃至3のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
A computer for calculating the input productivity adjustment factor;
System means for inputting a system environment factor,
System means for inputting a system scale factor,
Means for inputting the processing load factor,
Means for entering the quality requirement factor,
A means of entering document coefficients,
Productivity adjustment table storage means for recording coefficient values in advance for each item of the system environment coefficient, the system scale coefficient, the processing load coefficient, and the quality requirement coefficient;
Means for calculating the productivity adjustment coefficient by reading and multiplying the corresponding coefficient values of the system environment coefficient, the system scale coefficient, the processing load coefficient, and the quality requirement coefficient;
The software development man-hour cost estimation program according to any one of claims 1 to 3 for functioning as a program.
入力される前記開発改修率についてコンピュータを、
前記ソフトウェアの既存行数を改修前母体行数として入力する手段、
前記ソフトウェアを利用した既存システムの改変行数を入力する手段、
前記既存システムとは別に追加される外付け追加機能行数を入力する手段、
前記改修前母体行数に前記ソフトウェアの改修後の前記改修前母体行数に対する確認作業で行われる作業割合をR1%として乗算し第一作業行数を算出する手段、
前記改変行数に前記ソフトウェア改修後の前記改変行数に対する確認作業で行われる確認倍率をR2として乗算し第二作業行数を算出する手段、
前記第一作業行数、前記第二作業行数及び前記外付け追加機能行数を加算して開発作業行数を算出する手段、
前記ソフトウェアの改修後の行数を改修後母体行数として入力する手段、
前記開発作業行数を前記改修後母体行数により除算し前記開発改修率を算出する手段、
として機能させる請求項1乃至4のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
About the development and renovation rate entered, the computer
Means for inputting the number of existing lines of the software as the number of parent lines before renovation;
Means for inputting the number of modified lines of an existing system using the software;
Means for inputting the number of external additional function lines added separately from the existing system;
Means for multiplying the number of parent lines before renovation by multiplying the work ratio performed in the confirmation work for the number of mother lines before refurbishment after renovation of the software as R1%,
Means for multiplying the number of modified lines by R2 as a confirmation magnification performed in the confirmation work on the number of modified lines after the software modification, and calculating a second number of working lines;
Means for calculating the development work line number by adding the first work line number, the second work line number, and the external additional function line number;
Means for inputting the number of lines after the modification of the software as the number of parent lines after the modification;
Means for dividing the number of development work lines by the number of parent lines after the repair to calculate the development repair rate;
The software development man-hour cost estimation program according to any one of claims 1 to 4, wherein
入力される前記開発改修率についてコンピュータを、
前記ソフトウェアのデータ項目種別数を改修前母体DET数として入力する手段、
前記改修前母体DET数に改修後の前記改修前母体DET数に対する確認作業で行われる作業割合をR3%として乗算し改修前作業DET数を算出する手段、
前記ソフトウェアに対して改変を行う改変データ項目種別数を改変DET数として入力する手段、
前記改修前作業DET数と前記改変DET数の和を開発作業DET数として算出する手段、
前記ソフトウェアの改修後のデータ項目種別数を改修後母体DET数として入力する手段、
前記開発作業DET数を前記改修後母体DET数で除算して前記開発改修率を算出する手段、
として機能させる請求項1乃至4のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
About the development and renovation rate entered, the computer
Means for inputting the number of data item types of the software as the number of parent DETs before renovation;
Means for multiplying the number of parent DETs before renovation by multiplying by R3% the work ratio performed in the confirmation work for the number of parent DETs before renovation after renovation,
Means for inputting the number of modified data item types for modifying the software as the number of modified DETs;
Means for calculating the sum of the number of pre-repair work DETs and the number of modified DETs as the number of development work DETs;
Means for inputting the number of data item types after modification of the software as the number of parent DETs after modification;
Means for dividing the development work DET number by the post-remodeling parent DET number to calculate the development / repair rate;
The software development man-hour cost estimation program according to any one of claims 1 to 4, wherein
入力される前記テスト改修率についてコンピュータを、
前記ソフトウェアの新規開発時のテスト項目数を改修前母体・新規開発時のテスト項目数として入力する手段、
前記改修前母体・新規開発時のテスト項目数に改修後の前記改修前母体・新規開発時のテスト項目数に対する確認作業で行われる作業割合をR4%として乗算し第一テスト作業行数として算出する手段、
改修時に行われるテスト項目数を入力する手段、
前記第一テスト作業行数と前記テスト項目数とを加算して全体テスト作業行数として算出する手段、
前記ソフトウェアが改修された後の新規開発時のテスト項目数を改修後母体・新規開発時のテスト項目数として入力する手段、
前記全体テスト作業行数を前記改修後母体・新規開発時のテスト項目数で除算して前記テスト改修率を算出する手段、
として機能させる請求項1乃至6のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
Computer for the test refurbishment rate entered,
Means for inputting the number of test items at the time of new development of the software as the number of test items at the time of new development and parent
The number of test items before the renovation and the number of test items at the time of new development is multiplied by the work ratio performed in the confirmation work for the number of test items before the renovation and the number of test items at the time of the new development as R4% to calculate the number of first test work Means to
A means to input the number of test items to be performed at the time of renovation,
Means for calculating the total number of test work lines by adding the number of first test work lines and the number of test items;
Means for inputting the number of test items at the time of new development after the software has been modified as the number of test items at the time of new development and parent body after the modification;
Means for calculating the test renovation rate by dividing the total number of test work lines by the number of test items at the time of the renewed base / new development;
The software development man-hour cost estimation program according to any one of claims 1 to 6, wherein
ソフトウェア開発工数費用の見積りを行うためにコンピュータを、
前記各工程における工程別発注率の総和を総発注率として算出する手段、
として機能させる請求項1乃至7のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
Computer to estimate software development effort costs,
Means for calculating the total order rate for each process as the total order rate,
The software development man-hour cost estimation program according to any one of claims 1 to 7, wherein
ソフトウェアの開発工数費用の見積りを行うためにコンピュータを、
前記各工程における開発費用の総和を総開発費用として算出する手段、
として機能させる請求項1乃至8のいずれかに記載のソフトウェア開発工数費用見積りプログラム。
Computer to estimate software development effort costs,
Means for calculating the total development cost in each step as a total development cost;
The software development man-hour cost estimation program according to any one of claims 1 to 8, wherein
ソフトウェア開発工数費用の見積りを行うためにコンピュータを、
前記各工程における前記ソフトウェアの改修を依頼した依頼業者から提供される業者提示価格を入力する手段、
前記各工程における前記業者提示価格の総和を総業者提示価格として算出する手段、
前記各工程おける前記業者提示価格を前記開発費用で除算して価格格差率を算出する手段、
前記総業者提示価格を前記総開発費用で除算して総価格格差率を算出する手段、
として機能させる請求項9に記載のソフトウェア開発工数費用見積りプログラム。
Computer to estimate software development effort costs,
Means for inputting a contractor-provided price provided by a requesting contractor who has requested the renovation of the software in each step;
Means for calculating the sum of the vendor-presented prices in each step as a total vendor-presented price;
Means for calculating a price disparity rate by dividing the supplier-provided price in each step by the development cost;
Means for calculating a total price disparity ratio by dividing the total contractor presented price by the total development cost;
The software development man-hour cost estimation program according to claim 9, which is made to function as:
請求項1乃至10のいずれかに記載のソフトウェア開発工数費用見積りプログラムを記憶したコンピュータ読み取り可能な記憶媒体。 A computer-readable storage medium storing the software development man-hour cost estimation program according to claim 1.
JP2004354147A 2004-03-02 2004-12-07 Evaluation device for software development manhour cost Pending JP2006085663A (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2004354147A JP2006085663A (en) 2004-03-02 2004-12-07 Evaluation device for software development manhour cost
KR1020050035151A KR20060047546A (en) 2004-04-27 2005-04-27 Evaluation apparatus for evaluating software development manpower/cost

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
JP2004057302 2004-03-02
JP2004130688 2004-04-27
JP2004239011 2004-08-19
JP2004354147A JP2006085663A (en) 2004-03-02 2004-12-07 Evaluation device for software development manhour cost

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2006157706A Division JP2006323851A (en) 2004-03-02 2006-06-06 Evaluation device of software development manhour cost

Publications (1)

Publication Number Publication Date
JP2006085663A true JP2006085663A (en) 2006-03-30

Family

ID=36164088

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2004354147A Pending JP2006085663A (en) 2004-03-02 2004-12-07 Evaluation device for software development manhour cost

Country Status (1)

Country Link
JP (1) JP2006085663A (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007323226A (en) * 2006-05-31 2007-12-13 Fujitsu Fip Corp Software development man-hour estimation device
WO2010061440A1 (en) * 2008-11-26 2010-06-03 株式会社ジャステック Software modification estimate method and software modification estimate system
JP2014174728A (en) * 2013-03-08 2014-09-22 Nec Solution Innovators Ltd Cost calculation device, cost calculation method, and program
CN113011629A (en) * 2021-01-22 2021-06-22 浙江工业大学 Software project budget estimation method based on development team role

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007323226A (en) * 2006-05-31 2007-12-13 Fujitsu Fip Corp Software development man-hour estimation device
WO2010061440A1 (en) * 2008-11-26 2010-06-03 株式会社ジャステック Software modification estimate method and software modification estimate system
CN102292706A (en) * 2008-11-26 2011-12-21 株式会社Jastec Software modification estimate method and software modification estimate system
US8595686B2 (en) 2008-11-26 2013-11-26 Jastec Co., Ltd. Software modification estimate method and software modification estimate system
JP5818439B2 (en) * 2008-11-26 2015-11-18 株式会社ジャステック Software modification estimation method and software modification estimation system
JP2014174728A (en) * 2013-03-08 2014-09-22 Nec Solution Innovators Ltd Cost calculation device, cost calculation method, and program
CN113011629A (en) * 2021-01-22 2021-06-22 浙江工业大学 Software project budget estimation method based on development team role

Similar Documents

Publication Publication Date Title
US11126427B2 (en) Computer-implemented methods and systems for measuring, estimating, and managing economic outcomes and technical debt in software systems and projects
Markus et al. If we build it, they will come: Designing information systems that people want to use
US20030070157A1 (en) Method and system for estimating software maintenance
Rad Project estimating and cost management
US20080201254A1 (en) Method and system for computer-implemented procurement from pre-qualified suppliers
US20180341896A1 (en) Enterprise Construction Project Management and Business Integration System
Ansari Dynamic simulation model for project change-management policies: Engineering project case
RU2733485C1 (en) System and method of processing data for integrated assessment of scientific and technological project maturity based on the use of a set of parameters
JP5614843B2 (en) Integrated software design and operation management system
Supriadi et al. Development of risk-based standardized WBS (Work Breakdown Structure) for cost estimation of apartment’s project
Rad et al. Metrics for project management: Formalized approaches
Jayeola et al. Implementing target costing in small and medium scale enterprises in Ogun industrial metropolis
Chen et al. Using the Six Sigma DMAIC method to improve procurement: a case study
JP2012098849A (en) Credibility evaluation method for construction progress level
AU2010202477A1 (en) Component based productivity measurement
US20230245027A1 (en) Model Management System
JP2006085663A (en) Evaluation device for software development manhour cost
Garcia et al. Integrating functional metrics, COCOMO II and earned value analysis for software projects using PMBoK
JP2006323851A (en) Evaluation device of software development manhour cost
KR20060047546A (en) Evaluation apparatus for evaluating software development manpower/cost
Seo et al. Calculating the cost impact in loss of productivity claims
JP2002279147A (en) In-house production determination support device, in- house determination support method, machine-readable recording medium with in-house production determination support program recorded thereon and in-house determination support program
JPH0876992A (en) Device and method for evaluation and management of quality of software
Roncero et al. TeqReq: a new family of test-related requirements attributes
Paramasivam et al. Identifying software development IOT effort in human and machine using global wavelet method

Legal Events

Date Code Title Description
A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20060411

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20060531

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20060607

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20060531

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20060804

A912 Re-examination (zenchi) completed and case transferred to appeal board

Free format text: JAPANESE INTERMEDIATE CODE: A912

Effective date: 20060908