2013년 1월 30일 수요일

다이폴 안테나의 복사 저항(Radiation Resistance of a Dipole Antenna)

[경고] 아래 글을 읽지 않고 "다이폴 안테나의 복사 저항"을 보면 바보로 느껴질 수 있습니다.
1. 가장 쉬운 안테나 이론
2. 안테나의 복사저항
3. 헤르츠 다이폴
4. 다이폴 안테나
5. 코사인 적분

[확인] 본 페이지는 exp(jωt) 시간 약속을 사용하고 있습니다.


[그림 1]에 있는 다이폴 안테나(dipole antenna)입력 임피던스(input impedance)을 규정하는 중요한 양이 복사 저항(radiation resistance)이다. 안테나의 복사 저항을 구하려면 먼저 원역장(far-field) 복사 패턴을 구해야 한다.

[그림 1] 다이폴 안테나

다이폴 안테나(dipole antenna)의 복사 패턴(radiation pattern)은 헤르츠 다이폴(Hertz dipole)전자기장(electromagnetic field) 복사식을 이용해서 다음처럼 구한다.

                       (1)

                       (2)

여기서 $l$은 다이폴의 길이이다. 식 (1)의 복사 패턴을 이용해 다이폴 안테나의 복사 전력(radiated power)을 구하자.

                       (3)

식 (3)은 수치 적분(numerical integration)을 통해 구할 수도 있지만 반파장 다이폴 안테나(half-wave dipole antenna)인 경우는 간단하게 적분할 수 있다. 반파장 다이폴 안테나의 복사 패턴인 식 (4)를 식 (3)에 대입해서 복사 전력에 대한 적분을 얻는다.

                       (4)

                   (5)

식 (5)에는 특수 함수인 식 (6)의 코사인 적분(cosine integral)이 등장한다.

                       (6)

따라서 반파장 다이폴 안테나의 복사 전력은 다음처럼 표현된다.

                        (7)

식 (7)의 관계식을 통해 복사 저항을 구해보면 다음과 같다.

                       (8)

반파장 다이폴 안테나의 복사 저항은 실무 차원에서 매우 중요한 의미를 가진다.

   
[그림 2] 동축선(출처: wikipedia.org)

실험에 많이 쓰이는 [그림 2]의 동축선을 보자. 실무에 사용하는 동축선의 특성 임피던스(characteristic impedance)는 주로 50 혹은 75 Ω을 가진다. 만약 동축선의 특성 임피던스를 75 Ω으로 택하면, 임피던스 정합 회로(impedance matching circuit)가 없더라도 반파장 다이폴 안테나를 거의 반사(reflection)없이 동축선과 연결할 수 있어 전체 회로 구조가 매우 단순해진다.

2013년 1월 26일 토요일

Postcript 파일 읽는프로그램

수학자들이 좋아하는 문서 편집 프로그램인 LaTex은 기본적으로 포스트스크립트(PS: postscript) 파일을 생성한다. LaTex이 공짜인 것처럼 PS 파일 보기 프로그램(GSview)도 공짜이다. 자신의 OS에 맞게 Ghostscript를 깐 후 GSview를 깔면 PS 파일을 볼 수 있다.

2013년 1월 21일 월요일

32비트 코드를 64비트로 변환(Code Conversion from 32-bit to 64-bit)

윈도우7이 인기를 끌면서 64비트 프로그래밍(64-bit programming)은 거스를 수 없는 대세가 되었다. 아래 정보를 확인해 이전에 짜둔 Visual Studio의 32비트 코드를 64비트로 바꾸어 보자.

[64비트용 솔루션 플랫폼(solution platform) 생성]
1. “구성 관리자 -> 활성 솔루션 플랫폼 -> 새로 만들기”에서 ‘x64’를 추가함

2. “활성 솔루션 구성”에 “Debug x64”, “Release x64”를 추가하고 플랫폼을 모두 ‘x64’로 바꿈: "활성 솔루션 플랫폼"을 'x64'로 바꾸면 모든 솔루션이 x64로 바꾸므로 플랫폼 항목만을 바꾸자.

현재 컴파일러가 64비트 모드에서 동작 중인지 확인하려면 '_WIN64' 정의 여부를 확인하면 된다. 이걸로 확인이 안된다면 "구성 속성 -> C/C++ -> 전처리기 -> 전처리기 정의"에 'WIN64'를 추가하면 해결된다. 한가지 조심할 것은 '_WIN32'이다. 이 정의는 32비트와 64비트 모두에서 사용되기 때문에 '_WIN32'를 이용해 32비트 유무를 판별해서는 안된다. 반드시 '_WIN64'를 써야 한다.

[데이터 변환]
  • int -> INT64, __int64, long long
  • long -> LONG64, __int64, long long
  • unsigned int -> UINT64, usigned __int64, unsigned long long
  • unsigned long -> ULONG64, usigned __int64, unsigned long long
  • INT_PTR, UINT_PTR, LONG_PTR, ULONG_PTR처럼 ..._PTR로 끝나는 변수는 컴파일러가 32비트 모드인지 64비트 모드인지에 따라 선언되는 변수 종류가 자동으로 달라짐
  • int 상수 1 -> 1i64
  • long 상수 1L -> 1LL
  • unsigned int 상수 1 -> 1ui64
  • unsigned long 상수 1UL -> 1ULL 
double에 대해서는 변경할 것이 없다. long double이든지 double이든지 컴파일러는 동일한 코드를 만든다.

[참고문헌]

2013년 1월 1일 화요일

NEC-2의 문법(Grammar of NEC-2)

[경고] 아래 글을 읽지 않고 "NEC-2의 문법"을 보면 바보로 느껴질 수 있습니다.
1. 계산용 전자파 코드: NEC


NEC-2(Numerical Electromagnetic Code)는 포트란(Fortran: IBM 수학 공식 번역 체계, The IBM Mathematical Formula Translating System) 언어를 기반으로 만들었기 때문에, 문법 구조도 포트란과 매우 유사하다. 요즘은 포트란 사용자가 거의 없어서 포트란은 프로그래밍계의 라틴어에 해당한다. 하지만 우리 선배들이 이루어 놓은 방대한 포트란 코드로 인해, 수치 해석을 할 때는 어쩔 수 없이 포트란을 사용해야 하는 경우가 있다. NEC-2를 사용할 때 주의 사항은 아래와 같다.
  • 길이 단위는 단위 표준인 미터(meter)이다.
  • 주파수 단위는 Hz가 아닌 MHz이다. 
NEC-2의 예제는 [표 1]에 제시한다.

[표 1] NEC-2용 다이폴 안테나 예제
Example1.nec
CM Example 1 : Dipole in free space   ' Comment cards
CM See GetStarted.txt
CE    ' End of comment
'
GW 1 9 0 -.2418 0 0 .2418 0 .0001   ' Wire 1, 9 segments, halve wavelength long.
GE 0   ' End of geometry
'
EX 0 1 5 0 1 0   ' Voltage source (1+j0) at wire 1 segment 5.
'
FR 0 1 0 0 300 0   ' Set design frequency (300 Mc).
'
EN   ' End of NEC input


   1. 주석 처리(CM: CoMment)   

주석은 반드시 CM으로 시작해야 한다. 주석을 끝내려면 CE(Comment End)를 넣는다. 예를 들어 위에 있는 Example1.nec을 보자. 위 코드에 보이는 ' 표시는 그 다음 부분부터 무시하라는 뜻이다.


   2. 변수 정의(SY: SYmbol)   

변수 정의는 SY로 시작해야 한다. 문법은 아래와 같다.

[문법]
SY a = 1   ' a에 1을 대입
______________________________


   3. 금속 구조 입력(geometry)   

NEC-2는 아래처럼 여러 가지 구조를 입력할 수 있다. 구조 입력이 끝나면 GE(Geometry End)를 넣는다.

3.1. 선 구조 입력(GW: Geometry of Wire)

NEC-2에 금속 선을 넣는 명령은 GW이다.

[문법]
GW nTag nSegment x1 y1 z1 x2 y2 z2 rad   ' nTag번 금속 선에 nSegment개의 분할(segment) 생성, 금속 선은 좌표값 (x1, y1, z1)과 (x2, y2, z2)에 위치, 금속 선의 반지름은 rad
______________________________

금속 선 좌표값과 반지름의 단위는 모두 미터이다. 위에 있는 금속 선 번호(nTag)는 선 특성을 변경할 때 사용되므로 모든 선이 다른 번호를 가져야 한다.

3.2. 접지면(ground) 선택

접지면은 GE 다음에 오는 숫자를 이용해 다음처럼 정한다.
  • GE 0   ' 구조물이 자유공간에 있음
  • GE 1   ' 구조물이 접지면 위에 있음, 자세한 사항은 GN(GrouNd) 명령어로 정해야 함
  • GE -1   ' 구조물이 접지면 위에 있음, 자세한 사항은 GN(GrouNd) 명령어로 정해야 함
GE 1과 GE -1은 접지면이 있음은 동일하지만 금속 구조물이 접지면과 닿은 경우의 처리가 다르다. GE 1은 구조물이 접지면과 닿으면 구조물의 전류 분포를 바꾸어 구조물과 접지면이 붙게 한다. GE -1은 접지면과 닿은 부분의 구조물 전류 분포를 0으로 만들어 구조물과 접지면 연결을 사실상 끊는다.


   4. 원천 입력(EX: EXcitation)   

구조물 입력후에는 원천(source or excitation)을 넣어야 한다.

4.1. 전압원(voltage source)

[문법]
EX 0 nTag nSegment 0 real imag   ' 전압원을 nTag 번호를 가진 선 구조의 nSegment에 입력, 전압원의 복소수 입력값은 (real, imag)임
______________________________


   5. 주파수 입력(FR: FRequency)   

계산을 위한 다양한 주파수 입력은 아래처럼 한다. 주파수 단위는 MHz이다.

5.1. 단일 주파수(single frequency)

[문법]
FR 0 1 0 0 freq 0 ' 주파수 freq MHz로 계산
______________________________


   6. 끝내기(EN: ENd)   

NEC-2 입력을 끝내려면 EN을 넣는다.


[참고문헌]
[6] P. Knott, Wire Antenna Modelling with NEC-2, 2009.