유전 알고리즘-기초

이 섹션에서는 GA를 이해하는 데 필요한 기본 용어를 소개합니다. 또한 GA의 일반적인 구조는pseudo-code and graphical forms. 독자는이 섹션에 소개 된 모든 개념을 올바르게 이해하고이 튜토리얼의 다른 섹션도 읽을 때이를 염두에 두는 것이 좋습니다.

기본 용어

유전 알고리즘에 대한 토론을 시작하기 전에이 튜토리얼 전체에서 사용할 몇 가지 기본 용어를 숙지하는 것이 중요합니다.

  • Population− 주어진 문제에 대해 가능한 모든 (인코딩 된) 솔루션의 하위 집합입니다. GA의 인구는 인간 대신 인간을 대표하는 Candidate Solutions가 있다는 점을 제외하면 인간의 인구와 유사합니다.

  • Chromosomes − 염색체는 주어진 문제에 대한 해결책 중 하나입니다.

  • Gene − 유전자는 염색체의 한 요소 위치입니다.

  • Allele − 특정 염색체에 대해 유전자가 취하는 가치입니다.

  • Genotype− 유전자형은 계산 공간의 모집단입니다. 계산 공간에서 솔루션은 컴퓨팅 시스템을 사용하여 쉽게 이해하고 조작 할 수있는 방식으로 표현됩니다.

  • Phenotype − 표현형은 실제 상황에서 솔루션이 표현되는 방식으로 표현되는 실제 실제 솔루션 공간의 모집단입니다.

  • Decoding and Encoding − 간단한 문제의 경우 phenotype and genotype공백은 동일합니다. 그러나 대부분의 경우 표현형과 유전자형 공간이 다릅니다. 디코딩은 솔루션을 유전자형에서 표현형 공간으로 변환하는 과정이고 인코딩은 표현형에서 유전자형 공간으로 변환하는 과정입니다. 피트니스 값을 계산하는 동안 GA에서 반복적으로 수행되므로 디코딩이 빨라야합니다.

    예를 들어, 0/1 배낭 문제를 고려하십시오. 표현형 공간은 선택 될 항목의 항목 번호 만 포함하는 솔루션으로 구성됩니다.

    그러나 유전자형 공간에서는 길이가 n 인 이진 문자열로 표시 될 수 있습니다 (여기서 n은 항목 수). ㅏ0 at position x 그것을 나타냅니다 xth항목이 선택되고 1은 그 반대를 나타냅니다. 이것은 유전자형과 표현형 공간이 다른 경우입니다.

  • Fitness Function− 간단히 정의 된 피트니스 함수는 솔루션을 입력으로 취하고 솔루션의 적합성을 출력으로 생성하는 함수입니다. 어떤 경우에는 피트니스 함수와 목적 함수가 동일 할 수 있지만 다른 경우에는 문제에 따라 다를 수 있습니다.

  • Genetic Operators− 이들은 자손의 유전 적 구성을 변경합니다. 여기에는 교차, 돌연변이, 선택 등이 포함됩니다.

기본 구조

GA의 기본 구조는 다음과 같습니다.

초기 모집단 (무작위로 생성되거나 다른 휴리스틱에 의해 시드 될 수 있음)으로 시작하여이 모집단에서 짝짓기를 위해 부모를 선택합니다. 부모에 교차 및 돌연변이 연산자를 적용하여 새로운 자손을 생성합니다. 그리고 마지막으로이 자손들은 인구의 기존 개체를 대체하고 그 과정이 반복됩니다. 이런 식으로 유전 알고리즘은 실제로 인간의 진화를 어느 정도 모방하려고합니다.

다음 각 단계는이 자습서의 뒷부분에서 별도의 장으로 다룹니다.

GA에 대한 일반화 된 의사 코드는 다음 프로그램에서 설명합니다.

GA()
   initialize population
   find fitness of population
   
   while (termination criteria is reached) do
      parent selection
      crossover with probability pc
      mutation with probability pm
      decode and fitness calculation
      survivor selection
      find best
   return best