Các phương pháp ước lượng công thực hiện phần mềm

Uớc lượng là công việc tính toán gần đúng một đại lượng nào đó dựa trên tập dữ liệu liên quan đến đại lượng đó. Tập dữ liệu này thường được thu thập trong điều kiện thiếu, nhiễu hoặc chỉ có giá trị gần đúng. Khi tập dữ liệu ở trong điều kiện hoàn hảo hay đầy đủ thông tin thì ước lượng trở thành tính toán chính xác.

pdf18 trang | Chia sẻ: vietpd | Lượt xem: 3542 | Lượt tải: 1download
Bạn đang xem nội dung tài liệu Các phương pháp ước lượng công thực hiện phần mềm, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
12 PHẦN 2: HIỆN TRẠNG Chương 2: Các phương pháp ước lượng công thực hiện phần mềm 2.1. Sơ lược về ước lượng công thực hiện phần mềm 2.1.1. Khái niệm ước lượng công thực hiện phần mềm Uớc lượng là công việc tính toán gần ñúng một ñại lượng nào ñó dựa trên tập dữ liệu liên quan ñến ñại lượng ñó. Tập dữ liệu này thường ñược thu thập trong ñiều kiện thiếu, nhiễu hoặc chỉ có giá trị gần ñúng. Khi tập dữ liệu ở trong ñiều kiện hoàn hảo hay ñầy ñủ thông tin thì ước lượng trở thành tính toán chính xác. Trong bất cứ ngành nghề sản xuất nào làm ra sản phẩm có ñộ phức tạp cao, việc ước lượng những yếu tố liên quan ñến sản phẩm trước khi ñưa vào sản xuất ñều cần thiết. Những yếu tố này cung cấp cho nhà sản xuất một cái nhìn trước về sản phẩm, từ ñó giúp cho việc hoạch ñịnh ngân sách, lên kế hoạch sản xuất, phân bổ nhân lực và giảm thiểu rủi ro. Trong ngành công nghiệp sản xuất phần mềm, yếu tố ước lượng ñược quan tâm nhiều nhất là chi phí phần mềm. Chi phí ở ñây bao gồm hai loại: - Chi phí sản xuất: chi phí gốc ñể phát triển dự án phần mềm, chi phí này ñược tính dựa trên công thực hiện dự án của ñội ngũ phát triển phần mềm. - Chi phí môi trường: những chi phí phát sinh xung quanh quá trình phát triển, bao gồm: chi phí tài nguyên, chi phí ñi lại, chi phí bảo trì, chi phí ngoại giao, … Chi phí môi trường có thể chiếm ñến hơn 2/3 chi phí phần mềm và phụ thuộc vào nhiều yếu tố như: giá cả, lạm phát, xu hướng thị trường, kỹ năng ñàm phán, … Những yếu tố này nằm ngoài lĩnh vực phần mềm và thường xuyên biến ñộng, làm 13 cho việc ước lượng trước chi phí môi trường là ñiều không khả thi. Trong khi ñó, chi phí sản xuất ñược tính toán dựa trên công thực hiện là ñại lượng hoàn toàn có thể ước lượng ñược với ñộ chính xác tương ñối cao. Biết trước công thực hiện sẽ giúp cho việc lập kế hoạch và phân bố nhân lực tham gia vào quá trình phát triển phần mềm ñược tốt hơn. Vì những lý do này, ước lượng công thực hiện phần mềm là một công việc quan trọng ñược thực hiện ở hầu hết các dự án phần mềm nghiêm túc. Việc ước lượng công ñược tiến hành xuyên suốt quá trình thực hiện dự án, trãi qua từng giai ñoạn của quy trình phần mềm. Ở giai ñoạn ñầu, dự án còn ở dạng sơ khai, những thông tin xung quanh dự án còn chưa rõ ràng, công thực hiện ước lượng ñược trong giai ñoạn này có ñộ chính xác không cao và thường ñược dùng làm cơ sở ñể báo giá, ñấu thầu dự án phần mềm. Càng về những giai ñoạn sau, các chi tiết của dự án ñã ñược làm rõ dần, ñộ chính xác của ước lượng càng tăng, công thực hiện ñược dùng ñể ñiều chỉnh ngân sách, chỉnh sửa kế hoạch cho phù hợp với những giai ñoạn tiếp theo. Hình 2.1. Sai số của ước lượng qua từng giai ñoạn của dự án phần mềm [16]. 14 2.1.2. Các thông số ước lượng ðầu vào của quá trình ước lượng công thực hiện dự án phần mềm là các thông số ước lượng (Cost Driver). Mỗi thông số là một yếu tố ảnh hưởng ñến công thực hiện của dự án. Những thông số này chia làm ba loại - Thông số về sản phẩm (Product Factors): những yếu tố của sản phẩm phần mềm ảnh hưởng ñến công thực hiện dự án, như: ñộ lớn, ñộ phức tạp, loại phần mềm, … - Thông số về môi trường phát triển (Environment Factors): những yếu tố của môi trường phát triển phần mềm ít nhiều làm thay ñổi công thực hiện, như: ngôn ngữ lập trình, quy trình phát triển, công nghệ triển khai, công cụ, tài nguyên hỗ trợ quá trình phát triển, … - Thông số về ñội ngũ phát triển (People Factors): những yếu tố của cá nhân tham gia vào quá trình phát triển dự án, như: trình ñộ kỹ thuật, kinh nghiệm, mức ñộ quen thuộc, năng suất làm việc, kỹ năng làm việc nhóm, … Trước khi thực hiện việc ước lượng, giá trị các thông số ước lượng của dự án phần mềm ñược tính bằng cách cho ñiểm dựa vào kinh nghiệm của người thực hiện công tác ước lượng. Công việc này mang tính chủ quan, phụ thuộc rất nhiều vào yếu tố con người. Hiện nay, có những nghiên cứu áp dụng logic mờ (Fuzzy Logic) ñể mờ hóa các giá trị ñiểm số nhằm giảm mức ñộ cảm tính trong việc cho ñiểm [8]. Hình 2.2. Biểu diễn giá trị các thông số ước lượng bằng logic mờ. Một thông số ước lượng rất ñược quan tâm là yếu tố về ñộ lớn của phần mềm. Yếu tố này ñược cho là ảnh hưởng rất lớn ñến công thực hiện phần mềm. Thông thường, 15 ñộ lớn phần mềm ñược ño bằng ñơn vị dòng-mã-nguồn (SLOC - Source Line Of Code). Nhưng trong phần lớn các giai ñoạn của quy trình phát triển, khi phần mềm chưa ñược hoàn thành, thông số ñộ lớn ño bằng ñơn vị dòng-mã-nguồn thường phải phỏng ñoán nên không tránh khỏi những sai sót. ðể khắc phục hạn chế này, ñơn vị ñiểm-chức-năng (FP - Function Point) thường ñược dùng thay thế [7]. ðơn vị này ñược tính toán dựa trên các yêu cầu chức năng và phi chức năng của dự án phần mềm nên mang tính thực tế hơn. Trong vài năm trở lại ñây, một ñơn vị khác cũng ñược sử dụng là ñiểm-ñối-tượng (OP – Object Point) [7]. ðây là ñơn vị ñược tính toán dựa trên các yêu cầu về màn hình và báo biểu của phần mềm. Nó thường ñược dùng ñể ño ñộ lớn phần mềm trong giai ñoạn sơ khởi của dự án, khi những yêu cầu chi tiết dùng ñể tính ñiểm-chức-năng chưa ñược làm rõ. 2.1.3. ðại lượng công thực hiện phần mềm Kết quả của quá trình ước lượng là công thực hiện dự án phần mềm. ðại lượng công thể hiện công sức cần thiết bỏ ra ñể ñội ngũ phát triển ñể hoàn thành dự án phần mềm. Hay nói cách khác, ñây là ñại lượng ñược dùng ñể ño khối lượng công việc cần thực hiện của dự án. ðại lượng công ñược tính bằng ñơn vị người-tháng (Person-Month) hoặc người-giờ (Person-Hour). Công thực hiện là tiền ñề ñể tính toán chi phí sản xuất phần mềm thông qua chi phí trung bình cho một ñơn vị công người-tháng. Một công ty phần mềm có thể dễ dàng tính toán ñược chi phí này thông qua phân tích thống kê số liệu trong quá khứ. Sau khi tính toán, chi phí sản xuất sẽ ñược dùng làm cơ sở ñể hoạch ñịnh ngân sách, báo giá sản phẩm cho khách hàng, ñấu thầu dự án, … Ngoài ra, công thực hiện cũng là tiền ñề ñể lên kế hoạch thời gian và nhân lực cho dự án. Một công thức kinh nghiệm thường ñược dùng ñể tối ưu hóa thời gian và nhân lực dựa vào công thực hiện. 16 ETP ≈≈ Công thức 2.1. Tính thời gian và nhân lực dự án từ ñại lượng công. Trong ñó: - E: công thực hiện dự án phần mềm ước lượng ñược, ñơn vị người-tháng. - P: nhân lực dự kiến thực hiện dự án, ñơn vị người. - T: thời gian dự kiến hoàn thành dự án, ñơn vị tháng. 2.2. Nhóm phương pháp ước lượng dựa vào chuyên gia Là một nhánh trong ngành khoa học về dự báo, ước lượng là một công việc phức tạp và ẩn chứa nhiều rủi ro. Ước lượng công thực hiện phần mềm ñặc biệt phức tạp vì phần mềm là một sản phẩm trí tuệ, khó có thể cân ño ñong ñếm ñước. Vì vậy, những phương pháp ñầu tiên ñược sử dụng ñể ước lượng công thực hiện phần mềm là dựa vào con người, những chuyên gia có nhiều kinh nghiệm và am hiểu về lĩnh vực của dự án phần mềm. Kết quả ước lượng ñược ñưa ra dựa trên cơ sở phân tích, ñánh giá, và nhận ñịnh từ các chuyên gia này. Và ñến nay, mặc dù ñã xuất hiện nhiều phương pháp khác thay thế, việc tham khảo ý kiến chuyên gia ñể ñưa ra kết quả ước lượng vẫn ñược dùng khá phổ biến. Nhận ñịnh của các chuyên gia vẫn luôn ñáng ñược quan tâm xem xét. ðiểm yếu của các phương pháp ước lượng dựa vào chuyên gia là kết quả ước lượng thường là chủ quan và cảm tính, không thể kiểm chứng khi dự án chưa hoàn thành. Ngoài ra, thời gian ra quyết ñịnh thường kéo dài và giá thành thuê chuyên gia tốn kém cũng là một hạn chế không nhỏ của nhóm phương pháp này. Hai trong số những phương pháp thường ñược các chuyên gia sử dụng ñể ước lượng công thực hiện phần mềm là: phương pháp tương ñồng và phương pháp Wide-band Delphi sẽ ñược trình bày ở ñây. 17 2.2.1. Phương pháp tương ñồng [6][7] ðây là phương pháp ước lượng ñơn giản, ñược thực hiện dựa trên nguyên tắt “những dự án phần mềm tương ñồng nhau thường có công thực hiện gần giống nhau”. Theo ñó, công thực hiện dự án phần mềm mới sẽ ñược ước lượng dựa trên những dự án phần mềm cũ tương ñồng ñã ñược thực hiện trước ñó. Quy trình ước lượng của phương pháp tương ñồng bao gồm ba bước: - Bước 1 (Analysis): phân tích, ñánh giá những thông số của dự án phần mềm mới. - Bước 2 (Comparing): so sánh dự án phần mềm mới với những dự án phần mềm trong tập dữ liệu lịch sử ñể tìm ra dự án tương ñồng. - Bước 3 (Scaling): xem xét các thông số giữa hai dự án, từ ñó co giãn công thực hiện của dự án cũ ñể tìm ra công thực hiện dự án mới. ðể tăng tính chính xác của ước lượng, phương pháp tương ñồng phải ñược thực hiện bởi chuyên gia có nhiều kinh nghiệm trong lĩnh vực của dự án phần mềm mới sắp ñược thực hiện. Chuyên gia này cũng cần phải am hiểu về ñội ngũ phát triển và tình hình hoạt ñộng hiện tại của công ty. Hạn chế của phương pháp tương ñồng ñó là việc tìm ra dự án cũ tương ñồng với dự án mới là một công việc không hề dễ dàng. ðiều này ñòi hỏi phải ñề ra ñược những tiêu chí ñánh giá và công thức ñể tính toán mức ñộ tương ñồng giữa hai dự án phần mềm, từ ñó mới có thể xác ñịnh ñược dự án cũ nào trong tập dữ liệu lịch sử là tương ñồng với dự án mới cần ước lượng. Hơn nữa, sau khi ñã tìm ra ñược dự án tương ñồng với dự án mới, việc so sánh các thông số giữa hai dự án, rồi sau ñó co giãn công dự án cũ sao cho hợp lý ñể ñưa ra kết quả cuối cùng là một công việc ñầy cảm tính và dễ gây tranh cãi. ðiều này phụ 18 thuộc rất nhiều vào kinh nghiệm và khả năng phán ñoán của chuyên gia thực hiện công việc ước lượng. 2.2.2. Phương pháp Wide-band Delphi [6][7][18] Dựa vào một cá nhân nào ñó ñể ñưa ra con số ước lượng là một quá trình ñầy cảm tính và rủi ro. Nhằm tăng tính khách quan và ñộ chính xác của kết quả ước lượng, quy trình Wide-band Delphi thường ñược áp dụng. Quy trình này do Barry Boehm và John Farquhar phát triển từ quy trình ra quyết ñịnh Delphi. Thay vì phụ thuộc vào một chuyên gia, kết quả ước lượng giờ ñây ñược ñưa ra dựa trên sự ñồng thuận của một nhóm các chuyên gia, và tuân theo một quy trình bài bản gồm năm bước: - Bước 1 (Preparation): trước hết, một nhóm chuyên gia ñược thành lập, ñiều phối viên có nhiệm vụ gởi ñến mỗi chuyên gia ñầy ñủ thông tin, dữ kiện của dự án phần mềm cần ước lượng. - Bước 2 (Meeting): ñiều phối viên tổ chức một cuộc họp, tại ñây các chuyên gia thảo luận với nhau về những vấn ñề liên quan ñến dự án phần mềm: những thông số dự án, môi trường phát triển, ñội ngũ phát triển, … - Bước 3 (Decision): mỗi chuyên gia ñược phát một phiếu ñể ghi nhận ñịnh và con số ước lượng của mình một cách ñộc lập. - Bước 4 (Summary): ñiều phối viên tổng hợp kết quả ước lượng thu ñược từ các chuyên gia. - Bước 5 (Loop): nếu kết quả ước lượng của các chuyên gia quá khác biệt, bước 2 ñược lặp lại cho ñến khi nào có ñược sự ñồng thuận. Phương pháp Wide-band Delphi tỏ ra khá hiệu quả trong việc ước lượng công thực hiện của những dự án phần mềm lớn, có nhiều ràng buộc phức tạp, và ñòi hỏi ñộ chính xác cao. Tuy nhiên, phương pháp này khá tốn kém và thường mất nhiều thời gian. Các chuyên gia không phải lúc nào cũng có tiếng nói chung. Và ñể tìm ñược 19 sự ñồng thuận giữa họ, quy trình trên có thể phải lặp lại rất nhiều lần. Hơn nữa, việc tập hợp ñược một nhóm các chuyên gia có kinh nghiệm là không dễ dàng chút nào. 2.3. Nhóm phương pháp ước lượng dựa vào công thức Nhóm phương pháp này xem việc ước lượng công thực hiện phần mềm là quá trình tìm kiếm mối liên hệ giữa ñại lượng công và các thông số của dự án phần mềm cần ước lượng. Các phương pháp ước lượng dựa vào công thức biểu diễn mối liên hệ này bằng một phương trình toán học. ða số những phương trình này ở dạng hàm nhiều biến, với một bên là các biến số ñại diện cho các thông số của dự án phần mềm, một bên là ñại lượng công thực hiện dự án. Những hàm nhiều biến này có thể phân làm hai dạng: tuyến tính và phi tuyến. - Tuyến tính: ∑+= ii xaaE 0 . - Phi tuyến: ∏×= i x iaaE 0 . Trong ñó: - E: công thực hiện dự án phần mềm. - xi: thông số thứ i của dự án. - ai: hệ số của từng thông số. Những công thức này ñược xây dựng dựa trên việc khảo sát một tập dữ liệu lịch sử bao gồm các dự án phần mềm ñã ñược thực hiện trước ñó. Phương pháp dùng ñể khảo sát thường là phương pháp phân tích hồi quy (regression analysis). Ưu ñiểm của ước lượng dựa vào công thức là tính khách quan của nó. Các công thức ñược xây dựng bằng phương pháp toán học chặt chẽ. Với cùng một bộ thông số ñầu vào như nhau, các công thức luôn cho ñầu ra kết quả như nhau. Kết quả này không phụ thuộc vào người thực hiện công việc ước lượng và có thể dễ dàng ñược kiểm chứng. 20 Một ưu ñiểm nữa của ước lượng dựa vào công thức là thời gian ñưa ra kết quả ước lượng nhanh chóng và ít tốn kém hơn hẳn so với việc thuê chuyên gia. Tuy nhiên, do ñược xây dựng trên một tập dữ liệu lịch sử cục bộ của một ñội ngũ phát triển nào ñó, các công thức ước lượng thường không phải lúc nào cũng chính xác khi áp dụng vào từng công ty với từng loại dự án cụ thể. Trong trường hợp ñó, các công thức cần phải ñược tinh chỉnh lại cho phù hợp. 2.3.1. Mô hình COCOMO [4][5][6] Mô hình ước lượng công thực hiện phần mềm COCOMO (COst COnstructive MOdel) do Barry Boehm ñề xuất vào ñầu thập niên 1980. Nó ñã nhanh chóng trở thành mô hình ước lượng ñược giới công nghiệp phần mềm sử dụng rộng rãi nhất thời bấy giờ [6]. Nhưng cùng với sự phát triển không ngừng của các quy trình công nghệ phát triển phần mềm, phiên bản ñầu tiên của mô hình là COCOMO 81 ñã dần bị lỗi thời, không còn chính xác khi áp dụng cho những dự án phát triển theo quy trình công nghệ mới. Vì vậy, từ năm 1994 cho ñến năm 2000, Boehm cùng các ñồng sự ở ñại học Nam California ñã tiếp tục nghiên cứu, phát triển và ñưa ra mô hình COCOMO II. Mô hình COCOMO II bao gồm 3 phiên bản (stage) áp dụng vào những thời ñiểm khác nhau trong quy trình phát triển phần mềm. Mỗi phiên bản ñược dùng với tính chất và mục ñích riêng. Ba phiên bản này gồm có: Application Composition, Early Design, và Post-Architecture. Phiên bản Application Composition ñược dùng ñể ước lượng công thực hiện phần mềm ở giai ñoạn khởi ñầu của dự án, khi phần mềm chỉ mới ở dạng prototype, chưa có gì rõ ràng. Kết quả ước lượng thường mang tính tham khảo, dùng trong thương lượng, ñàm phán hợp ñồng dự án. Công thực hiện ñược tính theo công thức 2.2. 21 PROD SIZE E = Công thức 2.2. Tính công thực hiện theo COCOMO 2000 Application Composition [5]. Trong ñó: - E: công thực hiện dự án phần mềm, ñơn vị người-tháng (person-month). - SIZE: kích thước phần mềm tính bằng ñơn vị ñiểm-ñối tượng (object point), ñược ño bằng cách cho ñiểm dựa trên ñộ phức tạp của từng màn hình, báo biểu trong phần mềm rồi cộng lại. - PROD: năng suất thực hiện một ñơn vị ñiểm-ñối tượng của ñội ngũ phát triển. Phiên bản Early Design ñược dùng ñể ước lượng công thực hiện phần mềm trong giai ñoạn ñầu của quá trình thiết kế dự án. Lúc này, các yêu cầu chức năng của dự án ñã rõ ràng nhưng các yếu tố về cài ñặt chưa ñược biết ñến. Kết quả ước lượng ñược dùng ñể ñiều chỉnh ngân sách, nhân lực và lên kế hoạch cài ñặt cho dự án. Công thực hiện ở phiên bản này ñược tính theo công thức 2.3. ∏××= i B EMSIZEAE Công thức 2.3. Tính công thực hiện theo COCOMO 2000 Early Design [5]. Trong ñó: - E: công thực hiện dự án phần mềm, ñơn vị người-tháng (person-month). - A, B: các hệ số ñiều chỉnh của công thức, phụ thuộc vào môi trường phát triển phần mềm ở mỗi công ty. Theo tính toán của Boehm, giá trị mặc ñịnh A = 2.94 và B dao ñộng từ 1.1 ñến 1.24. Tuy nhiên, ñể tăng ñộ chính xác, ông khuyến cáo người dùng công thức nên tinh chỉnh lại A, B theo tập dữ liệu lịch sử của riêng mình cho phù hợp. 22 - SIZE: kích thước phần mềm tính bằng ñơn vị ñiểm-chức năng (function point), ñược ño bằng cách cho ñiểm dựa trên ñộ phức tạp của từng chức năng trong phần mềm rồi cộng lại. - EMi: các hệ số của dự án, trong phiên bản Early Design, có 7 hệ số ñược sử dụng. Bảng 2.1. Các hệ số dự án dùng trong COCOMO 2000 Early Design [1]. STT Hệ số Ý nghĩa 1 RCPX Product Reliability and Complexity 2 RUSE Required Reuse 3 PDIF Platform Difficulty 4 PERS Personnel Capability 5 PREX Personnel Experience 6 FCIL Facilities 7 SCED Required Development Schedule Phiên bản Post-Architecture là sự mở rộng của phiên bản Early Design. Nó ñược sử dụng sau khi giai ñoạn thiết kế của dự án ñã hoàn tất. Lúc này, những thông tin chi tiết về việc cài ñặt dự án ñã ñược biết rõ ràng và cặn kẽ. Kết quả ước lượng của phiên bản này ñược dùng ñể tham khảo cho những ñiều chỉnh cuối cùng về ngân sách và nhân lực của dự án. Công thức của phiên bản Post-Architecture tương tự phiên bản Early Design. Tuy nhiên, có một vài ñiểm khác biệt ở công thức 2.4. ∏××= i B EMSIZEAE Công thức 2.4. Tính công thực hiện theo COCOMO 2000 Post Architecture [5]. 23 Trong ñó: - SIZE: kích thước phần mềm tính bằng ñơn vị dòng mã nguồn (KSLOC), thông thường ñể tính ñược số dòng mã nguồn, người ta dựa vào bản tra số dòng mã nguồn trung bình trên một ñiểm-chức năng. - EMi: trong giai ñoạn này, khi các thông tin về dự án ñã ñược biết ñầy ñủ, có tất cả 17 hệ số ñược sử dụng như mô tả ở bảng 2.2. Bảng 2.2. Các hệ số dự án dùng trong COCOMO 2000 Post Architecture [1]. STT Hệ số Ý nghĩa 1 RELY Required System Reliability 2 CPLX Complexity of System Modules 3 DOCU Extent of Documentation Required 4 DATA Size of Database Used 5 RUSE Required Percentage of Reusable Components 6 TIME Execution Time Constraint 7 PVOL Volatility of Development Platform 8 STOR Memory Constraints 9 ACAP Capability of Project Analysts 10 PCON Personnel Continuity 11 PCAP Programmer Capability 12 PEXP Programmer Experience in Project Domain 13 AEXP Analyst Experience in Project Domain 14 LTEX Language and Tool Experience 15 TOOL Use of Software Tool 16 SCED Development Schedule Compression 17 SITE Extent of Multisite Working and Quality of Intersite Communications 24 2.3.2. Mô hình SLIM [6] Mô hình SLIM ñược Putnam ñề xuất vào thập niên 1980, dựa trên những nghiên cứu của ông về ñường cong Norden/Rayleigh thể hiện sự phân bố nhân lực trong quá trình phát triển phần mềm. Putnam ñưa ra mô hình sau khi phân tích số liệu của rất nhiều dự án phần mềm ñã hoàn tất của Bộ Quốc phòng Mỹ. Công thức toán học chủ ñạo của mô hình SLIM ñược mô tả ở công thức 2.5. 3 4 3 1 tEPRODSIZE ××= Công thức 2.5. Công thức chủ ñạo của mô hình SLIM [6]. Trong ñó: - SIZE: kích thước phần mềm, tính bằng ñơn vị dòng mã nguồn (SLOC). - PROD: năng suất của ñội ngũ phát triển phần mềm. - E: công thực hiện dự án phần mềm, ñơn vị người-năm (person-year). - t: thời gian thực hiện dự án, ñơn vị năm. Ưu ñiểm của mô hình SLIM là có công thức ñơn giản và khả năng tinh chỉnh lại công thức theo tập dữ liệu lịch sử một cách dễ dàng. Những thông số dự án như kích thước (SIZE), công thực hiện (E) và thời gian hoàn thành (t) là những dữ liệu mà ña số các công ty ñều lưu lại sau mỗi dự án. Dựa trên những dữ liệu lịch sử này, tham số PROD có thể ñược tinh chỉnh một cách dễ dàng. Sau ñó, tham số này ñược áp dụng lại vào công thức của mô hình ñể ước lượng cho những dự án tương lai. Tuy nhiên, SLIM không phải là một mô hình ñầy ñủ và công khai. Tập dữ liệu ñược dùng ñể xây dựng nên mô hình này tới nay vẫn còn ñược dấu kín. Những thông tin chi tiết về mô hình cũng không ñược cung cấp miễn phí. Hiện tại mô hình này do công ty QSM (Quality System Management) nắm giữ. Khách hàng của QSM ña số là những công ty thuộc Bộ Quốc phòng Mỹ. 25 2.4. Nhóm phương pháp ước lượng bằng máy học Ước lượng công thực hiện dự án phần mềm là một vấn ñề không ñơn giản. Nó vẫn ñang thu hút rất nhiều nghiên cứu trên thế giới. Hiện nay, các nghiên cứu ñang hướng ñến việc áp dụng những mô hình tính toán mềm (Soft Computing) hay trí tuệ nhân tạo vào trong các mô