1. Trang chủ
  2. » Giáo Dục - Đào Tạo

Luận văn tốt nghiệp một giải pháp toán học cho việc phân phối tài nguyên trong độ tin cậy phần mềm

94 3 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 94
Dung lượng 0,93 MB

Nội dung

Đại Học Quốc Gia Thành Phố Hồ Chí Minh Trường Đại Học Bách Khoa PHAN THỊ NGỌC MAI MỘT GIẢI PHÁP TOÁN HỌC CHO VIỆC PHÂN PHỐI TÀI NGUYÊN TRONG ĐỘ TIN CẬY PHẦN MỀM Chuyên ngành: Khoa học Máy tính LUẬN VĂN THẠC SĨ TP HỒ CHÍ MINH, tháng 06 năm 2008 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com ĐẠI HỌC QUỐC GIA TP HCM CỘNG HOÀ Xà HỘI CHỦ NGHIà VIỆT NAM TRƯỜNG ĐẠI HỌC BÁCH KHOA Độc Lập - Tự Do - Hạnh Phúc oOo Tp HCM, ngày 30 tháng 06 năm 2008 NHIỆM VỤ LUẬN VĂN THẠC SĨ Họ tên học viên : Phan Thị Ngọc Mai Giới tính : Nam… / Nữ ; Ngày, tháng, năm sinh : 1978 Nơi sinh : Bến Tre Chuyên ngành : Khoa học Máy tính Khoá : 15 1- TÊN ĐỀ TÀI : MỘT GIẢI PHÁP TOÁN HỌC CHO VIỆC PHÂN PHỐI TÀI NGUYÊN TRONG ĐỘ TIN CẬY PHẦN MỀM 2- NHIỆM VỤ LUẬN VĂN : 3- NGÀY GIAO NHIỆM VỤ : 4- NGÀY HOÀN THÀNH NHIỆM VỤ : 5- HỌ VÀ TÊN CÁN BỘ HƯỚNG DẪN : TS Nguyễn Văn Minh Mẫn Nội dung đề cương Luận văn thạc sĩ Hội Đồng Chuyên Ngành thông qua CÁN BỘ HƯỚNG DẪN CHỦ NHIỆM BỘ MÔN (Họ tên chữ ký) QUẢN LÝ CHUYÊN NGÀNH (Họ tên chữ ký) TS Nguyễn Văn Minh Mẫn TS Đinh Đức Anh Vũ LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com CƠNG TRÌNH ĐƯỢC HỒN THÀNH TẠI TRƯỜNG ĐẠI HỌC BÁCH KHOA ĐẠI HỌC QUỐC GIA TP HỒ CHÍ MINH Cán hướng dẫn khoa học : TS Nguyễn Văn Minh Mẫn Cán chấm nhận xét : Cán chấm nhận xét : Luận văn thạc sĩ bảo vệ HỘI ĐỒNG CHẤM BẢO VỆ LUẬN VĂN THẠC SĨ TRƯỜNG ĐẠI HỌC BÁCH KHOA, ngày tháng năm 2008 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp tốn học cho việc phân phối chi phí độ tin cậy phần mềm LỜI CAM ĐOAN Tôi cam đoan rằng, ngoại trừ kết tham khảo từ cơng trình khác ghi rõ luận văn, cơng việc trình bày luận văn tơi thực chưa có phần nội dung luận văn nộp để lấy cấp trường trường khác Ngày 30 tháng 06 năm 2008 Phan Thị Ngọc Mai Phan Thị Ngọc Mai Trang i LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối chi phí độ tin cậy phần mềm LỜI CẢM ƠN Tôi xin gởi lời cảm ơn chân thành đến TS Nguyễn Văn Minh Mẫn, người tận tình hướng dẫn, giúp đỡ tơi suốt q trình thực luận văn tạo điều kiện để tơi hồn thành luận văn Xin gởi lời cảm ơn đến Thầy Cô dạy thời gian qua Tôi xin cảm ơn bạn đồng môn đồng nghiệp quan tâm, chia suốt trình học làm luận văn Xin cảm ơn gia đình dành cho tơi tình thương yêu hỗ trợ tốt Phan Thị Ngọc Mai Trang ii LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối chi phí độ tin cậy phần mềm TĨM TẮT LUẬN VĂN Đánh giá độ tin cậy phần mềm vấn đề quan trọng việc đánh giá chất lượng phần mềm Quá trình thường thực giai đoạn thiết kế phần mềm, kiểm tra lỗi phần mềm Công việc kiểm tra lỗi phần mềm triển khai xuyên suốt giai đoạn phát triển phần mềm, công việc giúp giảm chi phí nâng cao chất lượng phần mềm triển khai cho khách hàng Trong thời gian hệ thống kiểm tra, việc đo lường độ tin cậy phần mềm tiêu chuẩn quan trọng có tác dụng định có nên cơng bố phần mềm phần hay khơng Ngồi ra, vấn đề quan trọng định thành bại phần mềm làm đau đầu nhà quản lý dự án Đó làm để phân phối chi phí cách hiệu nhằm tạo phần mềm có tính tin cậy cao Đã có số phương pháp giải tốn thực theo số mơ hình tốn học Phương pháp kết hợp quy hoạch nguyên quy hoạch phi tuyến giải pháp hữu hiệu để giải vấn đề Đề tài trình bày giải pháp toán học đa bước để phân phối tài nguyên cho độ tin cậy phần mềm Sử dụng quy hoạch nguyên nhị phân để thực việc phân phối chi phí cho module mua Sử dụng quy hoạch phi tuyến để thực hiệc việc phân phối chi phí cho module phát triển cơng ty Thơng qua việc kết hợp này, luận văn xây dựng giải pháp cho phép giải toán theo hai hướng: tìm độ tin cậy lớn có phần mềm mà khơng vượt q giới hạn chi phí cho ngược lại tìm chi phí nhỏ để phần mềm có độ tin cậy giá trị xác định trước Chương trình thực cung cấp lời giải với độ xác tương đối cho số minh họa cụ thể Từ khoá: Algorithm, Binary Integer Programming, Branch and Bound, Developed module, In-house Integration module, Nonlinear programming, Resource allocation, Programming modules, Purchased module, Software reliability Phan Thị Ngọc Mai Trang iii LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp tốn học cho việc phân phối chi phí độ tin cậy phần mềm MỤC LỤC LỜI CAM ĐOAN i LỜI CẢM ƠN ii TÓM TẮT LUẬN VĂN iii DANH MỤC HÌNH vi DANH MỤC BẢNG vii Chương GIỚI THIỆU .1 1.1 1.2 1.3 Giới thiệu Sơ lược việc phân phối độ tin cậy phần mềm Kết cấu luận văn Chương Các Mơ Hình Phân Phối Chi Phí Cho Độ Tin Cậy Phần Mềm .6 2.1 2.2 2.3 2.3.1 2.3.2 2.3.3 2.4 Giới thiệu Phân loại module phần mềm Mơ hình định trước Độ tin cậy module đơn phát triển công ty Độ tin cậy module mua Độ tin cậy module tích hợp Mơ hình tổng qt .14 Chương Phương Pháp Giải Bài Toán Quy Hoạch Nguyên .15 3.1 3.2 3.3 3.4 Giới thiệu 15 Sự cần thiết toán quy hoạch nguyên 15 Phương pháp giải toán quy hoạch nguyên .16 Phương pháp giải toán quy hoạch nguyên nhị phân 19 Chương Phương Pháp Giải Bài Toán Quy Hoạch Phi Tuyến 23 4.1 4.2 4.3 4.3.1 4.3.2 4.3.3 4.4 4.4.1 4.4.2 4.4.3 4.4.4 Giới thiệu 23 Những điều kiện tối ưu 25 Tính lồi hàm nhiều biến 26 Tập lồi .26 Định nghĩa hàm lồi 26 Đặc trưng hàm lồi .26 Các phương pháp giải toán quy hoạch phi tuyến 27 Giải tốn tối ưu khơng có điều kiện ràng buộc 27 Giải toán tối ưu với điều kiện ràng buộc biến lớn 28 Giải toán tối ưu với điều kiện ràng buộc phương trình tuyến tính 30 Giải tốn tối ưu với điều kiện ràng buộc phương trình phi tuyến 34 Chương Giải Quyết Bài Toán 36 5.1 5.2 5.3 Phân hoạch toán 36 Bài toán tối ưu hóa module mua 37 Bài tốn tối ưu hóa module phát triển công ty .39 Phan Thị Ngọc Mai Trang iv LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối chi phí độ tin cậy phần mềm 5.4 5.4.1 5.4.2 Sự kết hợp module mua module phát triển công ty 40 Bài toán A 41 Bài toán B 46 Chương Một số kết quả, kết luận 51 6.1 6.2 6.2.1 6.2.2 6.2.3 6.2.4 6.2.5 6.2.6 6.2.7 6.2.8 6.3 Sơ lược chương trình 51 Một số kết chạy chương trình 51 Bài tốn ví dụ 3.4 51 Bài toán ví dụ 4.1.1 51 Bài tốn ví dụ 4.3.1 52 Bài tốn ví dụ 4.3.4 52 Bài tốn cho phần mềm gồm có module .54 Bài toán cho phần mềm gồm có 11 module .56 Bài toán cho phần mềm gồm có 22 module .61 Bài tốn cho phần mềm gồm có 37 module .67 Kết luận 74 Tài Liệu Tham Khảo 76 Phụ lục Bảng đối chiếu Thuật ngữ Anh - Việt 77 Phụ lục Bảng tóm tắt mơ hình đánh giá độ tin cậy phần mềm 78 Phụ lục Sơ lược MATLAB .80 Tham khảo Chỉ Mục 84 Phan Thị Ngọc Mai Trang v LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp tốn học cho việc phân phối chi phí độ tin cậy phần mềm DANH MỤC HÌNH Hình 2.1: Độ tin cậy module phần mềm .8 Hình 2.2: Một hệ thống databate-indexing .11 Hình 3.1: Giá trị tối ưu LP làm tròn xa với giá trị tối ưu IP problem 16 Hình 3.2: Một liệt kê đầy đủ 17 Hình 3.3 : Cây tìm kiếm cho ví dụ 3.2 .22 Hình 4.1: Một giải pháp hình học cho ví dụ 4.1.1 24 Hình 4.2: Một giải pháp hình học cho ví dụ 4.1.2 25 Hình 5.1: Sự phân hoạch tốn 36 Hình 6.1: Mơ hình phần mềm có 11 module .56 Hình 6.2: Mơ hình phần mềm có 22 module .61 Hình 6.3: Mơ hình phần mềm có 37 module .67 Phan Thị Ngọc Mai Trang vi LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối chi phí độ tin cậy phần mềm DANH MỤC BẢNG Bảng 2.1: Giải pháp cho nguồn ngân sách khác 13 Bảng 6.1: Kết chạy phần mềm có module cho toán A 54 Bảng 6.2: Kết chạy phần mềm có module cho toán B .55 Bảng 6.3: Kết chạy phần mềm có 11 module cho tốn A 59 Bảng 6.4: Kết chạy phần mềm có 11 module cho tốn B 60 Bảng 6.5: Kết chạy phần mềm có 22 module cho tốn A 65 Bảng 6.6: Kết chạy phần mềm có 22 module cho toán B 66 Bảng 6.7: Kết chạy phần mềm có 37 module cho toán A 72 Bảng 6.8: Kết chạy phần mềm có 37 module cho tốn B 73 Phan Thị Ngọc Mai Trang vii LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm (0) ( ) r27 = ( r27(max) − r27( 0) )e −α 27 x 27 − x 27 ; r27(max) = r10 r24 , r27( 0) = q27 r27(max) (0) −α − r26 = ( r26(max) − r26( 0) )e 26 ( x 26 x 26 ) ; r26(max) = r1r9 r23 , r26( ) = q26 r26(max) (0) −α ( − ) r25 = ( r25(max) − r25( ) )e 25 x 25 x 25 ; r25(max) = r5r8 , r25( 0) = q25r25(max) (0) r24 = (r24(max) − r24( 0) )e −α 24 ( x 24 − x 24 ) ; r24(max) = r3r7 , r24( 0) = q24r24(max) r23 = (r23(max) − r23( ) )e −α 23 (0) ( x 23 − x 23 ) ; r23(max) = r2 r6 , r23( ) = q23r23(max) (0) (0) ) (0) (0) ) r5 = (r5(max) − r5( ) )e −α ( x5 − x5 ) , r6 = (r6(max) − r6( ) )e −α ( x − x r7 = (r7(max) − r7( ) )e −α ( x7 − x ) , r8 = (r8(max) − r8( 0) )e −α ( x8 − x8 (0) (0) r9 = (r9(max) − r9( 0) )e −α ( x9 − x9 ) , r10 = (r10(max) − r10( ) )e −α10 ( x10 − x10 ) (0) (0) ) (0) (0) ) (0) (0) ) (0) (0) ) r11 = (r11(max) − r11( 0) )e −α11 ( x11 − x11 ) , r12 = (r12(max) − r12( 0) )e −α12 ( x12 − x12 r13 = (r13(max) − r13( ) )e −α13 ( x13 − x13 ) , r14 = (r14(max) − r14( ) )e −α14 ( x14 − x14 r15 = (r15(max) − r15( ) )e −α15 ( x15 − x15 ) , r16 = (r16(max) − r16( ) )e −α16 ( x16 − x16 r17 = (r17(max) − r17( 0) )e −α17 ( x17 − x17 ) , r18 = (r18(max) − r18( 0) )e −α18 ( x18 − x18 (0) (0) ) (0) (0) ) r19 = (r19(max) − r19( 0) )e −α 19 ( x19 − x19 ) , r20 = (r20(max) − r20( ) )e −α 20 ( x 20 − x 20 r21 = (r21(max) − r21( 0) )e −α 21 ( x 21 − x 21 ) , r23 = (r23(max) − r23( 0) )e −α 23 ( x 23 − x 23 xi ≥ xi( ) , i = 6,…,37 Trong module 37 module gốc, độ tin cậy module độ tin cậy phần mềm a) Đối với toán B Đối với module mua tương tự toán A: Hàm mục tiêu: Maximizer11 y11 + r12 y12 + r13 y13 + r21 y21 + r22 y22 + r23 y23 + r31 y31 + r32 y32 + r33 y33 + r34 y34 + r41 y41 + r42 y42 + r43 y43 + r52 y52 + r52 y52 Các điều kiện ràng buộc: c11 y11 + c12 y12 + c13 y13 + c21 y21 + c22 y22 + c23 y23 + c31 y31 + c32 y32 + c33 y33c34 y34 + c41 y41 + c42 y42 + c43 y43 + c52 y52 + c52 y52 ≤ B' y11 + y12 + y13 = y21 + y22 + y23 = y31 + y32 + y33 + y34 = y41 + y42 + y43 = y51 + y52 = yij = or Đối với module phát triển công ty: Phan Thị Ngọc Mai Trang 70 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Hàm mục tiêu: 37 Min∑ xi i =6 Các điều kiện ràng buộc: (r37(max) − r37(min) )e (max) 37 r = r35 r36 , r (0) ) −α 11 ( x37 − x 37 (0) 37 =R =q r (max) 37 37 r36 = (r36(max) − r36( 0) )e (0) ) −α 36 ( x36 − x36 ; r36(max) = r21r22 r34 , r36( ) = q36 r36(max) r35 = (r35(max) − r35( ) )e (0) ) −α 35 ( x 35 − x 35 ; r35(max) = r19 r20 r32 r33 , r35( 0) = q35 r35(max) (0) −α − r34 = ( r34(max) − r34( ) )e 34 ( x34 x34 ) ; r34(max) = r18r31, r34( 0) = q34 r34(max) r33 = ( r33(max) − r33( 0) )e (0) −α 33 ( x 33 − x 33 ) ; r33(max) = r17 r30 , r33( 0) = q33r33(max) (0) −α x − x r32 = ( r32(max) − r32( ) )e 32 ( 32 32 ) ; r32(max) = r15r16 r29 , r32( 0) = q32 r32(max) r31 = ( r31(max) − r31( 0) )e (0) −α 31 ( x 31 − x 31 ) ; r31(max) = r14 r28 , r31( 0) = q31r31(max) (0) −α x − x r30 = ( r30(max) − r30( ) )e 30 ( 30 30 ) ; r30(max) = r12 r13r27 , r30( ) = q30 r30(max) (0) −α ( x − x ) r29 = ( r29(max) − r29( ) )e 29 29 29 ; r29(max) = r11r26 , r29( 0) = q29 r29(max) (0) −α ( x − x ) r28 = ( r28(max) − r28( 0) )e 28 28 28 ; r28(max) = r4 r25 , r28( ) = q28 r28(max) (0) −α ( x − x ) r27 = ( r27(max) − r27( 0) )e 27 27 27 ; r27(max) = r10 r24 , r27( ) = q27 r27(max) (0) −α ( x − x ) r26 = ( r26(max) − r26( ) )e 26 26 26 ; r26(max) = r1r9 r23 , r26( ) = q26 r26(max) (0) −α ( x − x ) r25 = ( r25(max) − r25( 0) )e 25 25 25 ; r25(max) = r5r8 , r25( 0) = q25r25(max) (0) r24 = (r24(max) − r24( ) )e −α 24 ( x 24 − x 24 ) ; r24(max) = r3r7 , r24( ) = q24 r24(max) (0) r23 = (r23(max) − r23( ) )e −α 23 ( x 23 − x 23 ) ; r23(max) = r2r6 , r23( ) = q23r23(max) (0) (0) ) (0) (0) ) r5 = (r5(max) − r5( 0) )e −α ( x5 − x5 ) , r6 = (r6(max) − r6( 0) )e −α ( x6 − x6 r7 = (r7(max) − r7( ) )e −α ( x7 − x7 ) , r8 = (r8(max) − r8( ) )e −α ( x8 − x8 (0) (0) r9 = (r9(max) − r9( ) )e −α ( x9 − x9 ) , r10 = (r10(max) − r10( 0) )e −α10 ( x10 − x10 (0) ) (0) ) (0) ) (0) (0) ) (0) (0) ) r11 = (r11(max) − r11( ) )e −α11 ( x11 − x11 ) , r12 = (r12(max) − r12( ) )e −α 12 ( x12 − x12 r13 = (r13(max) − r13( ) )e (0) −α 13 ( x13 − x13 ) , r14 = (r14(max) − r14( 0) )e −α14 ( x14 − x14 r15 = (r15(max) − r15( 0) )e −α15 ( x15 − x15 ) , r16 = (r16(max) − r16( 0) )e −α16 ( x16 − x16 r17 = (r17(max) − r17( 0) )e −α17 ( x17 − x17 ) , r18 = (r18(max) − r18( 0) )e −α18 ( x18 − x18 (0) (0) ) (0) (0) ) r19 = (r19(max) − r19( ) )e −α 19 ( x19 − x19 ) , r20 = (r20(max) − r20( 0) )e −α 20 ( x 20 − x 20 r21 = (r21(max) − r21( ) )e −α 21 ( x 21 − x 21 ) , r23 = (r23(max) − r23( ) )e −α 23 ( x 23 − x 23 xi ≥ xi( ) , i = 6,…,37 Phan Thị Ngọc Mai Trang 71 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Đối với toán A: B B’ yij 288 100 1000 33 100 100 10 299 001 0001 44 001 001 01 500 001 0001 44 001 001 01 600 001 0001 44 001 001 01 001 0001 1000 44 001 001 01 [ x6 ,…, x37 ] [9.00, 5.00, 7.00, 6.00, 8.00, 6.00, 9.00, 7.00, 8.00, 6.00, 9.00, 5.00, 8.00, 7.50, 8.50, 9.00, 10.00, 10.00, 9.00, 8.00, 5.00, 7.00, 6.00, 9.00, 7.50, 6.50, 8.00, 9.00, 11.00, 7.00, 9.00, 15.00] [9.00, 5.00, 7.00, 6.00, 8.00, 6.00, 9.00, 7.00, 8.00, 6.00, 9.00, 5.00, 8.00, 7.50, 8.50, 9.00, 10.00, 10.00, 9.00, 8.00, 5.00, 7.00, 6.00, 9.00, 7.50, 6.50, 8.00, 9.00, 11.00, 7.00, 9.00, 15.00] [9.00, 5.00, 45.76, 6.00, 8.00, 6.00, 9.00, 7.00, 24.55, 6.00, 9.00, 5.00, 24.64,7.50, 8.50, 31.15, 28.09, 10.00, 9.00, 25.14, 5.00, 7.00, 17.78, 9.00, 7.50, 38.53, 8.00, 9.00, 31.37, 7.00, 13.70, 17.79] [9.00, 5.00, 56.17, 6.00, 8.00, 6.00, 9.00, 7.00, 28.18, 6.00, 9.00, 5.00, 28.74, 7.50, 8.50, 34.89, 31.53, 10.00, 9.00, 37.78, 5.00, 7.00, 26.99, 9.00, 7.50, 66.35, 8.00, 9.00, 49.74, 7.00, 17.88, 20.24] [9.00, 5.00, 90.95, 6.00, 8.00, 6.00, 9.00, 7.00, 40.04, 6.00, 9.00, 5.00, 42.30,7.50, 8.50, 46.64, 42.57, 10.00, 9.00, 83.81, 5.00, 7.00, 62.63, 9.00, 7.50, 158.31, 8.00, 9.00, 115.17, 7.00, 35.90, 30.82] Độ tin cậy tối ưu ( r37 ) [r6 ,…, r36 ] [0.30, 0.50, 0.40, 0.30, 0.64, 0.40, 0.50, 0.40, 0.45, 0.40, 0.35, 0.40, 0.45, 0.50, 0.55, 0.30, 0.40, 0.22, 0.0014 0.38, 0.30, 0.05, 0.19, 0.23, 0.02, 0.04, 0.09, 0.003, 0.01, 0.04, 0.32] [0.30 0.50, 0.40, 0.30, 0.64, 0.40, 0.50, 0.40, 0.45, 0.40, 0.35, 0.40, 0.45, 0.50, 0.55, 0.30, 0.40, 0.28, 0.45, 0.35, 0.07, 0.19, 0.28, 0.03, 0.04, 0.11, 0.004, 0.01, 0.05, 0.37] 0.0054 [0.30, 0.50, 0.93, 0.30, 0.64, 0.40, 0.50, 0.40, 0.96, 0.40, 0.35, 0.40, 0.95, 0.50, 0.55, 0.96, 0.97, 0.28, 0.45, 0.89, 0.07, 0.60, 0.77, 0.03, 0.11, 0.74, 0.004, 0.04, 0.70, 0.87] 0.5574 [0.30, 0.50, 0.93, 0.30, 0.64, 0.40, 0.50, 0.40, 0.96, 0.40, 0.35, 0.40, 0.95, 0.50, 0.55, 0.96, 0.97, 0.28, 0.45, 0.89, 0.07, 0.60, 0.77, 0.03, 0.11, 0.74, 0.004, 0.04, 0.70, 0.87] 0.5625 [0.30, 0.50, 0.93, 0.30, 0.64, 0.40, 0.50, 0.40, 0.96, 0.40, 0.35, 0.40, 0.95, 0.50, 0.55, 0.96, 0.97, 0.28, 0.45, 0.89, 0.07, 0.60, 0.77, 0.03, 0.11, 0.74, 0.004, 0.04, 0.70, 0.87] 0.5647 Bảng 6.7: Kết chạy phần mềm có 37 module cho tốn A Phan Thị Ngọc Mai Trang 72 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Đối với toán B: Độ tin cậy phần mềm ( r37 ) B’ yij [ x6 ,…, x37 ] [r6 ,…, r36 ] Chi phí phần mềm (B) 100 [9.00, 5.00, 7.00, 6.00, 8.00, 6.00, 9.00, 7.00, 8.00, 6.00, 9.00, 5.00, 8.00, 7.50, 8.50, 9.00, 10.00, 10.00, 9.00, 8.00, 5.00, 7.00, 6.00, 9.00, 7.50, 6.50, 8.00, 9.00, 11.00, 7.00, 9.00, 15.00] [0.30, 0.50, 0.40, 0.30, 0.64, 0.40, 0.50, 0.40, 0.45, 0.40, 0.35, 0.40, 0.45, 0.50, 0.55, 0.30, 0.40, 0.22, 0.38, 0.30, 0.05, 0.19, 0.23, 0.02, 0.04, 0.09, 0.003, 0.01, 0.04, 0.32] 287 [9.00, 5.00, 15.36, 6.00, 8.00, 6.00, 9.00, 7.00, 10.48, 6.00, 9.00, 5.00, 12.30, 7.50, 8.50,14.82, 15.67, 10.00, 9.00, 8.25, 5.00, 7.00, 6.00, 9.00, 7.50, 8.16, 8.00, 9.00, 23.63, 7.62, 9.00,15.00] [0.30, 0.50, 0.89, 0.30, 0.64, 0.40, 0.50, 0.40, 0.77, 0.40, 0.35, 0.4, 0.84, 0.50, 0.55, 0.87, 0.91, 0.28, 0.45, 0.78, 0.07, 0.54, 0.63, 0.03, 0.10, 0.45, 0.004, 0.04, 0.38, 0.67, 0.29] 324.68 [9.00, 5.00, 16.66, 6.00, 8.00, 6.00, 9.00, 7.00, 15.32, 6.00, 9.00, 5.00, 14.85, 7.50, 8.50, 17.60, 16.81, 10.00, 9.00, 8.10, 5.00, 7.00, 7.70, 9.00, 7.50, 9.68, 8.00, 9.00, 40.89, 8.05, 9.00, 15.00] [0.30, 0.50, 0.90, 0.30, 0.64, 0.40, 0.50, 0.40, 0.93, 0.40, 0.35, 0.40, 0.90, 0.50, 0.55, 0.93, 0.93, 0.28, 0.45, 0.79, 0.07, 0.58, 0.66, 0.03, 0.11, 0.58, 0.004 0.04, 0.53, 0.59 0.45] 340.77 [9.00, 5.00, 18.47, 6.00, 8.00, 6.00, 9.00, 7.00, 16.47, 6.00, 9.00, 5.00, 15.76, 7.50, 8.50, 19.32, 17.39, 10.00, 9.00, 11.03, 5.00, 7.00, 8.27, 9.00, 7.50, 11.21, 8.00, 9.00, 47.29, 7.02, 9.05,15.00] [0.30, 0.50, 0.91, 0.30, 0.64, 0.40, 0.50, 0.40, 0.94, 0.40, 0.35, 0.40, 0.91, 0.50, 0.55, 0.94, 0.94, 0.27, 0.45, 0.84, 0.07, 0.58, 0.71, 0.03, 0.11, 0.65, 0.004 0.042, 0.59, 0.84, 0.5187] 378.91 1000 0.0014 33 100 100 10 001 0001 0.2 44 001 001 01 001 0001 0.3 44 001 001 01 001 0001 0.5 44 001 001 01 Bảng 6.8: Kết chạy phần mềm có 37 module cho toán B Phan Thị Ngọc Mai Trang 73 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm 6.3 Kết luận Tự động hóa q trình phân phối chi phí để đánh giá độ tin cậy phần mềm toán mở, nhiều phương pháp đưa để giải toán Phương pháp kết hợp quy hoạch nguyên quy hoạch phi tuyến hàm nhiều biến giải pháp đề xuất để giải vấn đề Đứng góc độ cơng trình nghiên cứu, luận văn cố gắng đưa hai giải pháp nhằm cung cấp thêm cách thức để giải tốn Mơ hình tính tốn độ tin cậy phần mềm dựa vào phân phối chi phí Bằng việc sử dụng phương pháp quy hoạch nguyên nhị phân để thực việc phân phối chi phí cho module mua, kết hợp với phương pháp quy hoạch phi tuyến để giải hàm số mũ nhiều biến, để thực hiệc việc phân phối chi phí cho module phát triển Thông qua việc kết hợp này, luận văn dùng hàm Matlab để xây dựng hai giải pháp cho phép kết hợp toán quy hoạch nguyên quy hoạch phi tuyến cách tự động Chương trình thực cung cấp giải với độ xác tương đối cho số minh họa cụ thể Tuy nhiên, chương trình có vài hạn chế: ƒ Hiện mơ hình thực hàm phân phối mũ để tính độ tin cậy module ƒ Việc phân phối chi phí module mua module phát triển cơng ty cịn mang tính cảm tính, làm cho lời giải tốn chưa tối ưu ƒ Chương trình sử dụng hàm Matlab để thực việc tối ưu hóa, mà khơng can thiệp vào bên ƒ Do số liệu chương trình tự tạo kết chương trình chưa xác thực tế Đây hạn chế mà phạm vi luận văn chưa thể giải trọn vẹn Một số đề xuất hướng mở rộng dựa vào hạn chế vừa nêu: ƒ Xây dựng mơ hình khác mơ hình số mũ để giải việc phân phối chi phí Phan Thị Ngọc Mai Trang 74 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm ƒ Xây dựng giải thuật thực việc phân phối chi phí module mua module phát triển cách tối ưu ƒ Xây dựng hàm quy hoạch phi tuyến tồn biến nguyên biến thực để giải toán cách tối ưu ƒ Lấy liệu thực từ hãng phần mềm ứng dụng vào mơ hình Với mở rộng xây dựng giải pháp hữu hiệu cho tốn Đây hướng phát triển luận văn Phan Thị Ngọc Mai Trang 75 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Tài Liệu Tham Khảo [1] Jonathan F.Bard “Practical Bilevel Optimization Algorithms and Applications” Springer 1999, ISBN 0-7923-5458-3 [2] John W Chinneck “Practical Optimization: A Gentle Introduction” Systems and Computer Engineering Carleton University Ottawa, Ontario K1S 5B6 Canada 74Hhttp://www.sce.carleton.ca/faculty/chinneck/po.html [3] Hoang Pham, “Software Reliability” Springer – Verlag Singapore Pte.Ltd.2000 [4] Lê Quang Hồng Nhân, “Giáo trình Tốn Cao Cấp – Phần Giải Tích” Nhà xuất thống kê [5] Nguyễn Đức Thành, “MATLAB ứng dụng điều khiển” Nhà xuất Đại học Quốc gia Tp.HCM [6] Nguyễn Nhật Lệ - Phan Mạnh Dần “Giải toán tối ưu hoá ứng dụng MATLAB-MAPLE tối ưu hoá tĩnh điều khiển tối ưu” Nhà xuất Khoa học Kỹ thuật Hà Nội [7] O.Berman and M.Cutler, “Cost Allocation for Software Reliability, Recent Advances in Reliability and Quality Engineering”, Vol.2, Series on Quality, Reliability & Engineering Statistisc, Editor Hoang Pham, Word Scientific, 2001 0.2, 1.1 Phan Thị Ngọc Mai Trang 76 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Phụ lục Bảng đối chiếu Thuật ngữ Anh - Việt Thuật ngữ Tiếng Anh Thuật ngữ Tiếng Việt Algorithm Giải thuật Bartitioning Sự phân chia Binary Integer Programming Quy hoạch nguyên nhị phân Branch and bound Nhánh cận Branching Sự phân nhánh Bounding Sự giới hạn Cost Allocation Phân phối chi phí Branching Sự phân nhánh In-house Developed module Module tự phát triển công ty Integation module Module tích hợp Fathoming Sự thăm dị Linear Programming Quy hoạch tuyến tính Mathematical Tốn học Mean Value Function Hàm giá trị trung bình Nonlinear Programming Quy hoạch phi tuyến Optimization Tối ưu Pruning Sự loại bỏ Purchased module Module mua Resource Allocation Phân phối tài nguyên Software system Hệ thống phần mềm Software Reliability Độ tin cậy phần mềm Solution Giải pháp Phan Thị Ngọc Mai Trang 77 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Phụ lục Bảng tóm tắt mơ hình đánh giá độ tin cậy phần mềm Một vài mơ hình đánh giá độ tin cậy phần mềm dựa vào q trình phân phối Poisson khơng đồng (Non-homogeneous Poisson Process - NHPP) NHPP nhóm mơ hình cung cấp q trình phân tích, mơ tả tượng lỗi phần mềm trình kiểm tra Điểm mơ hình NHPP đánh giá hàm giá trị trung bình (Mean Value Function – MVF) số lượng lỗi tích lũy khoảng thời gian [3] t m(t ) = ∫ λ ( s )ds Hàm độ tin cậy phần mềm là: t R (t ) = e − m ( t ) = e Tên mơ hình Goel-Okumoto (G-O) Delayed S-shaped ∫ − λ ( s ) ds Loại mô MVF (m(t)) hình Concave S-shaped m(t ) = a (1 − e − bt ) a (t ) = a b(t ) = b m(t ) = a (1 − (1 + bt )e − bt ) a(t ) = a b(t ) = Inflection S-shaped Yamade exponential Concave Concave b 2t + bt a(1 − e − bt ) m(t ) = + βe −bt a(t ) = a b b(t ) = + βe −bt m(t ) = a(1 − e − rα (1−e a (t ) = a ( − βt ) ) ) b(t ) = rαβ te − βt Phan Thị Ngọc Mai Trang 78 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm m(t ) = a (1 − e −rα (1−e Yamada Rayleigh S-shaped ( − βt / ) ) ) a (t ) = a b(t ) = rαβ te − βt /2 ab (eαt − e −bt ) α +b a (t ) = aeαt m(t ) = Yamada imperfect debugging model (1) S-shaped b(t ) = b m(t ) = a[1 − e −bt ][1 − Yamada imperfect debugging model (2) S-shaped α b ] + αat a (t ) = aeαt b(t ) = b S-shaped Pham-Nordmann concave m(t ) = Pham-Zhang concave Phan Thị Ngọc Mai α b ] + αat + β −bt a(t ) = a (1 + αt ) b b(t ) = + βe −bt m(t ) = S-shaped a[1 − e −bt ][1 − 1+ β −bt [(c + a )(1 − e −bt ) a (e −αt − e −bt )] b −α a (t ) = c + a(1 − e −αt ) b b(t ) = + β e −bt − Trang 79 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Phụ lục Sơ lược MATLAB MATLAB [4] có ngồn gốc từ chữ matrix laboratory, ngơn ngữ máy tính dùng để tính tốn kỹ thuật MATLAB sản phẩm công ty The Mathworks Inc, với địa www.mathworks.com sử dụng MATLAB phải có quyền Tuy nhiên, có nhiều hàm MATLAB viết người sử dụng phổ biến miễn phí mạng giúp cho MATLAB ngày phong phú Dưới trích hàm sử dụng chương trình [5][6] a) Hàm bintprog: tìm nghiệm tối ưu tốn lập trình số ngun nhị phân có dạng: Hàm mục tiêu: Minimize f y điều kiện ràng buộc: A y ≤ b Aeq y = beq đó: ƒ f , b, beq : vector ƒ A, Aeq : ma trận ƒ Các biến y bắt buộc phải biến nhị phân, nghĩa chúng nhận giá trị: Cú pháp: ƒ y = bintprog(f) ƒ y = bintprog(f, A, b) ƒ y = bintprog(f, A, b, Aeq, beq) ƒ [y, fval] = bintprog( ) ƒ [y,fval, exitflag] = bintprog( ) ƒ [y, fval, exitflag, output] = bintprog( ) Phan Thị Ngọc Mai Trang 80 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Mô tả: ƒ y = bintprog(f): giải tốn lập trình số ngun nhị phân có dạng: Minimize f y ƒ y = bintprog(f, A, b): tìm nghiệm tối ưu tốn lập trình số nguyên nhị phân có dạng: Min f y với điều kiện ràng buộc: A y ≤ b ƒ y = bintprog(f, A, b , Aeq, beq): tìm nghiệm tối ưu tốn lập trình số ngun nhị phân có dạng: Minimize f y với điều kiện ràng buộc: A y ≤ b Aeq y = beq ƒ [y, fval] = bintprog( ) trả giá trị hàm mục tiêu fval , nghiệm tối ưu y ứng với hàm mục tiêu ƒ [y,fval, exitflag] = bintprog( ) tương tự trên, cộng thêm exitflag mô trả trạng thái toán bintprog Exitflag =1 : hàm hội tụ đến giải pháp y Exitflag =0 : số lượng lần lặp lặp lại vượt q Options.MaxIter Exitflag =-2 : tốn khơng thể làm Exitflag =-4 : số lượng node vượt số lần lặp cực đại cho phép (Options.MaxIter) Exitflag =-5 : thời gian tìm kiếm vượt Options.Maxtime b) Hàm fmincon: tìm nghiệm tối ưu hàm nhiều biến có dạng: Hàm mục tiêu: f ( x) Phan Thị Ngọc Mai Trang 81 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm Các điều kiện ràng buộc: c( x) ≤ ceq( x) = A* x ≤ b Aeq * x = beq lb ≤ x ≤ ub Trong ƒ x, b, beq, lb, ub vector ƒ A, Aeq ma trận ƒ c( x), ceq( x) hàm trả vertor ƒ f ( x), c( x), ceq( x) phương trình phi tuyến Cú pháp: ƒ x = fmincon(fun,x0,A,b) ƒ x = fmincon(fun,x0,A,b,Aeq,beq) ƒ x = fmincon(fun,x0,A,b,Aeq,beq,lb,ub) ƒ x = fmincon(fun,x0,A,b,Aeq,beq,lb,ub,nonlcon) ƒ x = fmincon(fun,x0,A,b,Aeq,beq,lb,ub,nonlcon,options) ƒ [x,fval] = fmincon( ) ƒ [x,fval,exitflag] = fmincon( ) ƒ [x,fval,exitflag,output] = fmincon( ) ƒ [x,fval,exitflag,output,lambda] = fmincon( ) ƒ [x,fval,exitflag,output,lambda,grad] = fmincon( ) ƒ [x,fval,exitflag,output,lambda,grad,hessian] = fmincon( ) Mô tả: ƒ fmincon: cố gắng tìm cực tiểu thỏa mãn điều kiện ràng buộc phi tuyến tuyến tính Phan Thị Ngọc Mai Trang 82 LUAN VAN CHAT LUONG download : add luanvanchat@agmail.com Một giải pháp toán học cho việc phân phối tài nguyên độ tin cậy phần mềm ƒ x = fmincon(fun,x0,A,b): bắt đầu tìm kiếm x0 cố gắng tìm cực tiểu x để hàm mục tiêu đạt giá trị nhỏ thỏa mãn điều kiện ràng buộc A*x

Ngày đăng: 01/11/2022, 16:04

w