선형 부호

컴퓨터 과학조합론에서, 선형 부호(線型符號, 영어: linear code 리니어 코드[*])는 알파벳이 유한체이며, 부호화 함수가 유한체 위의 선형 변환블록 부호이다. 그 속의 벡터들 사이의 해밍 거리가 큰 선형 부호를 사용하면, 노이즈가 있는 채널을 통해 전송된 데이터의 일부 오류를 교정할 수 있다.

정의편집

두 자연수  소수의 (양의 정수 지수) 거듭제곱  가 주어졌다고 하자.

길이   차원  진 선형 부호(- 次元 進線型符號, 영어:  -dimensional  -ary linear code with length  )는 유한체   위의  차원 벡터 공간   속의  차원  -부분 벡터 공간

 

이다. 이는 블록 부호

 

으로 생각할 수 있다.

선형 부호  의 원소는 부호어(符號語, 영어: codeword)라고 한다.   위에 해밍 거리를 부여하면, 이는 거리 공간을 이룬다. 해밍 거리를  로 표기하자.

선형 부호  최소 거리(最小距離, 영어: minimum distance)  는 그 부호어 가운데 0이 아닌 것의 최소 해밍 무게이다. 이는  의 서로 다른 두 원소 사이의 거리의 최솟값과 같다.

 

흔히, 최소 거리  의, 길이  의.  차원  진 선형 부호를  -선형 부호라고 표기한다. ( 인 경우  가 흔히 생략된다.)

생성 행렬과 패리티 확인 행렬편집

 -선형 부호  생성 행렬(生成行列, 영어: generator matrix)은  를 선형 생성하는  개의 열벡터들로 구성된   행렬이며, 흔히  로 표기된다.

 -선형 부호  패리티 확인 행렬(영어: parity check matrix)은

 

가 되는   행렬이다. 다시 말해,  의 열벡터들은  를 선형 생성한다. 이는 흔히  로 표기된다.

만약  

 

의 꼴이라면,  표준형 패리티 확인 행렬(標準型parity確認行列, 영어: standard-form parity check matrix)이라고 한다. 임의의 선형 부호에 대하여, 표준형 패리티 확인 행렬이 존재한다.

연산편집

선형 부호

 

직교 여공간

 

 쌍대 선형 부호(雙對線型符號, 영어: dual linear code)라고 한다. 만약   -선형 부호라면,   -선형 부호이다. 일반적으로   로부터 결정되지 않는다.

예:

 
 

은 둘 다 [3,2,1]2-선형 부호이지만, 그 쌍대 선형 부호

 
 

는 각각 [3,1,1]2-선형 부호 및 [3,1,2]2-선형 부호이다.

편집

자명한 부호편집

임의의 소수 거듭제곱   및 두 양의 정수  에 대하여, 자명한 선형 부호

 

를 정의할 수 있다. 이는  -선형 부호이다. 즉, 이 자명한 선형 부호는 각 부호어마다

  • 0개의 오류를 교정할 수 있으며,
  • 0개의 오류를 발견할 수 있다.

다시 말해, 이 자명한 부호는 실제 데이터의 송신에는 쓸모가 없다.

해밍 부호편집

임의의 2 이상의 정수  에 대하여,  -이진 해밍 부호 -선형 부호이다. 예를 들어,  일 때 2-이진 해밍 부호는 [3,1,3]2-선형 부호이며, 3-이진 해밍 부호는 [7,4,3]2-선형 부호이다.

최소 해밍 무게가 3이므로, 이진 해밍 부호는 각 부호어마다

  • 1개 이하의 오류를 교정할 수 있으며,
  • 2개 이하의 오류를 발견할 수 있다.

2-이진 해밍 부호는 최대 거리 분리 선형 부호이지만,  일 경우  -이진 해밍 부호는 최대 거리 분리 선형 부호가 아니다.

아다마르 부호편집

정수  에 대하여, 아다마르 부호(영어: Hadamard code)는  -선형 부호이다. 예를 들어,  일 때 1-아다마르 부호는 [2,1,1]2-선형 부호이며, 2-아다마르 부호는 [4,2,2]2-선형 부호이며, 3-아다마르 부호는 [8,2,4]2-선형 부호이다.

골레 부호편집

이진 골레 부호는 [24,12,8]2-선형 부호이며, 삼진 골레 부호는 [12,6,6]3-선형 부호이다. 이들은 마티외 군의 군론적 성질을 사용하여 구성된다.

데이터 전송편집

데이터

 

  이진 해밍 부호로 전송한다고 하자.   이진 해밍 부호의 생성 행렬과 표준형 패리티 확인 행렬은 각각 다음과 같다.

 
 

그렇다면, 다음과 같은 부호를 송신하게 된다.

 

오류 없음의 확인편집

반대로, 위 데이터

 

를 수신하였다고 하자. 이 데이터가 오류 없이 수신되었음을 확인하려면, 패리티 확인 행렬을 사용하여 다음을 계산한다.

 

이 값이 0이므로 오류가 발생하지 않았음을 알 수 있다.

오류의 교정편집

전송 과정에서 다음과 같은 1비트 오류가 발생했다고 하자.

 

그렇다면, 다음과 같이 오류를 발견할 수 있다.

 

이에 따라, 둘째 비트에서 오류가 발생하였음을 알 수 있다.

역사편집

선형 부호 이론은 1950년에 해밍 부호의 발견으로부터 시작된다. 해밍은 1940년대 벨 연구소에서 벨 모델 V(영어: Bell Model V)라는 컴퓨터를 이용해서 작업을 했다. 이 컴퓨터는 확실히 여러 면에서 오늘날의 컴퓨터와는 거리가 멀었다. 릴레이 회로로 만들어졌으며 입력도 천공 카드를 이용했다. 천공 카드를 이용했으므로 컴퓨터에 입력되는 자료들은 필연적으로 언제나 오류의 가능성이 있었다. 주중에는 컴퓨터의 관리자가 있으면서 입력에 오류가 발생했다는 경고등이 켜지면 직접 수정할 수 있었으나, 관리자가 없는 주말에는 에러가 발생한 채 프로그램이 실행되지 않고 다음 작업으로 넘어가기 일쑤였다.

해밍은 이런 문제로 인해 여러 차례 고생을 한 후에, 이 문제를 근본적으로 해결하기 위해 노력했다. 그 후 몇 년 동안 오류를 수정하는 방법에 대해서 연구하면서 이와 관련된 여러가지의 효율적인 알고리즘을 만들어냈고 마침내 1950년에 해밍 부호를 발표했다.[1]

이진 골레 부호는 마르셀 골레(프랑스어: Marcel Jules Édouard Golay)가 도입하였다. 아다마르 부호는 자크 아다마르의 이름을 땄으며, 그 구성에 아다마르 행렬이 등장하므로 이러한 이름이 붙었다.

참고 문헌편집

  1. Hamming, Richard W. (1950년 4월). “Error detecting and error correcting codes”. 《Bell Labs Technical Journal》 (영어) 29 (2): 147–160. doi:10.1002/j.1538-7305.1950.tb00463.x. ISSN 1089-7089. 

외부 링크편집