힐베르트 변환(Hilbert變換 (또는 힐버트 변환), 영어: Hilbert transform)은 수학과 신호처리 용어로, u(t) 라는 함수를 취하는 선형연산자인데, 이는 같은 domain상에서 H(u)(t) 함수를 만들어 낸다.
힐베르트 변환은 신호 u(t)의 해석적 표현을 유도하기 위해 사용되는 신호처리 영역에서 대단히 중요하다.
이는 실수 신호u(t)를 복소수 차원으로 확장한다는 것이다.
예로, 힐베르트 변환은 푸리에 해석에서 주어진 함수의 고조파 쌍(en:harmonic conjugate)으로 만든다.
단일 적분 연산자와 푸리에 곱은 동등하다. (어떤 신호가 전달함수를 통과하면, 단일적분연산자인 합성곱의 결과와 전달함수의 주파수 함수인 푸리에 함수의 곱과 같다는 의미임)
힐베르트 변환은 원래 주기함수, 즉 원에서 힐베르트 핵(영어: Hilbert kernel)과 합성곱에 의해 주어지는 함수를 위해 정의되었다.
그러나 일반적으로 힐베르트 변환은 실선 R(위상단의 영역)에 정의되는 함수인 코시 핵(영어: Cauchy kernel)과 합성곱을 취한다.
힐베르트 변환은 페일리-위너 정리(영어: Paley–Wiener theorem)와 연관되어 있다.
힐베르트 변환은 정칙 함수에 대해 리만-힐베르트 문제(영어: Riemann–Hilbert problem)의 특수한 경우를 풀기 위해 도입한 연산자로 이를 도입한 다비트 힐베르트에 의해 이름이 붙어졌다.
u(t)의 힐베르트 변환은 함수 h(t) = 1/(πt) 와 u(t)의 합성곱으로 생각할 수 있다.
h(t)는 적분이 아니기 때문에, 합성곱을 정의하는 적분은 수렴하지 않는다. 대신, 코시 주요값(여기에 p.v.라 표시)을 사용하여 힐베르트 변환을 정의한다. 이 경우 명시적으로, 함수 또는 신호 u(t)의 힐베르트 변환은 다음과 같다. :
힐베르트 변환이 함수 u에 2번 연속 수행되면, 결과는 u 의 음의 값이 된다 :
역변환(inverse transform)은 −H이다. u(t)의 푸리에 변환에서 힐베르트 변환의 영향을 고려함에 의해 이 효과는 쉽게 볼 수 있다. (참조 아래 푸리에 변환과의 관계).
상반평면(upper half-plane)에서 해석함수(en:analytic function)에 대해, 힐베르트 변환은 경계값(boundary values)의 실수부와 허수부 사이의 관계를 설명한다.
즉, 만약 f(z)이 영역 Im z > 0에서 해석적이고 u(t) = Re f(t + 0·i ) 라면, 힐베르트 변환이 존재한다는 조건으로 부가적인 값까지 Im f(t + 0·i ) = H(u)(t) 가 된다.
힐베르트 변환 필터의 특성은 모든 주파수에서 크기는 변하지 않고(all-pass filter) 위상만 음의 주파수에선 +90도, 양의 주파수에선 -90도로 변화시켜주는 필터이다. 즉 어떤 주파수의 cos wt 신호가 들어가면 항상 sin wt 신호가 나오는 것이다. 아래 푸리에 변환과의 관계 참조.
신호처리에서 u(t)의 힐베르트 변환은 로 일반적으로 표기된다 (Brandwood 2003, pg 87 괄호 없는 하버드 인용 error: 대상 없음: CITEREFBrandwood2003 (help)).
그러나 수학에선 이 표기를 이미 u(t)의 푸리에 변환으로 광범위하게 사용하고 있다 (Stein & Weiss 1971 괄호 없는 하버드 인용 error: 대상 없음: CITEREFSteinWeiss1971 (help)). 경우에 따라선, 힐베르트 변환은 라고 쓰기도 한다. 더욱이, 많은 문헌에선 여기에 정의한 것의 음으로 힐베르트 변환을 정의한다 (Bracewell 2000, pg 359 괄호 없는 하버드 인용 error: 대상 없음: CITEREFBracewell2000 (help)).
힐베르트 변환은 리만-힐베르트 문제(Riemann–Hilbert problem)이라고 알려진 해석적 함수(Kress (1989) harvtxt error: 대상 없음: CITEREFKress1989 (help); Bitsadze (2001) harvtxt error: 대상 없음: CITEREFBitsadze2001 (help))에 관해 Riemann에 의해 제기된 문제에서 다비트 힐베르트의 1905년 작업에서 시작되었다. 힐베르트의 작업은 주로 원(Khvedelidze 2001 괄호 없는 하버드 인용 error: 대상 없음: CITEREFKhvedelidze2001 (help); Hilbert 1953 괄호 없는 하버드 인용 error: 대상 없음: CITEREFHilbert1953 (help))에서 정의된 함수에 대한 힐베르트 변환에 관한 것이었다.
고로 H(u)(t)은 u(t)의 음의 주파수 성분은 +90° (π/2 radians)의 위상이 이동 되고, 양의 주파수 성분은 −90° 의 위상이동 효과를 나타낸다.
그리고 i·H(u)(t) 은 양의 주파수 성분을 되살리고, 음의 주파수 성분은 추가로 +90° 위상이동시켜, 결론적으로 음으로 만든다.
힐베르트 변환을 2번 적용했을시, u(t)의 음과 양의 주파수 성분은 각각 +180° 와 −180° 이동한다. 이 신호는 크기는 같고 부호만 반대로 된다. H(H(u)) = −u,
그 이유는 다음과 같다.
아날로그 신호를 이산 신호로 바꾸면 주파수 축에서 아날로그 스펙트럼이 sampling 주파수마다 반복된다.
이산시간 푸리에 변환(discrete-time Fourier transform, DTFT), U(ω)에 대한 이산함수(discrete function) u[n]에 대해, 힐베르트 변환은 다음과 같다.
여기서:
그리고 합성곱 정리(convolution theorem)에 의해, 등가 수식은 다음과 같다.
여기서:
합성곱을 수치적으로 계산했을때, FIR 근사는 그림1에 보여주는 것처럼 h[n]에 대해 치환된다. (다시말해 들어오는 신호와 그림 1의 첫번째 함수로 합성곱을 취하면 힐베르트 변환이 된다.) 그리고 밴드패스필터의 결과로 낮은 주파수와 높은 주파수 (0과 나이퀴스트 주파수(Nyquist frequency))에서 통과대역이 0로 떨어지는 것을 볼 수 있다.
그림 2에서 보여주는 것처럼, 높은 끝 주파수는 부드럽고, 연속시간함수인 h(t)에 더욱 근사인 resembles samples의 FIR 에 의해 원위치될 수 있다.
그러나 실제적인 문제에 있어서, 적절히 sampling된 u[n] 연속 data는 그 주파수에서 사용가능한 주파수를 가지고 있지 않다.
임펄스 반응을 더욱 길게 얻는다면, 낮은 끝 쪽 주파수 또한 잘 처리할 수 있다.
[1]
h[n]에 근사 FIR 필터로, overlap-save이라는 방법은 긴 u[n] 연속 데이터로 합성곱을 수행하는게 효과적인 방법이다.
때때로 array FFT{h[n]}는 σH(ω)의 상응 샘플에 대치된다.
그것은 다음의 en:periodic summation으로 합성곱의 효과를 가진다.
그림 3은 hN[n]의 반주기와 h[n]의 상응 길이 부분의 비교이다.
그들 사이의 차이와 그들 세그먼트 길이 (N)보다 짧지 않다는 사실이 왜곡의 근원인데, 세그먼트 길이와 중첩 파라미터를 증가시킴으로써 왜곡을 관리하여 줄일 수 있다.
대중적인 매트랩(MATLAB) 함수인 hilbert(u,N)는 복소 출력 데이터의 허수부분으로 u[n]의 근사 이산 힐베르트 변환을 해준다.
실수부분은 원래의 입력 연속 데이터이게되어, 복소출력은 u[n]의 해석적 표현(analytic representation)이 된다.
위에서 이야기한 것과 비슷하게, hilbert(u, N)함수는 sgn(ω)분포만을 사용하여 hN[n]로 합성곱을 취하게 된다.
출력 데이터의 근사수를 무시하여 실제 u[n] 연속 데이터보다 큰 N값을 사용함에 의해 왜곡을 줄일 수 있다.
이 형태의 왜곡의 예는 그림 4에 있다.
그리고 L2의 u(n)에 대하여 순열 H(u)[n]이 또한 L2임을 증명하였다.(힐베르트의 부등식 참조). 이에 대한 기초적인 증명은 (Grafakos 1994) harv error: 대상 없음: CITEREFGrafakos1994 (help)에 있다. 이 변환은 E. C. Titchmarsh에 의하여 M. Riesz의 결과를 연속인 경우에 증명하기 위하여 사용되었으나(Titchmarsh 1926 괄호 없는 하버드 인용 error: 대상 없음: CITEREFTitchmarsh1926 (help); Hardy, Littlewood & Polya 1952, ¶314 괄호 없는 하버드 인용 error: 대상 없음: CITEREFHardyLittlewoodPolya1952 (help)), 실용적인 신호처리에서는 사용되지 않는다.