HỌC VIỆN CÔNG NGHỆ BƯU CHÍNH VIỄN THÔNG KHOA ĐÀO TẠO QUỐC TẾ VÀ SAU ĐẠI HỌC BÁO CÁO MÔN HỌC CÁC KỸ THUẬT TỐI ƯU Lập trình di truyền mã hóa cặp nút cho thiết kế topo mạng mắt lưới quang Giảng viên : TS. Lê Nhật Thăng Học Viên : Nguyễn Đình Hùng Phạm Công Huy Lớp : Khoa học máy tính 20131 Hà Nội, tháng 4 năm 2014 MỤC LỤC CHƯƠNG 1: CÁC KỸ THUẬT TÍNH TOÁN THÍCH ỨNG VÀ HEURISTIC TRONG VIỄN THÔNG 1 1.1 Các vấn đề tối ưu hóa trong viễn thông 1 1.2 Bài toán động và thích ứng. 2 1.3 Các kỹ thuật Heuristic hiện đại 3 1.3.1 Tìm kiếm cục bộ 4 1.3.2 Tìm kiến dựa trên tập hợp (PopulationBased Search) 10 1.4 Kỹ thuật tính toán thích nghi 12 1.4.1 Tính toán hệ thần kinh 14 1.4.2 Logic mờ 14 1.4.3 Lý thuyết trò chơi 15 1.5 Tổng kết 15 CHƯƠNG 6: LẬP TRÌNH DI TRUYỀN MÃ HÓA CẶP NÚT CHO THIẾT KẾ MẠNG MẮT LƯỚI QUANG 17 6.1 Giới thiệu 17 6.2 Tính toán tiến hóa cho thiết kế topo mạng 18 6.3 Mô tả bài toán 19 6.4 Các cách tiếp cận trước đây 22 6.4.1 Các thuật toán lai 23 6.4.2 Lập trình di truyền cho các cặp nút kết nối 23 6.5 Lập trình di truyền mã hóa cặp nút 24 6.6 Các kết quả thực nghiệm 27 6.6.1 Các thuật toán di truyền 28 6.6.2 Kết nốinút GP 30 6.6.3 NodePair Encoding GP 30 6.6.4 So sánh 31 6.7 Kết luận và hướng phát triển trong tương lai 33 Lời cảm ơn 35 TÀI LIỆU THAM KHẢO 36 CHƯƠNG 1: CÁC KỸ THUẬT TÍNH TOÁN THÍCH ỨNG VÀ HEURISTIC TRONG VIỄN THÔNG 1.1 Các vấn đề tối ưu hóa trong viễn thông Sự phức tạp và kích thước của các mạng viễn thông hiện đại cung cấp cho chúng ta nhiều thách thức và cơ hội. Trong cuốn sách này, những thách thức mà chúng tôi tập trung vào là những liên quan đến việc tối ưu hóa. Điều này chỉ đơn giản đề cập tới những trường hợp mà trong đó chúng ta đang hướng tới tìm một cách tiếp cận phương án tốt nhất giữa nhiều phương án có thể có để giải quyết bài toán. Ví dụ, có một số lượng lớn cách để thiết kế các cấu trúc liên kết một mạng dữ liệu riêng cho một công ty lớn. Làm thế nào chúng ta có thể tìm thấy một thiết kế đặc biệt tốt trong tất cả các khả năng? Ngoài ra, chúng ta có thể thử tìm một cách tốt để gán kênh tần số cho nhiều người sử dụng mạng di động. Có một loạt các khó khăn phức tạp liên quan ở đây, số lượng các phương án có thể đáp ứng các khó khăn vẫn còn quá lớn để chúng tôi hy vọng sẽ kiểm tra lần lượt từng phương án trong số chúng. Vì vậy, một lần nữa, chúng ta cần một số cách để tìm ra giải pháp tốt trong tất cả các khả năng. Những thách thức hiện tại là cơ hội cho sự hợp tác giữa các kỹ sư viễn thông, các nhà nghiên cứu và phát triển trong khoa học máy tính và trí tuệ nhân tạo cộng đồng. Đặc biệt, có một bộ các công nghệ phần mềm mới nổi nhằm tối ưu hóa các vấn đề mà hiện nay đang được được sử dụng trong ngành công nghiệp, nhưng có tiềm năng lớn cho các giải pháp có lợi nhuận và hiệu quả cho nhiều bài toán trong ngành viễn thông. Phần lớn cuốn sách này tập trung vào các kỹ thuật tối ưu hóa, và các công trình nghiên cứu trong các chương sắp tới trình bày một phần việc áp dụng những kỹ thuật này cho các bài toán liên quan đến viễn thông. Các kỹ thuật sử dụng bao gồm các phương pháp tìm kiếm địa phương “ như ủ mô phỏng (Aarts và Korst, 1989) và tìm kiếm tabu (Glover, 1989; 1989a), và các kỹ thuật tìm kiếm dựa trên tập hợp như thuật toán di truyền (Hà Lan, 1975 ; Goldberg, 1989), chiến lược phát triển (Schwefel, 1981; Back, 1996), lập trình tiến hóa (Fogel, 1995) và lập trình di truyền (Koza, 1992). Mục 1.3 giới thiệu ngắn gọn và cơ bản các kỹ thuật trên, dành cho các kỹ sư viễn thông, quản lý hoặc nghiên cứu, những người hiểu biết quá nhiều về vấn đề này, nhưng chưa biết cách để giải quyết chúng. Chương sau thảo luận về việc sử dụng liên quan đến các bài toán đặc biệt trong viễn thông. 1.2 Bài toán động và thích ứng. Một khía cạnh cơ bản của nhiều vấn đề tối ưu hóa trong viễn thông là một thực tế rằng các giải pháp tối ưu là động. Những gì có thể là giải pháp tốt nhất bây giờ có thể không phải là giải pháp lý tưởng trong một vài giờ, hoặc thậm chí một vài phút. Ví dụ, các nhà cung cấp dịch vụ của một cơ sở dữ liệu phân tán ( như video theo yêu cầu,
Trang 1-********** -BÁO CÁO MÔN HỌC: CÁC KỸ THUẬT TỐI ƯU
Đề tài: Lập trình di truyền mã hóa cặp nút cho thiết
kế topo mạng mắt lưới quang
Phạm Công Huy
Hà Nội, tháng 4 năm 2014
Trang 2VIỄN THÔNG 1
1.1 Các vấn đề tối ưu hóa trong viễn thông 1
1.2 Bài toán động và thích ứng 2
1.3 Các kỹ thuật Heuristic hiện đại 3
1.3.1 Tìm kiếm cục bộ 4
1.3.2 Tìm kiến dựa trên tập hợp (Population-Based Search) 10
1.4 Kỹ thuật tính toán thích nghi 12
1.4.1 Tính toán hệ thần kinh 14
1.4.2 Logic mờ 14
1.4.3 Lý thuyết trò chơi 15
1.5 Tổng kết 15
CHƯƠNG 6: LẬP TRÌNH DI TRUYỀN MÃ HÓA CẶP NÚT CHO THIẾT KẾ MẠNG MẮT LƯỚI QUANG 17
6.1 Giới thiệu 17
6.2 Tính toán tiến hóa cho thiết kế topo mạng 18
6.3 Mô tả bài toán 19
6.4 Các cách tiếp cận trước đây 22
6.4.1 Các thuật toán lai 23
6.4.2 Lập trình di truyền cho các cặp nút kết nối 23
6.5 Lập trình di truyền mã hóa cặp nút 24
6.6 Các kết quả thực nghiệm 27
6.6.1 Các thuật toán di truyền 28
6.6.2 Kết nối-nút GP 30
6.6.3 Node-Pair Encoding GP 30
6.6.4 So sánh 31
Trang 3TÀI LIỆU THAM KHẢO 36
Trang 4CHƯƠNG 1: CÁC KỸ THUẬT TÍNH TOÁN THÍCH ỨNG VÀ HEURISTIC TRONG VIỄN THÔNG
1.1 Các vấn đề tối ưu hóa trong viễn thông
Sự phức tạp và kích thước của các mạng viễn thông hiện đại cung cấp cho chúng
ta nhiều thách thức và cơ hội Trong cuốn sách này, những thách thức mà chúng tôi tậptrung vào là những liên quan đến việc tối ưu hóa Điều này chỉ đơn giản đề cập tớinhững trường hợp mà trong đó chúng ta đang hướng tới tìm một cách tiếp cận phương
án tốt nhất giữa nhiều phương án có thể có để giải quyết bài toán Ví dụ, có một sốlượng lớn cách để thiết kế các cấu trúc liên kết một mạng dữ liệu riêng cho một công
ty lớn Làm thế nào chúng ta có thể tìm thấy một thiết kế đặc biệt tốt trong tất cả cáckhả năng? Ngoài ra, chúng ta có thể thử tìm một cách tốt để gán kênh tần số cho nhiềungười sử dụng mạng di động Có một loạt các khó khăn phức tạp liên quan ở đây, sốlượng các phương án có thể đáp ứng các khó khăn vẫn còn quá lớn để chúng tôi hyvọng sẽ kiểm tra lần lượt từng phương án trong số chúng Vì vậy, một lần nữa, chúng
ta cần một số cách để tìm ra giải pháp tốt trong tất cả các khả năng
Những thách thức hiện tại là cơ hội cho sự hợp tác giữa các kỹ sư viễn thông, cácnhà nghiên cứu và phát triển trong khoa học máy tính và trí tuệ nhân tạo cộng đồng.Đặc biệt, có một bộ các công nghệ phần mềm mới nổi nhằm tối ưu hóa các vấn đề màhiện nay đang được được sử dụng trong ngành công nghiệp, nhưng có tiềm năng lớncho các giải pháp có lợi nhuận và hiệu quả cho nhiều bài toán trong ngành viễn thông.Phần lớn cuốn sách này tập trung vào các kỹ thuật tối ưu hóa, và các công trìnhnghiên cứu trong các chương sắp tới trình bày một phần việc áp dụng những kỹ thuậtnày cho các bài toán liên quan đến viễn thông Các kỹ thuật sử dụng bao gồm cácphương pháp "tìm kiếm địa phương “ như ủ mô phỏng (Aarts và Korst, 1989) và tìmkiếm tabu (Glover, 1989; 1989a), và các kỹ thuật tìm kiếm 'dựa trên tập hợp' như thuậttoán di truyền (Hà Lan, 1975 ; Goldberg, 1989), chiến lược phát triển (Schwefel, 1981;Back, 1996), lập trình tiến hóa (Fogel, 1995) và lập trình di truyền (Koza, 1992) Mục1.3 giới thiệu ngắn gọn và cơ bản các kỹ thuật trên, dành cho các kỹ sư viễn thông,quản lý hoặc nghiên cứu, những người hiểu biết quá nhiều về vấn đề này, nhưng chưa
Trang 5biết cách để giải quyết chúng Chương sau thảo luận về việc sử dụng liên quan đến cácbài toán đặc biệt trong viễn thông.
1.2 Bài toán động và thích ứng.
Một khía cạnh cơ bản của nhiều vấn đề tối ưu hóa trong viễn thông là một thực tếrằng các giải pháp tối ưu là động Những gì có thể là giải pháp tốt nhất bây giờ có thểkhông phải là giải pháp lý tưởng trong một vài giờ, hoặc thậm chí một vài phút Ví dụ,các nhà cung cấp dịch vụ của một cơ sở dữ liệu phân tán ( như video theo yêu cầu,dịch vụ web - bộ nhớ đệm, vv) phải cố gắng để đảm bảo chất lượng dịch vụ cho mỗikhách hàng Để làm điều này liên quan đến việc chuyển hướng cơ sở dữ liệu của kháchhàng truy cập đến các máy chủ khác nhau tại các thời điểm khác nhau ( khách hàngkhông thể nhận biết) để thực hiện phù hợp cân bằng tải giữa các máy chủ Kỹ thuật tối
ưu hóa hiện đại có thể được sử dụng để phân phối tải trọng phù hợp trên các máy chủ,tuy nhiên giải pháp này trở nên không hợp lệ ngay sau khi có sự thay đổi trung bìnhtrong mô hình truy cập cơ sở dữ liệu của khách hàng Một ví dụ khác là định tuyến góichung trong một mạng point-to -point Theo truyền thống, bảng định tuyến tại mỗi nútđược sử dụng để tìm kiếm ' bước kế tiếp ' tốt nhất cho một gói dựa trên điểm đến cuốicùng của nó Chúng ta có thể tưởng tượng một kỹ thuật tối ưu hóa áp dụng cho vấn đềnày, kỹ thuật này dựa vào mô hình tổng thể và xác định các bảng định tuyến thích hợpcho mỗi nút, do đó ùn tắc chung và sự chậm trễ có thể được giảm thiểu, tức là trongnhiều trường hợp là ‘bước kế tiếp’ tốt nhất có thể không tìm được nút tiếp theo trêncon đường ngắn nhất, vì liên kết này có thể được được sử dụng nhiều rồi Tuy nhiên,đây rõ ràng là một chương trình cần được thực hiện lặp đi lặp lại như những biểu đồthay đổi lưu lượng truy cập
Việc thực hiện lặp đi lặp lại của các kỹ thuật tối ưu hóa là một trong những cách
có thể để tiếp cận các bài toán động, nó thường là một cách khá phù hợp, đặc biệt làkhi các giải pháp tốt yêu cầu cần thiết phải rất nhanh, vì môi trường thay đổi rất nhanhchóng Thay vào đó, một phạm vi khác của các kỹ thuật tính toán hiện đại thườngthích hợp cho các bài toán như vậy Chúng ta có thể gọi chung lớp này là kỹ thuật
"thích ứng", mặc dù việc sử dụng ở các chương sau trong cuốn sách này thực sự khá
đa dạng Đặc biệt, chương sau sẽ sử dụng tính toán thần kinh (neural), logic mờ và lý
Trang 6thuyết trò chơi để giải quyết tối ưu hóa thích nghi trong môi trường động, trong một sốtrường hợp kết hợp với tìm kiếm cụ bộ hoặc dựa vào tập hợp Về cơ bản, một kỹ thuậttối ưu hóa cung cấp một cách nhanh chóng và hiệu quả để tìm một giải pháp tốt trongnhiều giải pháp, một kỹ thuật thích ứng phải cung cấp một giải pháp tốt gần như làngay lập tức.
Thủ thuật ở đây đó là các phương pháp sử dụng tiến trình “off-line” để học về vấn
đề đang giải quyết sao cho khi mà các kết quả tốt và nhanh được yêu cầu thì chúng sẽđược chuyển đi Ví dụ, một cách tiếp cận thích hợp cho việc định tuyến gói tin trongcác mặt thay đổi trong mô hình giao thông sẽ bao gồm một số liên tục nhưng tôi thiểuhóa xử lý mà được cập nhật liên tục trong bảng định tuyến tại mỗi nút dựa trên thôngtin hiện tại về độ trễ và mức độ giao thông
Trong phần còn lai của chương này chúng ta sẽ giới thiệu ngắn gọn về sự tối ưu và
và các kỹ thuật thích ứng mà chúng ta đã đề cập ở trên Chi tiết sẽ được nói ở cácchương sau Sau đó chúng ta sẽ nói một chút về ba phần trong cuốn sách này trong cácchương tiếp theo Sau cùng, chúng ta sẽ chỉ ra tại sao những kỹ thuật này là quan trọngtrong viễn thông, và chúng sẽ ngày càng phát triển theo thời gian
1.3 Các kỹ thuật Heuristic hiện đại
Có một loạt các phương pháp nổi tiếng trong hoạt động nghiên cứu, như là : quyhoạch động (DynamicProgramming), quy hoạch tuyến tính (Integer Programming ).V v đã được sử dụng để giải quyết các lọa vấn đề tối ưu khác nhau Tuy nhiên , mộtcộng đồng lớn của các nhà khoa học máy tính và các nhà nghiên cứu trí tuệ nhân tạongày nay đang dành rất nhiều nỗ lực vào những ý tưởng hiện đại hơn được gọi là
“metaheuristics” hay còn gọi là “heuristic” Vấn đề khác nhau cơ bản giữa các phươngpháp hiên đại và phương pháp cổ điển đó là , nó dễ áp dụng hơn Tực là nếu đưa ramột vấn đề thực tế điển hình và phức tạp thì nó sẽ cần ít công sức để phát triển cáchtiếp cận mô hình tôi thép để giải quyết vấn đề đó hơn là trình bày vấn đề theo cách quyhoạch tuyến tính có thể áp dụng trên nó
Điều này không nói rằng các phương pháp hiện đại sẽ làm tốt hơn phương pháp cổđiển Trên thực tế, kịch bản thực tế và điển hình khi mà cả hai loại phương pháp được
áp dụng đó là :
Trang 7 Một chuyên gia metaheuristics so sánh hại loại kỹ thuật: phương pháp hiệnđại làm tốt hơn phương pháp cổ điện
Một chuyên gia nghiên cứu các hoạt động cổ điển so sánh hai loại kỹ thuật:phương pháp cổ điển vượt trội hơn phương pháp hiện đại
Mặc dù sự quan sát này dựa trên một khía cạnh quan trọng trong việc giải quyếtcác vấn đề tối ưu bạn càng hiểu rõ các kỹ thuật riêng biệt mà bạn đang áp dụng thì bạncàng có khả sử dụng và khai thác nó để đạt được kết quả tốt hơn
Trong phần này chúng tôi chỉ cung cấp khía quát về một số thuật toán tối ưu hiệnđại, và do đó không cung cấp khá đầy đủ thông tin cho một người đọc để có thể chỉnhcho phù hợp với các vấn đề cụ thể Mặc dù chúng tôi không chỉ cho bạn cách để sángtạo với chúng, nhưng chúng tôi chỉ ra điểm mấu chốt ở đâu Làm cách nào để áp dụngsáng tạo chúng thì phụ thuộc và rất nhiều vấn đề, nhưng chương sau sẽ cung cấp cácthông tin cho từng trường hợp cụ thể Những gì sẽ trở nên rõ ràng từ chương này, tuynhiên, đó là những kỹ thuật được đánh giá cao chung trong ứng dụng của chúng.Trong thực tế, bất cứ khi nào cũng có một số cách khá sẵn để đánh giá hoặc tính điểmgiải pháp ứng cử viên cho vấn đề của bạn, sau đó các kỹ thuật này có thể được ápdụng
Về bản chất các kỹ thuật này được chia làm 2 nhóm : tìm kiếm địa phương, tìmkiếm dựa trên dân số Đó sẽ là những thứ sẽ được bàn đến tiếp theo đây
1.3.1 Tìm kiếm cục bộ
Giả sử rằng bạn đang cố gắng để giải quyết một vấn đề P, và bạn có một tập hợp S
là các giải pháp tiềm năng cho vấn đề này Bạn không nhất thiết phải có tập S, vì nóquá lớn để có thể hiểu rõ toàn bộ Tuy nhiên, bạn có một số cách để tạo ra các giảipháp từ nó Ví dụ, S có thể là một tập hợp các cấu trúc liên kết cho một mạng, và cácgiải pháp ứng cử s, s ', s'',… là các đề cử cấu trúc kết nối cụ thể mà bạn đã đưa ra theocách nào đó Thêm vào đó, hãy tưởng tượng rằng bạn có một hàm chuẩn hóa f(s)(fitness function) có chức năng đưa ra kết quả của một giải pháp đề cử Kết quả tốt hơnđồng nghĩa với việc đó là giải pháp tốt hơn Lấy ví dụ, chúng ta đang cố gắng tìm ranhững cấu trúc liên kết mạng đáng tin cậy nhất, sau đó f (s) có thể tính toán xác suấtthất bại của liên kết giữa hai nút đặc biệt quan trọng Trong trường hợp chúng ta muốn
Trang 8sử dụng nghịch đảo của giá trị này nếu chúng ta thực sự muốn gọi nó là ‘chuẩn hóa’(fitness) Trong những trường hợp khi mà kết quả thấp hơn, thì tốt hơn và thường thìthích hợp hơn đó là coi f(s) là một hàm chi phí.
Chúng ta còn cần thêm một điều nữa, mà chúng ta gọi là một toán tử lân cận(neighbourhood operator) Đây là hàm có chức năng lấy ra một giải pháp đề cử s, vàtạo ra một giải pháp đề cử mới s’ - thường chỉ hơi khác một chút so với s Chúng ta sẽ
sử dụng thuật ngữ ‘biến cố’ (mutation) để mô tả cho toán tử này Ví dụ, nếu chúng tabiến đổi một cấu trúc liên kết mạng, kết quả biến đổi có thể bao gồm một liên kết thêmkhông có trong cấu trúc liên kết ‘cha mẹ’, hoặc cũng có thể là giống như nhau Ngoài
ra, biến cố có thể loại bỏ, hoặc di chuyển, một liên kết
Bây giờ chúng ta có thể mô tả một cách cơ bản về tìm kiếm cục bộ Trước tiên,hãy xem xét một trong những phương pháp tìm kiếm cục bộ đơn giản nhất, được gọi làphương pháp leo đồi (hillclimbing), thực hiện theo các bước dưới đây:
1 Bắt đầu: tạo ra một giải pháp đề cử ban đầu (có thể bằng một cách ngẫu nhiên);gọi đây là giải pháp hiện tại, c Đánh giá nó
2 Biến đổi c để tạo ra một biến cố m, sau đó đánh giá m
3 Nếu f(m) là tốt hơn hơn hoặc tương đương f(c), vậy thì cần thay thế c với m (Ví
dụ c bây giờ là một bản sao của m).
4 Lặp lại bước 2, cho đến khi nào đạt tới một tiêu chí kết thúc
Ý tưởng của hillclimbing nên được trình bày rõ ràng theo thuật toán nêu trên Ởbất kỳ bước nào, chúng ta có một giải pháp hiện tại, và khi chúng ta nhìn vào một âncận của giải pháp này – có vài điểm khác nhau Nếu giải pháp lân cận là một bộ lọc(fitter) (hoặc tương đương), vậy thì có vẻ như là đây một ý tưởng tốt để chuyển sanglân cận đó; do đó, cần bắt đầu lại với lân cận giống như là với một giải pháp hiện tạimới Ý tưởng căn bản đằng sau điều này, và đằng sau phương pháp tìm kiếm cục bộnói chung, đó là sự hội tụ của các giải pháp tốt Bạn có thể không thực sự mong đợimột cấu trúc liên kết đáng tin cậy xuất hiện, ví dụ, thêm một liên kết đơn vào một cấutrúc liên kết không đáng tin cậy Tuy nhiên, bạn có thể mong đợi rằng một sự thay đổinhư vậy có thể biến một cấu trúc liên kết đáng tin cậy thành một cấu trúc liên kết đángtin cậy hơn
Trang 9Trong tìm kiếm cục bộ, chúng ta khai thác ý tưởng này bằng cách liên tục tìmkiếm trong vùng lân cận của giải pháp hiện tại Sau đó chúng ta sẽ chuyển đến mộtgiải pháp phù hợp, và tái thực thi quá trình này Sự nguy hiểm ở đây là chúng ta có thểgặp khó khăn trong với cái gọi là ‘tối ưu cục bộ’, tức là giải pháp hiện tại là không đủtốt cho mục đích của chúng ta, nhưng tất cả các phương án lân cận của nó thậm chícòn tồi hơn Đây là điểm không tốt đối với thuật toán leo đồi (hillclimbing), vì đơngiản là nó sẽ bị mắc kẹt ở đó Các phương pháp tìm kiếm cục bộ khác ngoàihillclimbing, có cách để giải quyết chính xác tình huống này.
Các phương pháp tìm kiếm cục bộ khác được phân biệt chúng với hillclimbing,tuy nhiên, có một số cách để giải quyết tình trạng này một cách chính xác Chúng ta sẽxem xét lại 2 phương pháp ở đây, đây là những phương pháp được sử dụng phổ biến
và được sử dụng ở phần sau trong cuốn sách này Dưới đây là mô phỏng luyện kim(simulated annealing) và tìm kiếm tabu (tabu search)
Simulated annealing
Simulated anneling giống với hillclimbing Sự khác biệt duy nhất là việc thêm vàocủa 1 cặp tham số, một bước phụ mà một số cuốn sách thực hiện với những tham sốnày, và đây là điểm chính, bước 3 được thay đổi để sử dụng các tham số này:
1 Bắt đầu: Tạo và đánh giá giải pháp ứng cử ban đầu (một cách ngẫu nhiên); gọi
đây là giải pháp hiện tại c Khởi tạo tham số nhiệt độ T và độ làm mát r (0<r<1).
2 Biến đổi c tạo ra m, kết quả của việc biến đổi c, và đánh giá m
3 Nếu đánh giá test(f(m), f(c), T) là đúng, thì thay thế c bằng m (c bây giờ là bảnsao của m)
4 Cập nhật tham số nhiệt độ (T thành rT)
5 Lặp lại bước 2, cho tới khi đạt được tiêu chí kết thúc
Vấn đề xảy ra trong mô phỏng luyện kim đó là đôi khi chúng ta chấp nhận kết quảcủa việc biến đổi ngay cả khi nó kém hơn cả giải pháp hiện tại Tuy nhiên, chúngkhông xảy ra thường xuyên và khả năng kết quả của việc biến đổi kém hơn là rất thấp.Ngoài ra, chúng ta có ít khả năng làm như vậy trong thời gian tới Kết quả tổng thể làthuật toán có cơ hội tốt để thoát khỏi optima cục bộ, do đó có thể tìm kiếm các miềntốt hơn của không gian sau này Tuy nhiên, hướng cơ bản của sự dịch chuyển về các
Trang 10miền tốt hơn được duy trì Tất cả những điều này được thực hiện trong chức năng testcủa bước 3 Một ví dụ về loại sử dụng test là đầu tiên thực hiện:
( ( )f m f c T( ))/
Giả thiết rằng chúng ta thực hiện tối ưu hóa cost (nếu không chúng ta chỉ cầnchuyển dổi f(m) và f(c)) Nếu kết quả của việc biến đổi tốt hơn hoặc tương đương giảipháp hiện tại, thì biểu thức trên sẽ lớn hơn hoặc bằng 1 Nếu kết quả của việc biến đổikém hơn, thì kết quả sẽ nhỏ hơn 1 và kém hơn kết quả biến đổi là gần bằng 0 Do đó,kết quả của biểu thức được sử dụng như một xác suất Tạo ngẫu nhiên 1 số rand, với0<rand<1 và thực hiện test trong bước 3 chỉ đơn giản là kiểm tra có hay không biểuthức nhỏ hơn rand Nếu vậy (luôn luôn được như vậy nếu kết quả biến đổi tốt hơnhoặc tương đương), chúng ta chấp nhận kết quả biến đổi T là tham số nhiệt độ Vớibắt đầu lớn và giảm dần (xem bước 4) theo thời gian Điều bạn có thể nói từ biểu thứctrên, là xác suất của kết quả biến đổi kém chấp nhận được cũng sẽ giảm dần theo thờigian
Mô phỏng luyện kim tạo ra một phương pháp mạnh, mặc dù nó khá khó khăn đểđạt được những tham số đúng Tham khảo A good modern account, Dowsland (1995)
Tabu Search
Một cách khác để thoát khỏi optima cục bộ được cung cấp bởi tìm kiếm tabu(Glover 1989; 1989a; Glover and Laguna, 1997) Có nhiều khía cạnh tinh vi để tìmkiếm tabu, ở đây chúng ta chỉ tìm hiểu về bản chất của kỹ thuật Giới thiệu một cách rõràng và đầy đủ được cung cấp trong Glover and Laguna (1995; 1997)
Phương pháp tìm kiểm Tabu, như nhiều phương pháp tìm kiếm cục bộ khác khôngbàn và xem xét về các láng giềng của giải pháp hiện tại và thậm chí chọn một trongláng giềng để chuyển đến Đặc tính có tính phân biệt này của phương pháp tìm kiếmTabu là về vấn đề đưa ra sự lựa chọn như thế nào Đây không đơn giản là việc lựachọn láng giềng nào phù hợp nhất trong số những láng giềng đã được kiểm tra.Phương pháp tìm kiếm Tabu tính đến cả sự biến đổi (mutation) mà cho chúng ta kếtquả Ví dụ, nếu láng giềng tốt nhất trong giải pháp của bạn là láng giềng mà kết nốibằng việc thay đổi liên kết từ nút k, nhưng chúng ta đã thực hiện việc kết nối đó tronglần lặp trước thì có thể một láng giềng khác sẽ được lựa chọn thay thế, thậm chí nếu sự
Trang 11di chuyển tốt nhất hiện tại là di chuyển gần đây nhất cũng có thể không được chấpnhận Tìm kiếm tabu cung cấp một cơ chế dựa trên chỉ tiêu nguyện vọng cho phép tachọn nhiều hơn nếu láng giềng đang được xem xét mà phù hợp hơn so với láng giềnghiện tại
Do vậy, bất kỳ việc cài đặt phướng pháp tìm kiếm tabu nào đều duy trì một vàidạng bộ nhớ ghi lại những thuộc tính nhất định của những di chuyển gần đây Nhữngthuộc tính này phụ thuộc nhiều vào vấn đề đang xem xét và đây là một phần của việc
áp dụng phương pháp tìm kiếm tabu Ví dụ, nếu chúng ta cố gắng tối ưu hóa topomạng, một dạng của bộ biến đổi sẽ phải thay đổi đường cáp liên kết giữa nút a và nút
b Hoặc là trong việc cài đặt phương pháp tìm kiếm tabu, chúng ta có lẽ chỉ ghi lại sựkiện thay đổi đường cáp ở lần lặp thứ i, hoặc là đơn giản chỉ ghi lại sự thay đổi trongliên kết giữa nút a với một nút mà liên kết với nút b Nếu chúng ta chỉ ghi lại kiểuthuộc tính trước đó thì những di chuyển có thể xảy ra gần thời điểm đó có thể khôngđược chấp nhận và không phụ thuộc vào các nút có liên quan Nếu chúng ta chỉ ghi lạithuộc tính sau đó thì những thay đổi tiềm năng bao gồm nút a và (hoặc) nút b có thểkhông được chấp nhận nhưng những di chuyển thay đổi cáp có thể được chấp nhận
Phương pháp tìm kiếm cục bộ Artful
Có một vài điểm chú ý về việc thuật toán tabu minh họa đó là khía cạnh quantrọng của phương pháp tìm kiểm cục bộ tốt là quyết định láng giềng nào cần di chuyểnđến Tất cả các phương pháp tìm kiếm cục bộ thực hiện các ý tưởng cơ bản về dichuyển cục bộ đều là những ý tưởng tốt Ví dụ, nếu giải pháp hiện tại của bạn tốt thì cóthể có một giải pháp tốt hơn gần đó và có thể có một giải pháp tốt hơn nữa
Tuy nhiên, rõ ràng là thỉnh thoảng (có lẽ là thường xuyên) chúng ta phải chấpnhận thực tế là chúng ta chỉ có thể tìm kiếm các giải pháp được cải tiến bằng cách tạmthời thực hiện các giải pháp khác tồi hơn Thuật toán mô phỏng annealing và phươngpháp tìm kiếm tabu là hai cách tiếp cận để giải quyết vấn đề này Tuy nhiên, đối vớimột vấn đề cụ thể thì cách tốt nhất trong triển khai và thiết kế hai cách tiếp cận trên làkhông rõ ràng Có nhiều sự lựa chọn có thể đưa ra: cách đầu tiên có thể là làm cáchnào để trình bày một giải pháp đưa ra tại vị trí đầu tiên Lấy ví dụ, một topo mạng cóthể được biểu diễn dưới dạng cách danh sách của các liên kết trong đó mỗi cặp liên kết
Trang 12là một cặp nút (a,b) Việc giải mã danh sách đó thành một topo mạng đơn giản là vẽliên kết cho mỗi cặp nút trong danh sách đó Nói cách khác, chúng ta có thể biểu diễnmột topo mạng như là một chuỗi nhị phân chứa thông tin về các liên kết có thể có Mỗi
vị trí trong chuỗi bit này sẽ có thể thể hiện một liên kết điểm tới điểm Do vậy, mộtgiải pháp đưa ra là “10010 ” có thể chỉ ra một liên kết điểm tới điểm giữa nút 1 và 2,không có liên kết giữa nút 1 và nút 3 hoặc là giữa nút 1 và nút 4 hoặc là có một liên kếtgiữa nút 1 và nút 5
Nói chung, trên đây là những cách để đưa ra một phương pháp đại diện cho cácgiải pháp của vấn đề Tất nhiên sự lựa chọn cũng ảnh hưởng đến thiết kế của các
“operator hàng xóm” Trong ví dụ trên, loại bỏ 1 liên kết từ topology liên quan đến 2loại hoạt động khác nhau trong 2 đại diện Trong trường hợp danh sách cặp node,chúng ta cần thực sự loại bỏ 1 cặp từ danh sách Trong trường hợp nhị phân, chúng tathay đổi một bit 1 đến một bit 0 trong một vị trí cụ thể trong chuỗi
Đề ra các đại diện và vận hành tốt là một phần của nghệ thuật sử dụng hiệu quảtìm kiếm địa phương để giải quyết các vấn đề tối ưu hóa cứng Tuy nhiên một phầnquan trọng khác của nghệ thuật này là vấn đề sử dụng tri thức cụ thể hoặc chuẩn đoántồn tại khi có thể Ví dụ, một vấn đề với một trong hai đại diện mà chúng ta đã ghinhận cho đến nay cho topology mạng là một topology được tạo ngẫu nhiên điển hìnhcũng có thể là không kết nối Đó là một giải pháp ứng cử có thể chỉ đơn giản là khôngchứa các đường dẫn giữa mỗi cặp nút Thông thường, chúng ta chỉ quan tâm đến cácmạng hướng kết nối, vì vậy bất kỳ thuật toán tìm kiếm nào mà effort dành cho kết nốivới các mạng hướng không kết nối thẩm định thì có vẻ khá lãng phí Đây là nơi màmiền tri thức cơ bản và những chuẩn đoán tồn tại sẽ có ích Đầu tiên, bất kỳ một nhàthiết kế mạng tốt nào đều sẽ biết các khái niệm lý thuyết đồ thị khác nhau, chẳng hạnnhư là: cây spanning, thuật toán đường đi ngắn nhất… Nó không khó để đưa ra 1 thayđổi đại diện danh sách cặp node là đã kết nối, đảm bảo rằng tất cả các giải pháp ứngviên s chứa 1 cây spanning cho mạng Một cách để làm điều này là liên quan đến việcgiải thích những cặp node đầu tiên gián tiếp Thay vì (a, b) chỉ ra rằng mạng này chứaliên kết giữa a và b, nó sẽ có nghĩa là node a đã kết nối sẽ được liên kết với node bkhông kết nối Bằng cách này, mọi cặp node tiếp theo cho thấy làm thế nào để tham
Trang 13gia như 1 node chưa được sử dụng để phát triển cây spanning Khi tất cả các node đãđược kết nối như vậy, cặp node còn lại có thể được giải thích trực tiếp.
Tuy nhiên vấn đề chúng ta giải quyết sẽ liên quan đến vấn đề chi phí, do đó chiphí của các liên kết cụ thể sẽ đóng vai trò quan trọng trong “hàm vừa đủ” (fitnessfunction) Miền tri thức cho chúng ta biết một số thuật toán nổi tiếng và nhanh chóngđưa ra đáp án cho việc tìm cây spanning chi phí nhỏ nhất (Kruskal, 1956; Prim, 1957)
Do đó nó có thể làm cho ý nghĩa tốt, tùy thuộc vào các chi tiết khác nhau của vấn đề,
để khởi tạo mỗi giải pháp ứng viên với cây chi phí nhỏ nhất, và tất cả những gì chúng
ta cần là đại diện cho các liên kết chúng ta thêm vào cây này
Có rất rất nhiều cách trong đó miền tri thức hoặc chuẩn đoán tồn tại có thể được
sử dụng để hưởng lợi từ phương pháp tiếp cận tìm kiếm địa phương cho vấn đề tối ưuhóa Một số về vấn đề này có thể cho chúng ta biết, ví dụ những loại biến đổi có cơ hộitốt hơn dẫn đến hàng xóm tốt Một phương thức chuẩn đoán hiện có cho biết nhanhchóng giao các kênh trong mạng di động, có thể được sử dụng để cung cấp điểm khởitạo cho tìm kiếm địa phương mà cố gắng để tìm ra giải pháp tốt hơn
1.3.2 Tìm kiến dựa trên tập hợp (Population-Based Search)
Một lựa chọn khác của thuật toán, hiện giờ đang rất phổ biến, được xây dựng dựatrên ý tưởng về tìm kiếm địa phương bằng cách sử dụng tập hợp các giải pháp “hiệntại” thay vì chỉ một Có 2 cách mà điều này có khả năng tương cường cơ hội tìm kiếmgiải pháp tốt Đầu tiên, khi chúng ta có 1 tập hợp, chúng ta có thể dành thời gian 1cách hiệu quả để tìm kiếm trong nhiều khu vực lân cận khác nhau như một Thuật toándựa trên tập hợp có xu hướng chia sẻ effort tính toán đến các giải pháp ứng viên khácnhau trong 1 cách thiên vị bởi “tương quan vừa đủ” (relative fitness) của chúng Đó là,nhiều thời gian sẽ được dùng để tìm kiếm các vùng lân cận của các giải pháp tốt hơn làcác giải pháp trung bình
Tuy nhiên, tối thiểu cần một ít thời gian cho việc tìm kiếm trong những miềnnghiệm ôn hòa hoặc thô, nên điều này dẫn đến việc tìm kiếm một đột biến đặc biệt tốttrên đường đi, sau đó các cân bằng tải của nỗ lực tính toán sẽ được sửa đổi cho phùhợp
Trang 14Một hướng tiếp cận khác được cung cấp bởi kỹ thuật dựa trên tổ hợp là chúng tathử sử dụng toán tử tái tổ hợp Đây là cách để tạo ra những đột biến, nhưng lần này từ
2 hoặc nhiều các nghiệm cha chứ không phải chỉ 1 Do đó kết quả được gọi là một tổhợp chứ không phải là một đột biến Tái tổ hợp cung cấp một cách có nguyên tắctưởng đối để giải thích sự dịch chuyển của một vùng lân cận lớn Một trong những khókhăn của tìm kiếm cục bộ là ngay cả các kỹ thuật tiên tiến như mô phỏng và tìm kiếmcũng khó khăn để tối ưu cục bộ, nó chỉ “thoát” trừ khi nó có thể là một đột biến kháquyết liệt Đó là thuật toán có thể thử tất cả các chuyển động cục bộ có thể, và do đóphải bắt đầu thử với các di chuyển phi cục bộ nếu nó có bất kỳ cơ hội nào để đạt đượcbất kỳ nơi nào Vấn đề thực tế ở đây là có rất nhiều khả năng di chuyển phi cục bộ.Thật vậy các hàng xóm ”phi cục bộ” là toàn bộ không gian khả năng!
Tái tổ hợp là một phương pháp cung cấp một cách lựa chọn di chuyển phi cục bộtốt từ một không gian lớn các khả năng Ví dụ, nếu 2 nghiệm cha là mỗi vécto của kphần tử, một toán tử tái tổ hợp được gọi là giao đơn điệu (uniform crossover), sẽ tạo ramột nghiệm con từ 2 nghiệm cha này bằng cách, với mỗi phần tử được trả ra lấy ngẫunhiên giá trị của nó tử một trong 2 điểm Mỗi nghiệm con có thể khác biệt tới 50% cha
mẹ của nó, và lớn hơn rất nhiều so với sự khác biệt điển hình giữa một nghiệm chađơn với một vài hàng xóm cục bộ của nó
Dưới đây là những bước cho một thuật toán dựa trên tổ hợp chung:
1 Bắt đầu: sinh ra một tập ban đâu các giải pháp có khả năng nhất (candidate).Đánh giá chúng
2 Lựa chọn một vài tập làm cha
3 Áp dụng toán tử tái tổ hợp và đột biến để từ các bộ cha mẹ tạo ra các bộ con
4 Kết hợp các bộ con được sinh ra vào tập hợp
5 Cho đến khi đạt được tiêu chí kết thúc, thì quay trở lại bước 2
Có rất nhiều cách để thực hiện ở mỗi bước, nhưng có những điểm quan trọng nhưsau Bước 2 thường sử dụng chiến lược chọn lọc tự nhiên (survival of the fittest), đây
là nơi mà các tải chia sẻ (load sharing) được thảo luận ở trên sẽ được áp dụng Cácnghiệm ứng viên được tạo thành, càng nhiều cơ hội nó trở thành cha, và do đó cónhiều cơ hội hơn để thuật toán tìm ra các vùng lân cận của nó Có những kỹ thuật chọnlựa khác nhau, hầu hết đều được tham số hóa để thay đổi mức độ để các tổ hợp cha
Trang 15được tạo ra ưa thích hơn (các áp lực chọn lọc) Bước 3 áp dụng các toán tử tái tổ hợphoặc đột biến, hoặc cả hai Đây có tất cả các toán tử tái tổ hợp và đột biến, nhưng nhưchung tôi gợi ý trên, những lợi ích thực sự đến khi một vài suy nghĩ đã được đưa vàothiết kế cụ thể các loại toán tử sử dụng miền tri thức Trong bước 4, nhớ rằng chúng taluôn duy trì một kích thước tổ hợp cố định Vì vậy, nếu chúng ta có một tổ hợp 100,nhưng 20 phần tử con được thêm vào, thì 20 của 120 phần tử phải được loại bỏ Mộtcách tiếp cận phổ biến nhất là chỉ đơn giản loại bò 20 phần tử ít phù hợp nhất với cácnhóm kết hợp, nhưng có một vài phương pháp khác; chúng ta có thể sử dụng côngnghệ được gọi là “dồn nén” (crowding), eg De Jonh (1975), trong đó đa dạng đóng vaitrò quyết đinh về những giải pháp ứng viên để loại bỏ Ví dụ, chúng ta chắc chắn sẽthích để loại bỏ giải pháp S có lợi và một giải pháp t ít phù hợp, nếu điều đó xảy ra làtrường hợp đó là một bản sao trong dân số, nhưng t là “mới”.
Ví dụ, chúng tôi chắc chắn sẽ thích để loại bỏ giải pháp tội ủng hộ một giải pháp t
ít phù hợp, nếu điều đó xảy ra là trường hợp đó salready có một bản sao trong dân số ,nhưng tis 'mới' Cuối cùng, chúng ta phải chỉ ra một số vấn đề thuật ngữ Có rất nhiềuthuật toán dựa trên dân số , và trong thực tế, họ thường được gọi là thuật toán tiến hóa( địa bàn ) Một thuật ngữ phổ biến được sử dụng là thuật toán di truyền , mà đúng đềcập đến một gia đình của các phương pháp như vậy mà luôn luôn sử dụng một nhàđiều hành tái tổ hợp (Hà Lan , 1965; Goldberg , 1989) , trong khi các gia đình kháccủa thuật toán như vậy, gọi là lập trình tiến hóa ( Fogel , 1995) và tiến hóa chiến lược (trở lại, 1996), xu hướng sử dụng đột biến một mình, nhưng khá thông minh về cách họ
sử dụng nó Trong mọi trường hợp , một giải pháp ứng cử viên có xu hướng được gọi
là một phần tử của nó chromosomeand được gọi là gen
1.4 Kỹ thuật tính toán thích nghi
Để giải quyết nhu cầu tối ưu trong môi trường viễn thông luôn luôn thay đổi, sửdụng trực tiếp các kỹ thuật tối ưu cục bộ (local optimization) hoặc tối ưu quần thể chokết quả không phù hợp Lý do là nó mất nhiều thời gian để hội tụ về một solution tốt,
vì thế thời điểm mà nó đưa ra solution thì bài toán đã thay đổi
Cái chúng ta cần là một cách đưa ra các decision nhanh và tốt VD, để xác địnhxem “bước kế tiếp”(next hop) cho một gói tin từ node a (đích đến là node d ), chúng ta
Trang 16có thể chạy mô phỏng mô hình giao thông mạng (network traffic model) ở thời điểmhiện tại và ước lượng gần đúng thời điểm đến node d với các “bước kế tiếp” hiện tạicủa node a Tuy nhiên, vì thời gian để có thể dựng mô phỏng với phần cứng của bộchuyển mạch mạng (network switch) lên đến nhiều giờ nên ý tưởng chạy mô hình môphỏng không phù hợp.
Thay vào đó, chúng ta cần một cách khác Lý tưởng nhất, chúng ta đang tìm một
“hộp đen” (black box), đầu vào là question và các điều kiện hiện tại còn đầu ra làanswer hợp lý và ngay lập tức VD về “hộp đen”: Bảng định tuyến (Routing table).Question được hỏi bởi gói tin là: “Tôi muốn đi đến node d, vậy bước tiếp theo tôi nên
đi như thế nào?” Routing table đưa ra một cách nhanh chóng câu trả lời nhanh chóng
và gửi gói tin đi Cách làm này về cơ bản là không linh hoạt (non-adaptive) Nếu một
số giao thức quản lý mạng tiên tiến (advanced network management protocols) khônghoạt động, routing table luôn đưa ra cùng 1 answer, thậm chí ngay cả khi đường đi đến
d mà nó suggest đang bị tắc nghẽn ở thời điểm hiện tại Vì thế, hộp đen của chúng taphải có khả năng thay đổi để thích hợp với điều kiện hiện tại Chương 8 và chương 9
sẽ thảo luận về cách để thực thi vấn đề này liên quan đến routing table trong mạngchuyển mạch gói
Đây là sự ước lượng về thần kinh, logic mờ và lý thuyết trò chơi Vai trò củaước lượng thần kinh trong hoàn cảnh này là phát triển một mô hình ẩn, mô hình đónghiên cứu ( từ ví dụ) để làm thế nào có quyết định đúng đắn trong tập các trường hợpkhác nhau Kết quả tạo ra sẽ như một mạng lưới thần kinh, sau đó để làm việc trựctuyến như thế nào thì nhà sản xuất sẽ quyết định Vai trò của logic mờ là đưa ra cách
để tạo ra các quy định vững chắc, đây là những quy định để ra quyết định Điều này về
cơ bản là tạo ra cách giải quyết của hộp đen, giống như một mạng lưới thần kinhnhưng với hoạt động bên trong khác nhau Cuối cùng lý thuyết trò chơi sẽ đưa ra mộtcách nhìn khác, đó là một kịch bản mạng năng động Về cơ bản, nếu chúng ta xem một số khía cạnh của quản lý mạng như là một 'trò chơi', một tập hợp các phương trình và các môhình được biết đến bắt đầu hoạt động, nó sẽ lần lượt cung cấp những phép tính gầnđúng của mạng năng động thực sự
1.4.1 Tính toán hệ thần kinh
Trang 17Viễn thông là một lĩnh vực quan trọng và đang phát triển Không chỉ vậy, nó còncung cấp các dịch vụ cho những lĩnh vực khác nhau của đời sống con người Hơn nữahiện nay tồn tại nhu cầu đối với tập các dịch vụ viễn thông ngày càng mở rộng cùngvới băng thông ngày càng gia tăng Một công nghệ cụ thể có khả năng cung cấp băngthông lớn nếu các dịch vụ viễn thông băng thông rộng như trên được áp dụng rộng rãi
đó là các mạng truyền dẫn quang đa bước sóng (Mukherjee, 1977) Tuy nhiên, sự pháttriển của mạng như vậy mang đến cho các nhà khoa học và các kỹ sư hàng loạt nhữngkhó khăn trong bài toán thiết kế và tối ưu
1.4.2 Logic mờ
Trong một số trường hợp chúng ta có thể nghĩ về các quy tắc hợp lệ cho miền giátrị của vấn đề Ví dụ, “nếu lưu lượng đông đúc, sử dụng node a’ và ‘nếu lưu lượng rấtđông đúc, sử dụng node b’ Tuy nhiên, những quy luật như vậy không thực sự hữu íchnếu không có một cách tốt để quyết định rằng “đông đúc” hay “rất đông đúc” thực sự
có ý nghĩa gì Trong cách tiếp cận hệ thống chuyên gia cổ điển, chúng ta sẽ áp dụngngưỡng được xác định trước cho những cái gọi là “biến ngôn ngữ”, và quyết định, ví
dụ, “lưu lượng đông đúc” có nghĩa là việc sử dụng liên kết trong câu hỏi là giữa 70%
và 85% Điều này có vẻ tốt, nhưng không khó để thấy rằng việc sử dụng 69.5% có thể
là nguyên nhân gây ra các vấn đề; trong một kịch bản như vậy, quy luật có điều kiện là
“lưu lượng trung bình” (có thể là từ 55% đến 70%) sẽ được sử dụng, nhưng nó có thểthích hợp hơn, và mang lại một kết quả tốt hơn là sử dụng “lưu lượng đông đúc”
Logic mờ cung cấp một cách để sử dụng các biến ngôn ngữ để giải quyết vấn đềngưỡng một cách rất tự nhiên và mạnh mẽ Thực tế, nó gần như loại bỏ nhu cầungưỡng, thay vì giới thiệu những thứ gọi là “các chức năng thành viên” Chúng takhông còn có lưu lượng đông đúc hay trung bình Thay vào đó, một giá trị lưu lượngnhất định cho lưu lượng ở mức đông đúc và một giá trị cho mức độ trung bình Cácmức độ phụ thuộc vào các giá trị số thực tế bằng cách các chức năng thành phần,thường đơn giản là “chức năng hình tam giác” Ví dụ, mức độ lưu lượng nặng có thể là
0 giữa 0% và 35% sử dụng, sau đó nó có thể tăng lên 1 giữa 35% và 75%, và sau đólại giảm xuống 0 giữa 75% và 90% Chức năng thành phần (membership function) cho
Trang 18biến ngôn ngữ “rất nặng” sẽ chồng chéo nhau với điều này, bởi vậy một giá trị lưulượng 82.5% có thể là ‘nặng’ đến mức 0.5 và ‘rất nặng’ đến mức 0.7.
Với mỗi điều kiện môi trường nhất định, các quy tắc khác nhau sẽ áp dụng nhữngmức độ khác nhau Đặc biệt, logic mờ cung cấp nhiều cách để xác định mức độ mà cácquy luật khác nhau được áp dụng khi các thành phần điều kiện trong quy luật liên quanđến nhiều biến ngôn ngữ Chương 8 sử dụng logic mờ, sẽ thảo luận chi tiết hơn về vấn
đề này
Sức mạnh chính của logic mờ là chúng ta chỉ cần đảm bảo rằng các chức năngthành phần là hợp lý Hệ thống kết quả, với các quyết định phù hợp, hướng tới cácbiến thể trong các chức năng thành phần, trong giới hạn hợp lý Tuy nhiên chúng ta cóthể phải làm một số việc, là xây dựng các nguyên tắc hoạt động Đây là nơi việc học
‘offline’ đưa ra trong khi chúng ta đang sử dụng logic mờ trong một môi trường thíchnghi Đôi khi, các thuật toán di truyền có thể được sử dụng cho nhiệm vụ xây dựngmột tập các quy luật tốt
1.4.3 Lý thuyết trò chơi
Cuối cùng, lý thuyết trò chơi cung cấp một cách khác để nhìn vào các vấn đề phứctạp, dynamic và liên quan đến giao tiếp, đặc biệt là liên quan đến quản lý mạng vàcung cấp dịch vụ Xem xét các quá trình ra quyết định phức tạp liên quan trong việcquyết định những gì để thiết lập cho lời gọi kết nối hoặc cung cấp dịch vụ dữ liệutrong một môi trường mạng động, liên quan đến cạnh tranh với nhiều nhà cung cấpdịch vụ khác
1.5 Tổng kết
Phương pháp Heuristic và các kĩ thuật thích hợp được ứng dụng trong rất nhiềutrong viễn thông liên quan tới việc tối ưu Nó được chia làm 3 phần chính , tươngđương với 3 vấn đề thường gặp Thứ nhất, đó là vấn đề thiết kế và tổ chức mạng.Trong thực tế, có rất nhiều hoạt động sử dụng kĩ thuật Heuristic hiện đại, việc thiết kếmạng sẽ đơn giản với các vấn đề tối ưu do các vấn đề này đã được xác định rõrang.Điều đó có nghĩa là Chúng ta có thể tiết kiệm nhiều thời gian và công sức để phát
Trang 19triển 1 kĩ thuật tối ưu tốt nhờ sử dụng các thuật toán và cơ chế đặc tả Khi một giảipháp được thiết kế, nó có thể được thực hiện cài đặt trong vài tuần hoặc vài tháng Ngược lại, với vấn đề định tuyến và sử dụng giao thức được nói đến trong phần 2,bao gồm các kĩ thuật tối ưu động gồm 2 vấn đề liên quan đến tối ưu thời gian tiêuthụ.vấn đề chính ở phần này là tập trung vào các phương thức để thực thi và tích hợp
mô hình “hộp đen” Trong một trường hợp , hộp đen là mạng tự nhiên , trường hợpkhác, nó là tập luật logic mờ hay 1 form được đặc tả trong bảng định tuyến
Phần 3 xem xét phạm vi vấn đề, bao gồm phần mềm, chiến thuật, phương thứcquản lý lưu lượng Phát triển phần mềm cũng có nhiều vấn đề trong lĩnh vực viễnthông tuy nhiên nó cũng cung cấp nhiều giải pháp hợp lý trong việc cung cấp dịch vụ.Các vấn đề cung cấp dịch vụ, trang bị trong mạng, đều cần tới những ưu điểm và tínhlinh động của các phần mềm Tuy nhiên các phần mềm cần nhiều thời gian để pháttriển Phần 3 cũng chỉ ra tầm quan trọng của “chiến lược” bang cách xem xét các vấn
đề của việc quản lý 1 mạng động phức tạp Các vấn đề bao gồm cấp phát dịch vụ ,quản trị luồng dữ liệu Trong mỗi trường hợp , một cách tiếp cận dựa vào lý thuyếtgame được tích hợp Cuối cùng, ở phần 3 cũng chỉ ra vẫn đề quản lý băng thông trong
cả mạng cố định và mạng di động
Chính vì vậy, chúng tôi đã bao quát một phạm vi rộng của các vấn đề tối ưu mạngviễn thông trong quyển sách này Chúng tôi đã trình bày một tập các vấn đề cần đượchoàn thiện Các vấn đề tương tự trong việc kết nối các kĩ thuật lại cũng được nhắc đến.Việc phát triển các kĩ thuật tính toán đã được tích hợp và cài đặt nhanh chóng tronglĩnh vực viễn thông
Trang 20CHƯƠNG 6: LẬP TRÌNH DI TRUYỀN MÃ HÓA CẶP NÚT CHO THIẾT KẾ MẠNG MẮT LƯỚI QUANG6.1 Giới thiệu
Viễn thông là một lĩnh vực quan trọng và đang phát triển Không chỉ vậy, nó còncung cấp các dịch vụ cho những lĩnh vực khác nhau của đời sống con người Hơn nữahiện nay tồn tại nhu cầu đối với tập các dịch vụ viễn thông ngày càng mở rộng cùngvới băng thông ngày càng gia tăng Một công nghệ cụ thể có khả năng cung cấp băngthông lớn nếu các dịch vụ viễn thông băng thông rộng như trên được áp dụng rộng rãi
đó là các mạng truyền dẫn quang đa bước sóng (Mukherjee, 1977) Tuy nhiên, sự pháttriển của mạng như vậy mang đến cho các nhà khoa học và các kỹ sư hàng loạt nhữngkhó khăn trong bài toán thiết kế và tối ưu
Một trong những khó khăn đó là việc thiết kế topo mạng mắt lưới Trong trườnghợp tổng quát, công việc này bắt đầu bằng một tập các vị trí các nút, ma trận lưu thông
và xác định các cặp nút nào được kết nối trực tiếp với nhau bởi một liên kết Việc thiết
kế được thực hiện nhờ có hàm mục tiêu dựa trên chi phí cho phép đánh giá một mạngứng cử phù hợp nhất Vấn đề cụ thể hơn khi thiết kế topo cho mạng truyền tải toànquang đa bước sóng là các nút có thể kết nối chéo được với nhau sử dụng các sợiquang liên kết và truyền dẫn tĩnh Các thuật toán định chiều và định tuyến phải đượclựa chọn, với chi phí tổn thất đầy đủ cho các đường khôi phục để đảm bảo cho mạngvẫn tồn tại trong trường hợp một phần tử của mạng (một nút hoặc một liên kết) gặp lỗi.Trong một công trình của mình, Sinclair (1995, 1997) đã áp dụng thuật toán ditruyền chuỗi bit ở dạng đơn giản, thuật toán lai di truyền, cùng với 3 cách tiếp cậnkhác nhau về lập trình di truyền của Aiyarak và Saket (1997) cho vấn đề này Trongchương này một cách tiếp cận mới sử dụng lập trình di truyền lấy ý tưởng từ mã hóacạnh (Luke và Spector, 1996) được miêu tả (một bản ngắn gọn của chương này đãđược công bố tại GECCO’99 (Sinclair,1999)) Người ta hy vọng rằng cách tiếp cậnnày sẽ cung cấp những kết quả tốt hơn cách tiếp cận trước đó về lập trình di truyền và
có thể có tính cạnh tranh hơn so với thuật toán di truyền tốt nhất trước đó Nghiên cứuhiện nay của tác giả về lược đồ mã hóa lập trình di truyền cho topo mạng mắt lưới là