Kỹ thuật xác thực kết cấ u

Một phần của tài liệu Kiểm tra mô hình phần mềm sử dụng lý thuyết Ôtômat Buchi và Logic thời gian tuyến tín (Trang 37 - 40)

Kỹ thuật xác thực kết cấu (Compositional verification) khai thác dựa trên sự phân rã một hệ thống phức tạp thành các thành phần đơn giản hơn. Các thuộc tính của các thành phần hệ thống được xác thực đầu tiên. Những thuộc tính này sau đó được hợp lại với nhau để suy ra các thuộc tính của hệ

thống tổng thể. Rõ ràng là, cách tiếp cận này không phải đối mặt với khó khăn về bùng nổ không gian trạng thái vì nó không yêu cầu phải xây dựng trên không gian trạng thái của hệ thống. Một vấn đề nữa đó là những trạng thái của các hệ thống con chỉ được thoả mãn chỉ khi các giả định được đặt ra trên môi trường đó. Một cách tiếp cận cho vấn dề này là sử dụng giao diện các tiến trình để mô hình hoá môi trường của các hệ thống con. [2]

Một số lượng lớn các nghiên cứu đều dành cho xác thực kết cấu, đưa lại những hi vọng khả quan về việc ngăn chặn sự bùng nổ không gian trạng thái. Giải thuật rút gọn cục bộ có thể coi như một phương pháp xác thực kết cấu đơn giản vì nó sẽ chứng minh các thuộc tính của hệ thống tổng thể bằng cách kiểm tra xem nó có thoả mãn một số các thành phần của hệ thống. Thuận lợi của việc rút gọn cục bộđó là nó có thể tựđộng được.

Nhìn chung, đó là một nhiệm vụ phức tạp để phân rã các thuộc tính của một hệ thống tổng thể thành các thuộc tính cục bộ của các thành phần của hệ

thống. Hơn nữa, nó phải chứng minh rằng sự phân rã đó là đúng đắn, đó là: phải thoả mãn các thuộc tính cục bộ của các hệ thống con và các thuộc tính tổng thể của hệ thống. Cách tiếp cận này được hỗ trợ bởi các công cụ tựđộng

ở mức độ cao để được sử dụng một cách rộng rãi bởi các kỹ sư phần mềm. Theo các kết quả nghiên cứu, tìm ra một heuristic có ích để quyết định sự

phân rã các thuộc tính của hệ thống tổng thể thành các thuộc tính cục bộ của các hệ thống con là một trong những vấn đề mở trước tiên của lĩnh vực này.

2.6 KẾT LUẬN CHƯƠNG

Để kiểm tra mô hình phần mềm, các kỹ thuật đưa ra đều tuân theo một nguyên tắc chung đó là phải trừu tượng hoá mô hình hệ thống và thuộc tính hệ

thống cần thoả mãn. Sau đó, sử dụng bộ kiểm tra mô hình để kiểm tra xem hệ

thống có thoả mãn thuộc tính đó hay không. Nếu thoả mãn, đưa ra thông báo thành công, nếu không thoả mãn, đưa ra các vết lỗi để thiết kế lại. Điểm khác nhau cơ bản giữa 4 kỹ thuật đề xuất: biểu diễn ký hiệu, duyệt nhanh, rút gọn, xác thực kết cấu đó là cách xử lý để tránh sự bùng nổ không gian trạng thái của hệ thống. Trong 4 kỹ thuật trên, điều khiển không gian trạng thái hiệu quả

nhất là kỹ thuật duyệt nhanh (On the fly). Bằng cách thức sử dụng hàm băm

để lưu trữ toàn bộ không gian trạng thái, nhưng quá trình duyệt và tìm kiếm trạng thái lại rất nhanh. Mặt khác kỹ thuật duyệt nhanh không yêu cầu phải lưu trữ các chuyển trạng thái, sử dụng kỹ thuật bộ nhớ cache để tiết kiệm dung lượng bộ nhớ, tăng tốc độ tìm kiếm. Đồng thời với việc dựa trên các ưu

điểm lưu trữ của kỹ thuật duyệt nhanh, luận văn sẽ đi sâu nghiên cứu tìm ra giải thuật để giải quyết bài toán kiểm tra mô hình phần mềm sử dụng kỹ thuật duyệt nhanh sẽđược đề cập ở chương 3 tiếp theo.

CHƯƠNG 3:

K THUT KIM TRA MÔ HÌNH PHN MM S DNG LÝ THUYT LOGIC THI GIAN TUYN TÍNH VÀ

ÔTÔMAT BUCHI 3.1. BÀI TOÁN KIỂM TRA MÔ HÌNH PHẦN MỀM

Bài toán đặt ra: Cho một hệ thống chuyển trạng thái T và một thuộc tính f. Cần kiểm tra xem hệ thống T có thoả mãn thuộc tính f hay không?

Ý tưởng giải quyết: [5]

- Chuyển đổi hệ thống chuyển trạng thái T về dạng Ôtômat Buchi, ký hiệu AT

- Đặc tả thuộc tính f dưới dạng Logic thời gian tuyến tính (LTL – Linear Temporal Logic)

- Lấy phủ định của thuộc tính LTL f là ¬f và chuyển ¬f sang dạng Ôtômat Buchi A¬f

- Kiểm tra giao của các ngôn ngữ được đoán nhận bởi AT và A¬f có là rỗng hay không, tức là:

o L(AT) ∩ L(A¬f) = ∅

o Nếu L(AT) ∩ L(A¬f) ≠ ∅ chứng tỏ hệ thống chuyển trạng thái T

đã vi phạm thuộc tính f, đưa ra vết lỗi. - Chú ý:

o L(AT) ∩ L(A¬f) = ∅ nếu và chỉ nếu L(AT) ⊆ L(A¬f)

o Cho hai Ôtômat Buchi AT và A¬f, xây dựng tích chập của hai Ôtômat AT × A¬f như sau:

o Sau đó, ta kiểm tra ngôn ngữ được đoán nhận bởi Ôtômat Buchi AT × A¬f có bằng rỗng (empty) hay không.

Một phần của tài liệu Kiểm tra mô hình phần mềm sử dụng lý thuyết Ôtômat Buchi và Logic thời gian tuyến tín (Trang 37 - 40)

Tải bản đầy đủ (PDF)

(102 trang)