Thành viên:Cheminiwawaky/Lập trình di truyền
Trong trí tuệ nhân tạo, lập trình di truyền (genetic programming, GP) là một kỹ thuật tiến hóa các chương trình mà ban đầu chưa thích nghi (thường là chương trình ngẫu nhiên), cho đến khi thích nghi được với một nhiệm vụ cụ thể bằng cách áp dụng các quá trình tương tự như các quá trình di truyền tự nhiên cho quần thể của các chương trình. Về cơ bản, nó là một kỹ thuật tìm kiếm heuristic thường được mô tả là 'leo đồi' [cần dẫn nguồn], tức là tìm kiếm một chương trình tối ưu hoặc ít nhất là phù hợp trong không gian chứa tất cả chương trình.
Các quá trình thực hiện bao gồm: chọn lọc các chương trình tốt nhất để sinh sản (trao đổi chéo) và đột biến dựa trên một thang đo độ thích nghi được định nghĩa trước, thường là trình độ thực hiện đối với nhiệm vụ mong muốn. Quá trình trao đổi chéo bao gồm việc hoán đổi các bộ phận ngẫu nhiên của các cặp được chọn (cặp bố mẹ) để tạo ra các thế hệ con mới và khác biệt trở thành một phần của thế hệ chương trình mới. Đột biến là sự thay thế một bộ phận ngẫu nhiên của chương trình bằng một bộ phận ngẫu nhiên khác. Một số chương trình không được chọn để tái tạo được sao chép từ thế hệ hiện tại sang thế hệ mới. Sau đó, quá trình chọn lọc và các quá trình khác được áp dụng đệ quy cho thế hệ chương trình mới.
Thông thường, các cá thể của mỗi thế hệ mới trên trung bình thường tốt hơn các cá thể của thế hệ trước đó và chương trình tốt nhất thế hệ cũng thường tốt hơn các chương trình tốt nhất thế hệ của các thế hệ trước. Vòng lặp đệ quy được kết thúc khi xuất hiện cá thể chương trình nào đó đạt đến mức độ thành thạo hoặc độ thích nghi được định trước.
Mỗi lần chạy thuật toán có thể và thường xuyên xảy ra sự hội tụ sớm đến điểm cực đại cục bộ nào đó mà không phải là điểm tối ưu toàn cục hoặc thậm chí không phải là nghiệm tốt. Để có được một kết quả rất tốt thường đòi hỏi rất nhiều lần chạy (từ hàng chục tới hàng trăm lần). Ngoài ra, có thể phải tăng kích thước quần thể ban đầu và sự biến đổi của các cá thể để tránh nhiễm gen xấu.
Lịch sử
[sửa | sửa mã nguồn]Đề xuất tiến hóa các chương trình đầu tiên trong lịch sử có lẽ là của Alan Turing vào năm 1950. [1] Phải tới 25 năm sau, sự xuất bản cuốn sách 'Sự thích nghi trong các hệ thống tự nhiên và nhân tạo' của John Holland mới đặt ra những nền móng lý thuyết và thực nghiệm của ngành khoa học này. Năm 1981, Richard Forsyth đã chứng minh sự tiến hóa thành công của các chương trình nhỏ, được biểu diễn dưới dạng cây, để thực hiện phân loại bằng chứng hiện trường vụ án cho Bộ Nội vụ Vương quốc Anh. [2]
Mặc dù ý tưởng về các chương trình tự tiến hóa, ban đầu được viết bằng ngôn ngữ máy tính Lisp, đã nảy ra giữa các sinh viên của John Holland, [3] phải đến khi họ tổ chức hội nghị Giải thuật di truyền (GA) đầu tiên ở Pittsburgh, Nichael Cramer [4] mới công bố các chương trình tiến hóa trong hai ngôn ngữ được thiết kế đặc biệt, bao gồm phát biểu đầu tiên của Lập trình di truyền "dựa trên cây" hiện đại (nghĩa là các ngôn ngữ thủ tục được tổ chức theo cấu trúc cây và được vận hành bởi các toán tử GA được định nghĩa phù hợp). Năm 1988, John Koza (cũng là một nghiên cứu sinh của John Holland) đã được cấp bằng sáng chế cho phát minh GA cho sự tiến hóa chương trình. [5] Tiếp theo là công bố trong Hội nghị chung quốc tế về trí tuệ nhân tạo IJCAI-89. [6]
Koza tiếp nối điều này với 205 ấn phẩm về “Lập trình di truyền” (GP), tên được đặt ra bởi David Goldberg, cũng là một nghiên cứu sinh của John Holland. [7] Tuy nhiên, chính loạt 4 cuốn sách của Koza, bắt đầu từ năm 1992 [8] với các video đi kèm, [9] mới thực sự thành lập GP. Sau đó, đã có sự mở rộng đáng kể về số lượng xuất bản với chỉ mục lập trình di truyền, vượt qua 10.000 mục nhập. [10] Năm 2010, Koza [11] liệt kê 77 kết quả trong đó Lập trình di truyền có khả năng cạnh tranh với con người.
Năm 1996, Koza bắt đầu hội nghị Lập trình di truyền hàng năm [12], sau đó là hội nghị EuroGP hàng năm vào năm 1998, [13] và cuốn sách đầu tiên [14] trong loạt bài GP do Koza biên tập. Năm 1998 cũng chứng kiến sách giáo khoa GP đầu tiên. [15] GP tiếp tục phát triển mạnh mẽ, dẫn đến việc xuất bản tạp chí GP chuyên khoa đầu tiên [16] và ba năm sau (2003) hội thảo thường niên về Lý thuyết và Thực hành Lập trình Di truyền (GPTP) được thành lập bởi Rick Riolo. [17] [18] Các bài báo về Lập trình di truyền tiếp tục được xuất bản tại nhiều hội nghị và tạp chí liên quan. Ngày nay có mười chín cuốn sách GP trong đó có một số cuốn dành cho học sinh.
Công trình nền tảng trong GP
[sửa | sửa mã nguồn]Những công trình đầu tiên tạo tiền đề cho các chủ đề nghiên cứu lập trình di truyền và ứng dụng hiện nay rất đa dạng, bao gồm tổng hợp và sửa chữa phần mềm, mô hình dự đoán, khai thác dữ liệu, [19] mô hình tài chính, [20] cảm biến mềm, [21] thiết kế, [22] và xử lý hình ảnh. [23] Các ứng dụng trong một số lĩnh vực, chẳng hạn như thiết kế, thường sử dụng các biểu diễn trung gian, [24] chẳng hạn như mã hóa tế bào của Fred Gruau. [25] Sự tiếp nhận công nghiệp đã trở nên đáng kể trong một số lĩnh vực bao gồm tài chính, công nghiệp hóa chất, tin sinh học [26] [27] và công nghiệp thép. [28]
Phương pháp
[sửa | sửa mã nguồn]Biểu diễn chương trình
[sửa | sửa mã nguồn]Theo truyền thống, các chương trình tiến hóa bằng GP được biểu diễn trong bộ nhớ dưới dạng cấu trúc cây . [29] Cấu trúc cây có thể được định lượng dễ dàng một cách đệ quy. Mọi nút cây đều có một hàm toán tử và mọi nút đầu cuối đều có một toán hạng, làm cho việc tiến hóa và định lượng các biểu thức toán học trở nên dễ dàng. Vì vậy, theo truyền thống GP ủng hộ việc sử dụng các ngôn ngữ lập trình có cấu trúc cây một cách tự nhiên (ví dụ: Lisp ; các ngôn ngữ lập trình chức năng khác cũng phù hợp).
Các biểu diễn không phải cây đã được đề xuất và thực hiện thành công, chẳng hạn như lập trình di truyền tuyến tính phù hợp với các ngôn ngữ mệnh lệnh vốn truyền thống hơn [ví dụ, xem Banzhaf et al. (1998)]. [30] Phần mềm GP thương mại Discipulus sử dụng mã máy nhị phân đệ quy tự động ("AIM") [31] để đạt được hiệu suất tốt hơn. µGP [32] sử dụng đa đồ thị có hướng để tạo ra các chương trình khai thác triệt để cú pháp của một hợp ngữ nhất định. Các biểu diễn chương trình khác mà các công trình nghiên cứu và phát triển quan trọng đã thực hiện bao gồm các chương trình cho máy ảo dựa trên ngăn xếp, [33] [34] [35] và chuỗi các số nguyên được ánh xạ tới các ngôn ngữ lập trình tùy ý thông qua ngữ pháp. [36] [37] Lập trình di truyền Descartes là một dạng khác của GP sử dụng biểu diễn đồ thị thay vì biểu diễn dựa trên cây thông thường để mã hóa các chương trình máy tính.
Hầu hết các biểu diễn chứa phần mã vô hiệu về mặt cấu trúc (intron). Các gen không mã hóa như vậy có vẻ vô dụng vì chúng không ảnh hưởng đến hoạt động của bất kỳ cá thể nào. Tuy vậy, chúng thay đổi xác suất tạo ra các con khác nhau dưới các toán tử biến dị, và do đó làm thay đổi các thuộc tính biến dị của cá thể. Các thí nghiệm dường như cho thấy sự hội tụ nhanh hơn khi sử dụng các biểu diễn chương trình cho phép các gen không mã hóa so với các biểu diễn chương trình không có bất kỳ gen không mã hóa nào. [38] [39]
Chọn lọc
[sửa | sửa mã nguồn]Chọn lọc là một quá trình theo đó những cá nhân nhất định được chọn từ thế hệ hiện tại sẽ đóng vai trò là cha mẹ cho thế hệ tiếp theo. Các cá nhân được chọn theo xác suất để những cá nhân có thành tích tốt hơn có cơ hội được chọn cao hơn. [18] Phương pháp chọn lọc phổ biến nhất được sử dụng trong GP là chọn lọc giải đấu, mặc dù các phương pháp khác như chọn lọc thích nghi tỉ lệ, chọn lọc lexicase, [40] và các phương pháp khác đã được chứng minh là hoạt động tốt hơn đối với nhiều vấn đề về GP.
Chọn lọc tinh hoa, hay gieo mầm cho thế hệ tiếp theo với cá thể tốt nhất (hoặc n cá thể tốt nhất) từ thế hệ hiện tại, là một kỹ thuật đôi khi được sử dụng để tránh thoái triển.
Trao đổi chéo
[sửa | sửa mã nguồn]Trong Lập trình di truyền, hai cá thể phù hợp được chọn từ quần thể để làm bố mẹ cho một hoặc hai con. Trong lập trình di truyền cây, những bậc cha mẹ này được biểu diễn dưới dạng cây treo ngược, với các nút gốc ở trên cùng. Trong trao đổi chéo cây con, ở mỗi cá thể cha mẹ, một cây con (subtree) được chọn ngẫu nhiên. (Được đánh dấu bằng màu vàng trong hoạt hình.) Bên trong cá thể cha mẹ hiến gốc (trong hoạt hình bên trái), cây con đã chọn sẽ bị xóa và được thay thế bằng một bản sao của cây con được chọn ngẫu nhiên từ cá thể cha mẹ còn lại, để tạo ra một cá thể con mới (child tree).
Đôi khi trao đổi chéo hai con được sử dụng, trong trường hợp đó, cây con đã bị xóa (trong hoạt hình bên trái) không chỉ bị xóa mà được sao chép vào bản sao của cá thể cha mẹ thứ hai (ở đây bên phải) thay thế (trong bản sao) cây con đã được chọn ngẫu nhiên trước đó. Do đó, kiểu trao đổi chéo cây con này lấy hai cá thể thích nghi và tạo ra hai cá thể con.
Đột biến
[sửa | sửa mã nguồn]Có nhiều dạng đột biến trong lập trình di truyền. Chúng đều xuất phát từ một cá thể cha mẹ thích nghi và đúng về mặt cú pháp và nhắm đến mục tiêu tạo ra một cá thể con ngẫu nhiên đúng về mặt cú pháp. Trong hoạt ảnh, một cây con được chọn ngẫu nhiên (được đánh dấu bằng màu vàng). Nó bị loại bỏ và thay thế bằng một cây con được tạo ngẫu nhiên.
Các phép đột biến khác chọn một lá (nút bên ngoài) của cây và thay thế nó bằng một lá được chọn ngẫu nhiên. Một phép đột biến khác nữa là chọn ngẫu nhiên một hàm (nút bên trong) và thay thế nó bằng một hàm khác có cùng arity (số đối số). Phép đột biến dịch lên chọn ngẫu nhiên một cây con và thay thế nó bằng một cây con bên trong chính nó. Do đó đột biến dịch lên bảo đảm con có kích thước nhỏ hơn. Phép thay thế lá và thay thế hàm cùng số đối số đảm bảo con có cùng kích thước với cha mẹ. Trong khi đó, đột biến cây con (trong hoạt hình) có thể, tùy thuộc vào tập hợp các hàm và đầu cuối, có xu hướng làm tăng hoặc giảm kích thước cây. Các đột biến dựa trên cây con khác cố gắng kiểm soát cẩn thận kích thước của cây con thay thế và do đó kích thước của cá thể con
Tương tự, có nhiều dạng đột biến lập trình di truyền tuyến tính, mỗi dạng đều cố gắng đảm bảo cá thể con bị đột biến vẫn đúng về mặt cú pháp.
Các ứng dụng
[sửa | sửa mã nguồn]GP đã được sử dụng thành công như một công cụ lập trình tự động, một công cụ học máy và một công cụ giải quyết vấn đề tự động. [18] GP đặc biệt hữu ích trong các lĩnh vực mà lời giải chính xác không được biết trước hoặc một lời giải gần đúng có thể chấp nhận được (có thể vì việc tìm ra lời giải chính xác là rất khó khăn). Một số ứng dụng của GP là khớp đường cong, mô hình hóa dữ liệu, hồi quy ký hiệu, chọn lọc đặc trưng, phân loại, v.v. John R. Koza đề cập đến 76 trường hợp mà Lập trình di truyền có thể tạo ra kết quả cạnh tranh với kết quả do con người tạo ra (được gọi là kết quả cạnh tranh với con người). [41] Kể từ năm 2004, Hội nghị Tính toán di truyền và tiến hóa (GECCO) hàng năm tổ chức cuộc thi Giải thưởng cạnh tranh với con người (còn gọi là Humies), [42] nơi các giải thưởng tiền mặt được trao cho các kết quả cạnh tranh được với con người bằng bất kỳ hình thức tính toán di truyền và tiến hóa nào. GP đã giành được nhiều giải thưởng ở cuộc thi này trong những năm qua.
Lập trình siêu di truyền
[sửa | sửa mã nguồn]Lập trình siêu di truyền (Meta-genetic programing, Meta-GP) là kỹ thuật siêu học được đề xuất để phát triển một hệ thống lập trình di truyền bằng cách sử dụng chính lập trình di truyền. Nó đề xuất rằng nhiễm sắc thể, quá trình trao đổi chéo và đột biến đều là kết quả của sự tiến hóa, do đó, chúng nên được phép tự thay đổi như những phiên bản ngoài đời thực thay vì được xác định bởi một lập trình viên. Meta-GP được Jürgen Schmidhuber chính thức đề xuất vào năm 1987. [43] Kĩ thuật này có thể tương đồng với công trình Eurisko trước đó của Doug Lenat. Nó là một thuật toán đệ quy tự dừng, cho phép tránh rơi vào đệ quy vô hạn. Trong phương pháp tiếp cận "tiến hóa tự xây dựng" đối với lập trình siêu di truyền, các phương pháp sinh sản và biến dị con cái được mã hóa trong chính các chương trình đang tiến hóa, và các chương trình được thực hiện để tạo ra các chương trình mới được thêm vào quần thể. [34] [44]
Những người chỉ trích ý tưởng này thường nói rằng cách tiếp cận này có phạm vi quá rộng. Tuy nhiên, có thể giới hạn tiêu chí thích nghi thành một tiêu chí chung để thu được một GP tốt hơn để tiến hóa cho các lớp con. Chẳng hạn như meta-GP tiến hóa để tạo ra các thuật toán đi bộ của con người, sau đó được sử dụng để tiến hóa hoạt động chạy, nhảy của con người, v.v. Tiêu chí thích nghi áp dụng cho meta GP này sẽ chỉ đơn giản là một giá trị hiệu suất.
Xem thêm
[sửa | sửa mã nguồn]- Máy tính lấy cảm hứng từ sinh học
- Chiến lược tiến hóa ma trận hiệp phương sai thích nghi (CMA-ES)
- Xấp xỉ hàm mục tiêu
- Lập trình biểu hiện gen
- Cải thiện di truyền
- Đại diện di truyền
- Sự tiến hóa ngữ pháp
- Lập trình quy nạp
- Lập trình di truyền tuyến tính
- Lập trình đa biểu thức
- Lan truyền sơ đồ
Tham khảo
[sửa | sửa mã nguồn]- ^ “Computing Machinery and Intelligence”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “BEAGLE A Darwinian Approach to Pattern Recognition”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ A personal communication with Tom Westerdale
- ^ “A representation for the Adaptive Generation of Simple Sequential Programs”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “Non-Linear Genetic Algorithms for Solving Problems”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “Hierarchical genetic algorithms operating on populations of computer programs”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ Goldberg. D.E. (1983), Computer-aided gas pipeline operation using genetic algorithms and rule learning. Dissertation presented to the University of Michigan at Ann Arbor, Michigan, in partial fulfillment of the requirements for Ph.D.
- ^ “Genetic Programming: On the Programming of Computers by Means of Natural Selection”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “Genetic Programming:The Movie”. gpbib.cs.ucl.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2021.
- ^ “The effects of recombination on phenotypic exploration and robustness in evolution”. gpbib.cs.ucl.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2021.
- ^ “Human-competitive results produced by genetic programming”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Genetic Programming 1996: Proceedings of the First Annual Conference”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “Genetic Programming”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 19 tháng 5 năm 2018.
- ^ “Genetic Programming and Data Structures: Genetic Programming + Data Structures = Automatic Programming!”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Genetic Programming -- An Introduction; On the Automatic Evolution of Computer Programs and its Applications”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ Banzhaf, Wolfgang (1 tháng 4 năm 2000). “Editorial Introduction”. Genetic Programming and Evolvable Machines (bằng tiếng Anh). 1 (1–2): 5–6. doi:10.1023/A:1010026829303. ISSN 1389-2576.
- ^ “Genetic Programming Theory and Practice”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ a b c “A Field Guide to Genetic Programming”. www.gp-field-guide.org.uk. Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Data Mining and Knowledge Discovery with Evolutionary Algorithms”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “EDDIE beats the bookies”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Applying Computational Intelligence How to Create Value”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Human-competitive machine invention by means of genetic programming”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Discovery of Human-Competitive Image Texture Feature Extraction Programs Using Genetic Programming”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Three Ways to Grow Designs: A Comparison of Embryogenies for an Evolutionary Design Problem”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Cellular encoding as a graph grammar - IET Conference Publication”. ieeexplore.ieee.org (bằng tiếng Anh). tháng 4 năm 1993. tr. 17/1–1710. Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Genetic Algorithm Decoding for the Interpretation of Infra-red Spectra in Analytical Biotechnology”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Genetic Programming for Mining DNA Chip data from Cancer Patients”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ “Genetic Programming and Jominy Test Modeling”. www.cs.bham.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2018.
- ^ Nichael L. Cramer "A Representation for the Adaptive Generation of Simple Sequential Programs" Lưu trữ 2005-12-04 tại Wayback Machine.
- ^ Garnett Wilson and Wolfgang Banzhaf. "A Comparison of Cartesian Genetic Programming and Linear Genetic Programming".
- ^ (Peter Nordin, 1997, Banzhaf et al., 1998, Section 11.6.2-11.6.3)
- ^ Giovanni Squillero. “µGP (MicroGP)”.
- ^ “Stack-Based Genetic Programming”. gpbib.cs.ucl.ac.uk (bằng tiếng Anh). Truy cập ngày 20 tháng 5 năm 2021.
- ^ a b Spector, Lee; Robinson, Alan (1 tháng 3 năm 2002). “Genetic Programming and Autoconstructive Evolution with the Push Programming Language”. Genetic Programming and Evolvable Machines (bằng tiếng Anh). 3 (1): 7–40. doi:10.1023/A:1014538503543. ISSN 1389-2576.
- ^ Spector, Lee; Klein, Jon; Keijzer, Maarten (25 tháng 6 năm 2005). The Push3 execution stack and the evolution of control. ACM. tr. 1689–1696. CiteSeerX 10.1.1.153.384. doi:10.1145/1068009.1068292. ISBN 978-1595930101.
- ^ Ryan, Conor; Collins, JJ; Neill, Michael O (1998). Lecture Notes in Computer Science. Berlin, Heidelberg: Springer Berlin Heidelberg. tr. 83–96. CiteSeerX 10.1.1.38.7697. doi:10.1007/bfb0055930. ISBN 9783540643609.
- ^ O'Neill, M.; Ryan, C. (2001). “Grammatical evolution”. IEEE Transactions on Evolutionary Computation (bằng tiếng Anh). 5 (4): 349–358. doi:10.1109/4235.942529. ISSN 1089-778X.
- ^ Julian F. Miller. "Cartesian Genetic Programming". p. 19.
- ^ Janet Clegg; James Alfred Walker; Julian Francis Miller. A New Crossover Technique for Cartesian Genetic Programming". 2007.
- ^ Spector, Lee (2012). Assessment of problem modality by differential performance of lexicase selection in genetic programming: a preliminary report. Proceedings of the 14th Annual Conference Companion on Genetic and Evolutionary Computation. Gecco '12 (bằng tiếng Anh). ACM. tr. 401–408. doi:10.1145/2330784.2330846. ISBN 9781450311786.
- ^ Koza, John R (2010). “Human-competitive results produced by genetic programming”. Genetic Programming and Evolvable Machines (bằng tiếng Anh). 11 (3–4): 251–284. doi:10.1007/s10710-010-9112-3.
- ^ “Humies =Human-Competitive Awards”.
- ^ “1987 THESIS ON LEARNING HOW TO LEARN, METALEARNING, META GENETIC PROGRAMMING,CREDIT-CONSERVING MACHINE LEARNING ECONOMY”.
- ^ GECCO '16 Companion : proceedings of the 2016 Genetic and Evolutionary Computation Conference : July 20-24, 2016, Denver, Colorado, USA. Neumann, Frank (Computer scientist), Association for Computing Machinery. SIGEVO. New York, New York. ISBN 9781450343237. OCLC 987011786.Quản lý CS1: khác (liên kết)
Liên kết ngoài
[sửa | sửa mã nguồn]- Aymen S Saket & Mark C Sinclair
- Lập trình di truyền và Máy có thể tiến hóa, một tạp chí
- Evo2 cho lập trình di truyền
- Thư mục GP
- Hướng dẫn về tính toán tiến hóa của Hitch-Hiker
- Riccardo Poli, William B. Langdon, Nicholas F. McPhee, John R. Koza, " Hướng dẫn thực địa về lập trình di truyền " (2008)
- Lập trình di truyền, một nguồn tài nguyên do cộng đồng duy trì
[[Thể loại:Thể loại:Giải thuật di truyền]] [[Thể loại:Trang có bản dịch chưa được xem lại]]