유전자형 표현
유전자 알고리즘을 구현하는 동안 내릴 가장 중요한 결정 중 하나는 솔루션을 나타내는 데 사용할 표현을 결정하는 것입니다. 부적절한 표현은 GA의 성능 저하로 이어질 수 있음이 관찰되었습니다.
따라서 적절한 표현을 선택하고 표현형과 유전자형 공간 간의 매핑에 대한 적절한 정의를 갖는 것은 GA의 성공에 필수적입니다.
이 섹션에서는 유전 알고리즘에 가장 일반적으로 사용되는 표현 중 일부를 제시합니다. 그러나 표현은 매우 문제에 따라 다르며 독자는 여기에 언급 된 다른 표현이나 표현의 혼합이 자신의 문제에 더 적합 할 수 있음을 알 수 있습니다.
이진 표현
이것은 GA에서 가장 간단하고 널리 사용되는 표현 중 하나입니다. 이 유형의 표현에서 유전자형은 비트 문자열로 구성됩니다.
솔루션 공간이 부울 의사 결정 변수 (예 또는 아니오)로 구성되는 일부 문제의 경우 이진 표현은 자연 스럽습니다. 예를 들어 0/1 배낭 문제를 생각해보십시오. n 개의 항목이있는 경우 n 개 요소의 이진 문자열로 솔루션을 나타낼 수 있습니다. 여기서 x 번째 요소는 항목 x가 선택되었는지 (1) 선택되지 않았는지 (0)를 알려줍니다.
다른 문제, 특히 숫자를 다루는 문제의 경우 이진 표현으로 숫자를 나타낼 수 있습니다. 이러한 종류의 인코딩의 문제점은 서로 다른 비트가 서로 다른 의미를 가지므로 변형 및 교차 연산자가 원하지 않는 결과를 초래할 수 있다는 것입니다. 이것은 다음을 사용하여 어느 정도 해결할 수 있습니다.Gray Coding, 한 비트의 변화가 솔루션에 큰 영향을 미치지 않기 때문입니다.
실제 가치 표현
이산 변수가 아닌 연속 변수를 사용하여 유전자를 정의하려는 문제의 경우 실제 가치 표현이 가장 자연 스럽습니다. 그러나 이러한 실수 또는 부동 소수점 숫자의 정밀도는 컴퓨터로 제한됩니다.
정수 표현
이산 값 유전자의 경우 솔루션 공간을 항상 이진 '예'또는 '아니오'로 제한 할 수는 없습니다. 예를 들어 북쪽, 남쪽, 동쪽 및 서쪽의 네 거리를 인코딩하려면 다음과 같이 인코딩 할 수 있습니다.{0,1,2,3}. 이러한 경우 정수 표현이 바람직합니다.
순열 표현
많은 문제에서 솔루션은 요소 순서로 표현됩니다. 이러한 경우 순열 표현이 가장 적합합니다.
이 표현의 전형적인 예는 TSP (traveling salesman problem)입니다. 여기에서 판매원은 모든 도시를 둘러보고 정확히 한 번 각 도시를 방문하고 시작 도시로 돌아와야합니다. 투어의 총 거리를 최소화해야합니다. 이 TSP에 대한 해결책은 자연스럽게 모든 도시의 순서 또는 순열이므로 순열 표현을 사용하는 것이이 문제에 적합합니다.