기본 콘텐츠로 건너뛰기

MeGUI 2375 버전의 x264 옵션 정리

MeGUI 의 x264 설정창을 기준으로 각각의 옵션들을 정리해 보겠습니다.
먼저 옵션 설명에 필요한 x264의 압축 과정을 간단히 요약하면 다음과 같습니다.

1) IDR프레임,I프레임,P프레임,B프레임 중 어떤 종류의 프레임으로 압축할지를 결정합니다.
  프레임의 종류가 결정되면 각각의 프레임은 다시 매크로블럭(Macroblock)이라는 16x16 크기의
  작은 블럭으로 나눠지는데 이 매크로블럭을 압축하는 방식에는 크게 Intra코딩과 Inter코딩이 있습니다.
  IDR, I프레임은 프레임 내의 모든 매크로블럭이 Intra코딩되는 프레임 이고,
  P프레임 내의 매크로블럭은 Intra코딩과 Inter코딩(전방향)의 두가지 방식이 모두 가능합니다.
  B프레임 내의 매크로블럭도 Intra코딩과 Inter코딩(전방향, 후방향, 양방향)의 두가지 방식이 가능합니다.

  1-1) Inter코딩은 움직임예측(Motion Estimation)을 사용하는 압축방식입니다.
       이미 압축돼있는 프레임을 참조하여 현재 압축하려는 블럭을 예측(Inter Prediction)하고
       예측된 블럭과 실제 블럭의 차이값인 예측오류데이터(Residual Data)를 계산합니다.
       이 때, 예측에 사용된 부분이 참조프레임의 어디에 있는지를 나타내는 움직임벡터(Motion Vector)도
       구해야 하는데 여기에서도 예측이 사용됩니다.
       H.264/AVC 표준 상에 정의된 여러가지 방법으로 PMV(Predicted Motion Vector) 즉, 예측된 움직임벡터를 산출합니다.
       이렇게 산출된 PMV와 움직임예측으로 구해진 실제 움직임벡터와의 차이값(MVD : Motion Vector Difference)을 구합니다.
  1-2) Intra코딩은 움직임예측을 사용하지않는 압축방식입니다.
       움직임벡터가 필요한 프레임 간 예측(Inter Prediction)을 샤용하지 않는 대신, 인접한 주변 블럭들의
       픽셀값을 직접 사용해서 현재 압축하려는 블럭을 예측하는 프레임 내 예측(Intra Prediction)을 사용합니다.
       Inter코딩과 마찬가지로 예측된 블럭과 실제 블럭의 차이값인 예측오류데이터를 구하는게 목적입니다.

2) 1번 과정에서 구해진 예측오류데이터를 압축하기 위해서 먼저 주파수변환을 수행합니다.
  주파수변환은 픽셀 영역의 예측오류데이터를 주파수 영역의 계수들로 변환하는 과정을 말합니다.
  주파수변환을 통해 예측오류데이터를 주파수 계수들로 분리함으로써 이후의 양자화 과정에서 효율적인 압축이 가능합니다.
  H.264/AVC 표준은 이전의 표준에서 사용되었던 8x8 DCT대신에 DCT를 약간 수정한 4x4 정수변환을 사용합니다.
  High Profile 이상에서는 4x4 정수변환과 8x8 정수변환을 선택적으로 사용할 수 있습니다.

3) 2번 과정에서 구해진 주파수 계수들을 양자화(Quantization)합니다.
  불필요하거나 덜 중요하다고 판단되는 주파수 계수들을 줄이거나 제거함으로써 압축을 수행합니다.
  이 과정에서 줄어들거나 제거된 주파수 계수들은 디코딩 과정에서 정확한 복원이 불가능하기 때문에
  실질적으로 데이터의 손실이 방생하는 과정입니다.

4) 양자화된 계수들은 다시 한 번 압축되는데 이 과정을 엔트로피 코딩이라고 합니다.
  엔트로피 코딩은 확률적인 방법을 사용해서 데이터의 크기를 줄이는 무손실 압축방식입니다.
  H.264/AVC 표준에서는 Exp-Golomb, CAVLC, CABAC 등의 방식이 사용되는데 양자화된 예측오류데이터에는
  CAVLC와 CABAC이 선택적으로 사용됩니다. (CABAC은 Main Profile 이상에서만 사용이 가능합니다.)

다음으로 MeGUI 의 설정창에 표시되는 x264 옵션들에 대한 정리입니다.


Main


Encoding Mode
인코딩 모드를 결정하는 부분으로 비트레이트를 배분하는 방법에 따라서 여러가지로 나뉩니다.
  - ABR : 1패스 평균비트레이트 모드입니다. 정해진 비트레이트를 크게 벗어나지 않는 범위 내에서 비트를 배분합니다.
  영상의 전반적인 모습을 알지 못하는 상태에서 정해진 비트레이트에 맞게 비트를 배분해야하기 때문에
  비트 배분에 있어서는 약간 효율이 떨어지는 방식입니다.
  어느정도의 비트레이트를 맞춰야하는 동시에 2패스 모드를 사용하기엔 시간이 부족한 경우라면 ABR모드가 적당합니다.
  비트레이트 단위는 kbit/s입니다.
  - Const. Quantizer : 고정 양자화 모드입니다. 보통 CQP 모드라고 합니다.
  고정된 양자화 수치(QP : Quantization Parameter)로 압축을 수행합니다.
  QP값은 3)번 과정에서 어느정도로 계수들을 양자화할지 결정하는 수치인데 값이 클수록 비트레이트는 낮아집니다.
  비트레이트를 특정해서 인코딩하는 ABR이나 멀티패스 모드에서는 정해진 비트레이트를 맞추기 위해서 QP값을 유동적으로
  조절하면서 압축을 수행하지만 고정 양자화 모드에서는 QP값이 일정하기 때문에 "비트 배분 조절"이라는 개념이 없습니다.
  따라서 인코딩된 영상의 비트레이트가 어떻게 될지는 인코딩이 끝날 때까지 예측할 수가 없습니다.
  QP값이 고정돼있기 때문에 화면이 복잡하고 움직임이 많으면 비트레이트가 높아지고, 반대로 화면이 단순하고 움직임이
  적으면 비트레이트가 낮아집니다. 비트레이트를 예측할 수는 없지만 영상 전체적으로 비슷한 화질을 보여줍니다.
  0부터 51까지의 값이 사용 가능하고 20 ~ 25 사이의 값이 주로 사용됩니다.
  - Const. Quality : 고정 레이트 팩터(CRF : Constant Rate Factor) 모드입니다. 보통 CRF 모드라고 합니다.
  화면의 복잡성을 고려해서 고정된 CRF수치로 비트를 배분하는데, 이 때 사용되는 배분 방식이 멀티패스 모드와 동일하기 때문에
  비트 배분의 효율성에 있어서는 멀티패스 모드와 거의 같다고 할 수 있습니다.
  단, CRF 모드 역시 정해진 비트레이트 없이 고정된 CRF 수치를 기준으로 비트를 배분하는 방식이기 때문에 인코딩된 영상의
  비트레이트를 사전에 예측할 수 없습니다. 이런 면에서는 CQP 모드와 비슷하지만 비트 배분에 있어서 CQP 모드보다
  더 효율적이기 때문에 특별한 경우가 아니라면 CRF 모드를 사용하는 편이 화질면에서 유리합니다.
  마찬가지로 0부터 51까지의 값이 사용 가능하고 20 ~ 25 사이의 값이 주로 사용됩니다.
  - Automated 2pass : 2패스 평균비트레이트 모드입니다. 총 2번의 인코딩 과정이 수행됩니다.
  첫 번째 패스에서는 프레임 종류, 각각의 장면에서 필요한 비트량 등을 분석해서 .stats파일에 기록합니다.
  (MB-Tree를 사용하는 경우에는 MB-Tree에 필요한 정보를 기록하기 위해 .mbtree파일이 추가로 만들어집니다.)
  두번쨰 패스에서는 첫 번째 패스에서 만들어진 .stats파일을 참고해서 실제 인코딩을 수행합니다.
  실제로 영상이 만들어지는 두 번째 패스에서는 .stats파일을 통해서 영상의 전반적인 모습을 알 수 있기 때문에
  정해진 비트레이트를 정확하게 맞춰주면서 동시에 효율적인 비트 배분이 가능합니다.
  비트레이트 단위는 kbit/s입니다.
  - Automated 3pass : 3패스 평균비트레이트 모드입니다. 총 3번의 인코딩 과정이 수행됩니다.
  기본적으로 2패스 평균비트레이트 모드와 같은 방식입니다. 첫 번째 패스에서 .stats파일을 만들어 내고 두 번째 패스에서는
  이미 만들어진 .stats파일을 갱신합니다. 마지막으로 세 번째 패스에서 갱신된 .stats파일을 참고해서 인코딩을 수행합니다.
  두 번째 패스에서 .stats파일을 한 번 더 업데이트하기 때문에 좀 더 정확한 .stats파일을 사용할 수 있다는 장점이 있지만
  그로 인한 이익은 아주 미미한 수준입니다. 인코딩 시간 대비 효율이 낮아서 거의 사용되지 않는 방식입니다.
  비트레이트 단위는 kbit/s입니다.
  - Lossless : 무손실 압축 모드입니다. CQP 모드나 CRF 모드에서 값을 0으로 지정하면 무손실 압축을 수행합니다.
  x264의 압축과정 중에서 데이터의 손실이 발생하는 부분인 3)번 양자화 과정을 거치지 않는 방식입니다.
  3)번 과정을 거치지 않기 때문에 2)번 과정도 생략되고, 1)번 과정에서 바로 4)번 과정으로 진행합니다.
  즉, 예측을 통해 구해진 예측오류데이터를 곧바로 엔트로피 코딩함으로써 무손실 압축이 가능하게 합니다.
  단, 무손실인 만큼 대부분의 경우 비트레이트가 굉장히 높아집니다.
  또한 무손실 압축은 H.264/AVC 표준의 High 4:4:4 Predictive Profile에서만 사용 가능한 방식입니다.
  따라서 x264의 Lossless 모드로 인코딩된 파일은 High 4:4:4 Predictive Profile에 해당합니다.
  프로파일의 이름처럼 H.264/AVC 표준에서는 Lossless 모드에서도 P, B프레임을 모두 사용 가능하도록 정하고 있지만
  x264 개발자들은 Lossless 모드에서 B프레임이 효율적이지 않다는 판단하에 P프레임만 사용하도록 하고 있습니다.

Presets
프리셋은 이용자의 편의를 위해 x264의 여러 옵션값들을 미리 설정해 놓은 메뉴라고 할 수 있습니다.
프리셋의 이름에서 알 수 있듯이 인코딩 속도를 기준으로 여러가지 프리셋이 마련되어 있습니다.
빠른 프리셋은 그만큼 압축 효율은 낮아지고 느린 프리셋은 압축 효율이 높습니다.
먼저 적당한 프리셋을 선택한 후에 추가적으로 조절할 옵션들이 있다면 설정창에서 직접 조절하는 방식으로 사용하면 좋습니다.

Tunings
튜닝 또한 이용자의 편의를 위해 x264의 여러 옵션값들을 미리 설정해 놓은 메뉴입니다.
튜닝의 이름에서 알 수 있듯이 인코딩하려는 소스나 목적에 따라서 여러가지 튜닝값이 마련되어 있습니다.
먼저 적당한 튜닝값을 선택한 후에 추가적으로 조절할 옵션들이 있다면 설정창에서 직접 조절하는 방식으로 사용하면 좋습니다.

AVC Profiles
프로파일은 H.264/AVC 표준에서 사용 가능한 여러가지 압축 기술들을 조합해 놓은 묶음이라고 볼 수 있습니다.
여러가지 프로파일이 정의돼 있지만 x264에서는 High, Main, Baseline 프로파일 중 하나를 선택할 수 있습니다.
(CQP, CRF 모드에서 수치를 0으로 지정하면 High 4:4:4 Predictive 프로파일이 선택됩니다.)
상위의 프로파일을 선택할수록 사용 가능한 옵션들도 많아지고 그만큼 압축된 영상의 디코딩에도 부하가 커지게 됩니다.
하나의 프로파일을 선택하면 해당 프로파일을 만족하는 영상을 만들기 위해서 몇몇 옵션들이 제한됩니다.
각각의 프로파일에서 제한되는 옵션들은 다음과 같습니다.
  - High Profile : No Lossless
  - Main Profile : No Lossless, --no-8x8dct, --cqm flat
  - Baseline Profile : No Lossless, --no-8x8dct, --cqm flat, No Interlaced, --no-cabac, --bframes 0, --weightp 0

AVC Level
레벨은 인코딩된 영상이 어느정도의 디코딩 자원이 필요한지를 표시해 주는 플래그라고 볼 수 있습니다.
H.264/AVC 표준에는 영상의 비트레이트, 해상도, DPB, CPB 등등 여러가지 요인에 따라서 프로파일마다 각각의 레벨을
정해놓고 있습니다. 레벨을 지정해 주지 않으면(Unrestricted/Autoguess) H.264/AVC 표준에 따라서 x264가 자동으로
인코딩된 영상의 레벨을 지정해 줍니다.
특정한 레벨을 지정해 주면 Presets이나 Tunings에서 정해진 참조프레임의 수를 해당 레벨에 맞게 조절해 줍니다.
단, 참조프레임의 수를 직접 지정해 주는 경우가 우선합니다.

Target Playback Device
MeGUI에서 자체적으로 지원하는 옵션입니다. 각종 재생기기에서 요구하는 스펙에 맞게 x264 옵션들을 조정해 줍니다.


Frame Type


H.264 Features
  - Deblocking : H.264/AVC 표준의 In-loop Deblocking 필터와 관련된 옵션입니다. In-loop Deblocking 필터는 1-1)번 과정에서
  참조프레임에 Deblocking 필터를 적용함으로써 좀 더 효율적인 움직임 에측이 가능하게 합니다.
  참조프레임은 이미 압축된 프레임이기 떄문에 블럭화 현상이 나타나는 경우가 많은데 이런 블럭화 현상을 줄여줌으로써
  Inter코딩시 에측오류데이터를 줄일 수 있습니다.
  Strength는 Deblocking 필터의 강도를 결정합니다. 낮은 값일수록 필터의 강도가 약해집니다.
  Threshold는 얼마나 많은 블럭에 Deblocking 필터를 적용할지를 결정합니다.
  낮은 값일수록 더 많은 블럭에, 더 낮은 강도의 Deblocking 필터가 적용됩니다. 
  각각 0이 기본값이고 -3 ~ 3 사이의 값이 주로 사용됩니다.
  - CABAC : Context-Adaptive Binary Arithmetic Coding의 약자입니다.
  4)번 과정에서 엔트로피 코딩에 사용되는 방식 중 가장 효율적인 압축 방식입니다.
  CABAC을 사용하지 않으면 CAVLC(Context-Adaptive Variable Length Coding)이 대신 사용됩니다.
  CAVLC보다 CABAC의 압축 효율이 더 높기 때문에 특별한 이유가 없다면 사용하는 편이 좋습니다.
  다만 압축 효율이 높은 만큼 훨씬 복잡한 방식이기 때문에 인코딩, 디코딩 모두 부하가 커집니다.
  Main Profile이상에서만 사용 가능합니다.
GOP Size
  I프레임은 참조프레임 없이 Intra코딩되는 프레임이기 때문에 키프레임이라고 하면 보통은 I프레임을 말합니다.
  하지만 다수의 참조프레임을 사용하는 H.264/AVC 표준에서는 단순히 I프레임인 것 만으로는 키프레임의 역할을 할 수 없습니다.
  I프레임의 뒤에 위치한 프레임이 다수의 참조프레임을 사용한다면, I프레임의 앞에 위치한 프레임을 참조하는 경우도
  있을 수 있기 때문입니다. 이렇게 프레임 간의 참조 관계가 I프레임을 경계로 하지 않을 수도 있기 때문에 특정한 I프레임에는
  IDR(Instantaneous Decoding Refresh)이라는 플래그를 달아줍니다. 이렇게 IDR플래그가 있는 IDR-I프레임은 뒤에 위치한 프레임이
  IDR-I프레임의 앞에 위치한 프레임을 참조하지 못하게 합니다. 따라서 IDR-I프레임만이 실질적인 키프레임의 역할을 하게됩니다.
  아래의 옵션들은 IDR-I프레임과 관련된 옵션들이고 IDR-I프레임이 아닌 I프레임과는 상관이 없습니다.
  - Maximum GOP size : IDR-I프레임 간의 최대 간격을 설정합니다. 기본값은 250입니다.
  - Minimum GOP size : IDR-I프레임 간의 최소 간격을 설정합니다. 기본값은 25입니다.
  - GOP calculation : MeGUI에서 자체적으로 지원하는 옵션입니다. 기본값인 FPS based를 선택하면 인풋 파일의 FPS에 따라서
  Maximum GOP size와 Minimum GOP size를 조절해 줍니다. 각각 FPS*10, FPS*1 이 사용됩니다.
  Fixed를 선택하면 사용자가 입력한 Maximum GOP size와 Minimum GOP size를 그대로 사용합니다.
  - Open GOP : Open GOP란 GOP의 마지막 프레임을 B프레임으로 압축함으로써 다음 GOP의 키프레임을 해당 GOP의 B프레임이
  참조할 수 있도록 만드는 GOP 구조를 말합니다. Open GOP로 압축되는 경우에는 키프레임에 IDR-I프레임을 사용할 수 없고 대신
  Recovery Point SEI가 삽입된 I프레임을 사용합니다. 이렇게 함으로써 GOP 사이즈가 작은 경우에 약간의 이득을 얻을 수 있습니다.
  x264는 기본적으로 Closed GOP를 사용하고 여기에 체크하면 Open GOP가 사용됩니다.
  
Slicing
  슬라이스는 여러개의 매크로블럭으로 구성된 인코딩의 기본 단위로, 하나의 프레임은 여러개의 슬라이스로 구성됩니다.
  물론 프레임이 한 개의 슬라이스로 구성되는 것도 가능하며 x264는 기본적으로 프레임당 한 개의 슬라이스를 사용합니다.
  이 옵션은 x264가 프레임을 여러개의 슬라이스로 나눠서 인코딩을 수행하게 만드는 옵션입니다.
  일반적으로 사용되는 옵션은 아니고 블루레이 스펙에 맞는 영상을 만드는 등 특별한 경우에 사용되는 옵션입니다.
  하나의 프레임을 여러개의 슬라이스로 나눠서 인코딩하는 경우 프레임 내 예측에 제한이 가해지는 등
  기본값인 하나의 슬라이스를 사용하는 경우보다 압축효율이 낮아집니다.
  - Nb of slices by Frmae : 프레임당 슬라이스의 수를 결정하는 옵션입니다.
  - Max size (in bytes) : 슬라이스의 최대 크기입니다. (단위는 bytes/slice)
  - Max size (in MBs) : 슬라이스당 최대 매크로블럭 수입니다. (단위는 MBs/slice)

B-Frames
  - Weighted Prediction for B-Frame : P-Frame Weighted Prediction 옵션과 마찬가지로 H.264/AVC 표준의 WP을 사용합니다.
  이 옵션에 체크하면 B프레임에서만 사용 가능한 Implicit WP이 사용됩니다.
  특별한 이유가 없다면 사용하는 편이 좋습니다.
  - Number of B-Frames : 연속한 B프레임의 최대 개수를 정하는 옵션입니다.
  Adaptive B-Frames옵션과 함께 사용하는 편이 좋습니다.
  기본값은 3이고 최대 16까지 사용 가능합니다. 3 ~ 5 사이의 값이 주로 사용됩니다.
  - Adaptive B-Frames : 연속한 B프레임의 수를 정해진 범위안에서 유동적으로 조절해 주는 옵션입니다.
  연속한 B프레임의 수를 고정시키는 것보다 상황에 맞게 효율적으로 조절해 주기 때문에 화질면에서 유리합니다.
  기본값은 Fast입니다. Optimal과 Fast가 주로 사용됩니다.
  - B-Frame bias : Adaptive B-Frames에 적용되는 옵션입니다.
  연속한 B프레임의 수를 조절할 때 얼마나 적극적으로 B프레임을 사용할지 정하는 옵션입니다.
  기본값은 0이고 높일수록 B프레임이 많이 사용됩니다. 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - B-Pyramid : 1-1)번 과정에서 움직임예측시 B프레임도 참조프레임으로 사용될 수 있도록 허용하는 옵션입니다.
  이전의 표준들에서는 B프레임이 참조프레임으로 사용되지 못하지만 H.264/AVC 표준에서는 Inter코딩시 B프레임도
  참조프레임으로 사용될 수 있습니다. 기본값은 Normal이고 기본값을 사용하는 편이 좋습니다.
  블루레이 스펙은 H.264/AVC 표준과 다르게 B프레임이 참조프레임으로 사용될 때 약간의 제약이 있습니다.
  P프레임이 B프레임을 참조하지 못하고 B프레임도 바로 옆에 있지 않은 B프레임은 참조하지 못하게 하고 있습니다.
  이런 블루레이의 추가적인 제한을 맞춰주는 옵션이 Strict입니다.
  당연히 Normal보다는 효율이 떨어지기 때문에 특별한 경우가 아니라면 사용되지 않습니다.

Other
  - Number of Reference Frames : Inter코딩시 사용되는 참조프레임의 수를 결정합니다.
  값이 클수록 압축 효율이 높아지지만 역시 인코딩 시간은 늘어납니다.
  기본값은 3이고 3 ~ 5 사이의 값이 주로 사용됩니다.
  Minimum GOP size, Maximum GOP size값에 따라서 IDR 또는 I프레임이 조건에 맞게 사용됩니다.
  - Number of Extra I-Frames : IDR-I프레임 또는 I프레임(Extra I-Frame)을 얼마나 사용할지 결정하는 옵션입니다.
  장면이 전환되는 부분이나 급격하게 화면이 변하는 경우에는 Inter코딩의 효율이 낮아지는데 이 때 IDR프레임 또는 I프레임을
  사용함으로써 얍축 효율을 높일 수 있습니다. 값을 높일수록 사용 빈도가 높아집니다.
  기본값은 40이고 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - P-Frame Weighted Prediction : 화면이 어두워지거나 밝아지는 페이딩 장면같은 경우, 움직임예측이 힘들기 때문에
  Inter코딩의 효율이 낮아지는 경우가 많습니다. 이런 경우에 어두워지거나 밝아진 일련의 프레임들의 유사성을 높이기 위해
  밝아진 프레임은 밝아진 만큼, 어두워진 프레임은 어두워진 만큼 반대 방향으로 가중치를 줌으로써 Inter코딩시 압축 효율을
  높이는 방법이 H.264/AVC 표준에 정의된 Weighted Prediction(WP)인데 WP에는 크게 두가지가 있습니다.
  P, B프레임에서 사용 가능한 Explicit WP와 B프레임에서만 사용 가능한 Implicit WP입니다.
  이 옵션은 P, B프레임에서 사용 가능한 Explicit WP에 관련된 옵션으로 기본값은 Smart입니다.
  Disable을 선택하면 사용하지 않게 되고 Blind는 Smart보다 빠르지만 압축 효율은 떨어집니다.
  - Encode Interlaced : 이 옵션에 체크하면 인터레이스 인코딩 방식을 사용합니다.
  인코딩 방식은 크게 프로그레시브와 인터레이스로 구분할 수 있는데 전자는 일반적인 프레임 단위의 압축방식이고
  후자는 프레임과 필드를 구분해서 압축하는 방식입니다.
  H.264/AVC 표준의 인터레이스 인코딩 방식은 다시 두가지로 나눌 수 있는데 하나는 PAFF(Picture-Adaptive Frame-Field)이고
  또 하나는 MBAFF(Macroblcok-Adaptive Frame-Field) 입니다.
  x264의 인터레이스 인코딩 방식은 MBAFF로서 매크로블럭을 위 아래로 두 개씩 짝지은 다음 프로그레시브 코딩할지
  인터레이스 코딩할지를 정하게 됩니다. 다만 아직은 Adaptive방식이 아니라서 모든 매크로블럭 쌍들이 인터레이스 코딩됩니다.
  프로그레시브 인코딩 방식에 비해서 압축 효율이 많이 떨어집니다.
  인풋 영상의 필드 오더에 따라서 TFF, BFF를 선택해서 인코딩할 수 있습니다.
  - Pulldown : 프로그레시브 스트림에 풀다운 플래그를 삽입해 주는 옵션입니다. 소프트 텔레시네가 적용됩니다.
  - Adaptive I-Frame Decision : IDR-I프레임과 I프레임(Extra I-Frame)을 유동적으로 사용할지 결정하는 옵션입니다.
  이 옵션에 체크하면 장면이 전환되는 부분에서 IDR 또는 I프레임을 적응적으로 사용하게 됩니다.


Rate Control


Quantizers
  주파수변환된 계수들을 얼마나 양자화할 것인지 결정하는 수치인 QP값에 관련된 옵션들입니다.
  - Min/Max/Delta : 프레임당 양자화 수치(QP)의 최소값, 최대값 그리고 연속한 프레임 간에 증가하거나
  감소하는 QP값의 최대치를 조절하는 옵션입니다.
  기본값은 각각 0, 69, 4이고 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - Qunatizers Ratio (I:P / P:B) : I:P 수치는 P프레임을 기준으로 I프레임의 QP값을 산출할 때 사용되는 가중치입니다.
  P:B 수치는 P프레임을 기준으로 B프레임의 QP값을 산출할 때 사용되는 가중치입니다.
  P:B 수치는 MB-Tree옵션과 함께 사용되면, 지정된 값이 무시되고 MB-Tree에 의해서 자동으로 조절됩니다.
  각각 기본값은 1.4, 1.3입니다. 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - Deadzones (Inter / Intra) : 3)번 과정에서 사용되는 양자화 방식의 하나입니다.
  x264는 양자화 방식으로 Deadzones과 Trellis 중 하나를 선택할 수 있습니다.
  이 옵션은 Deadzones을 사용하는 경우에 적용되는 수치이고 기본값은 21, 11입니다.
  각각 0 ~ 32 사이의 값이 사용 가능하고 값을 낮출수록 미세한 디테일이나 필름 그레인 유지에 효과가 있습니다.
  x264는 Trellis를 기본적으로 사용하기 때문에 Deadzones을 사용하려면 Trellis를 사용하지 않아야 합니다.
  - Chroma QP Offset : H.264/AVC 표준에서는 Chroma블럭의 QP값은 따로 계산되지 않고 Luma블럭의 QP값에 따라서
  자동으로 산출되는데, Chroma블럭의 QP값을 산출할 때 사용되는 가중치입니다.
  -12 ~ 12 사이의 값이 사용 가능하고 기본값은 0입니다. 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  Psy-RD, Psy-Trellis 옵션이 사용되면 각각의 수치에 따라서 자동으로 값이 조절됩니다.
  - Credits Quantizer : MeGUI에서 자체적으로 지원하는 옵션입니다.
  MeGUI의 Video Preview 창에서 Intro 버튼과 Credits 버튼으로 Intro / Credits 구간을 지정해 주면 해당 구간을
  x264의 Zones 옵션을 사용해서 고정된 QP값으로 인코딩하는데, 이 때 사용되는 QP값을 결정하는 옵션입니다.
  영화의 초반부나 후반부처럼 자막만으로 구성되는 구간은 비트가 많이 필요하지 않기 때문에 이 옵션을 사용해서
  해당 구간의 QP값을 높여줌으로써 비트를 절약할 수 있습니다. 기본값은 40입니다.

Rate Control
  - VBV Buffer Size : 비디오 버퍼 검증기(VBV)의 버퍼 사이즈를 결정하는 옵션입니다.
  - VBV Maximum Bitrate : VBV의 버퍼에 입력되는 최대 비트레이트를 결정하는 옵션입니다.
VBV(Video Buffer Verifier)는 비디오 버퍼의 크기가 제한되어 있는 하드웨어 재생을 위한 동영상을 만들거나
스트리밍처럼 전송용 동영상을 만드는 경우에 주로 사용되는 기능입니다. 기본값은 각각 0, 0으로 사용되지 않습니다.
각종 휴대기기나 하드웨어 재생기에서 재생할 목적으로 인코딩하는 경우에는 VBV를 사용하는 편이 좋습니다.
  - VBV Initial Buffer : VBV의 버퍼에 데이터가 어느정도 채워졌을 때 재생을 시작할지 결정하는 옵션입니다.
  0 ~ 1 사이의 값이 사용 가능하고 기본값은 0.9입니다. VBV가 사용되지 않으면 이 옵션도 무시됩니다.
  - Bitrate Variance : 1패스 평균비트레이트 모드에서 주로 사용되는 옵션입니다.
  정해진 평균비트레이트를 얼마나 정확하게 맞춰줄지를 결정하는 옵션입니다.
  1패스 평균비트레이트 모드의 목적은 정해진 비트레이트에서 크게 벗어나지 않는 동시에 효율적으로 비트를 배분하는 것인데
  이 옵션값을 높일수록 비트 배분을 효율적으로 하는 대신 정해진 비트레이트에서 벗어나는 정도가 커집니다.
  기본값은 1.0이고 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - Quantizer Compression : 화면의 복잡도에 따라서 비트레이트 배분의 가중치를 결정하는 옵션입니다.
  옵션값을 높일수록 영상 내의 복잡하거나 움직임이 많은 부분에서 비트레이트를 높여 줍니다.
  0 ~ 1 사이의 값이 사용 가능하고 기본값은 0.6입니다.
  MB-Tree와 함께 사용되면 MB-Tree의 강도를 조절해 줍니다. 값이 높을수록 MB-Tree의 강도는 낮아집니다.
  - Temp. Blur of est. Frame complexity : x264는 비트레이트를 배분할 때, 먼저 영상의 복잡하거나 단순한 정도에 따라서
  복잡도(Complexity)가 계산되고 이 복잡도에 따라서 비트를 배분하게 됩니다.
  이 옵션은 계산된 복잡도의 편차를 줄여줌으로써 프레임 간의 과도한 비트레이트 변동을 막아줍니다.
  기본값은 20이고 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  Mb-Tree와 함꼐 사용되면 이 옵션은 무시됩니다.
  - Temp. Blur of Quant after CC : Temp. Blur of est. Frame complexity 옵션과 마찬가지로 프레임 간의 과도한
  비트레이트 변동을 막아주는 옵션입니다. 복잡도에 따라 비트레이트를 배분한 후에 적용되어 다시 한 번 프레임 간의
  비트레이트 편차를 줄여줍니다. 기본값은 0.5이고 특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - Use MB-Tree : Inter코딩시 블럭 간의 참조 관계를 분석해서 참조율이 높은 부분의 비트레이트를 높여주는 옵션입니다.
  즉, Inter코딩시 여러번 참조된 부분의 비트레이트를 높여줌으로써 이후 반복되는 1-1)번 과정에서 예측오류데이터를
  줄여줄 수 있습니다. Quantizer Compression 옵션으로 MB-Tree의 강도를 조절할 수 있습니다.
  - Nb of Frames for Lookahead : MB-Tree의 블럭 간 참조 관계를 분석하는 데에 사용되는 프레임의 수입니다.
  기본값은 40이고 40 ~ 60 사이의 값이 주로 사용됩니다.

Adaptive Quantizers
x264의 AQ(Adaptive Quantization)은 블럭의 Variance(편평도)를 기준으로 QP값을 조절해 주는 옵션입니다.
하늘을 배경으로 하는 장면이나 화면의 어두운 부분, 또는 멀리서 바라 본 잔디밭이나 필름 그레인처럼 편평도가 큰 블럭의
비트레이트를 높여줌으로써 블럭현상을 줄이거나 미세한 디테일을 유지하는 데에 도움이 됩니다.
고정된 QP값을 사용하는 CQP 모드에서는 사용할 수 없습니다.
  - Mode : Variance AQ는 프레임마다 동일한 AQ Strength를 사용합니다.
  Auto Variance AQ는 프레임마다 AQ Strength를 자동적으로 조절해 주는 모드입니다.
  기본값은 Variance AQ입니다.
  MB-Tree 옵션을 사용하면 Variance AQ가 자동적으로 사용됩니다.
  - Strength : AQ의 강도를 결정하는 옵션입니다. 기본값은 1.0이고 0.5 ~ 1.5 사이의 값이 주로 사용됩니다.

Quantizer Matrices
2), 3)번 과정에서 사용되는 Scaling Factor를 조절하는 옵션입니다.
Scaling Factor는 주파수변환된 계수들마다 양자화의 수준을 조절할 수 있게 만들어 주는 수치입니다.
주파수변환과 연계되어 사용되는 값이기 때문에 주파수변환과 마찬가지로 4x4, 8x8 크기의 매트릭스로 구성됩니다.
기본적으로 H.264/AVC 표준에 정의된 Flat(Flat16) 매트릭스가 사용되고 JVT(Joint Video Team) 매트릭스를 선택하거나
사용자가 직접 지정한 매트릭스를 사용할 수도 있습니다.


Analysis


Motion Estimation
1)번 과정에서 사용되는 움직임예측(Motion Estimation)과 프레임 내 예측 등에 관련된 옵션들입니다.
H.264/AVC 표준은 Inter코딩시 움직임예측에 사용되는 블럭의 크기를 최소 4x4 까지 허용합니다. 16x16 크기의 매크로블럭은
16x8, 8x16, 8x8, 8x4, 4x8, 4x4 크기의 서브 파티션들로 나눠지고 각각의 서브 파티션마다 움직임예측이 수행될 수 있습니다.
Intra코딩시에는 16x16, 8x8, 4x4 크기의 서브 파티션이 선택될 수 있고 서브 파티션마다 프레임 내 예측이
수행되는데 각각 4, 9, 9 가지의 예측 모드가 정의되어 있습니다.
또한 움직임예측시 탐색의 정확도에 따라서 Full-Pel(정수 픽셀 단위), Half-Pel(1/2 픽셀 단위), Quater-Pel(1/4 픽셀 단위)로
나눌 수 있는데 x264는 Full-Pel, Half-Pel, Quater-Pel 순으로 개선해가며 움직임예측을 수행합니다.
종합하면, 움직임예측 및 프레임 내 예측은 코딩에 사용될 서브 파티션의 종류와 그에 맞는 움직임벡터 및 프레임 내 예측 모드를
선택하는 과정이라고 할 수 있습니다.
먼저 서브 파티션의 종류 및 프레임 내 예측 모드를 선택할 때 단순히 예측오류데이터가 가장 작은 종류를 선택하는 방법이 있을 수 있지만
이 방법으로는 작은 서브 파티션(4x4 또는 8x8 등)을 선택했을 때, 코딩해야 할 움직임벡터의 수와 예측 모드의 수가 증가하는 것을 고려하지
못합니다. 마찬가지로 움직임벡터를 선택할 때에도 Quater-Pel을 사용하면 예측오류데이터를 줄일 수는 있겠지만
해당 움직임벡터를 코딩하는 데에 더 많은 비트가 필요하게 되는 것을 고려하지 못합니다.
따라서 인코더는 어떤 선택을 할 때마다 그 선택으로 인한 예측오류데이터와 그 선택을 코딩하는 데에 필요한 비트를 함께
고려해야만 최선의 결정을 할 수 있는데 이를 가능하게 하는 선택 결정 방법이 RDO(Rate-Distortion Optimization)입니다.
RDO는 어떤 선택으로 인한 Distortion(예측오류데이터 등)과 그 선택에 필요한 Rate(비트)를 동시에 고려함으로써
효율적인 모드 결정을 가능하게 합니다.
RDO는 서브 파티션의 종류나 움직임벡터의 선택 외에도 프레임 내 예측 모드 등, 여러가지 대안들 중에서 어떤 선택을
해야 하는 경우에 사용될 수 있는 모드 결정 방법이라고 할 수 있습니다. 다만 정확한 Rate를 구하기 위해서는 훨씬 더 많은
계산이 필요하기 때문에 Non-RDO 모드보다 인코딩 속도는 상당히 느려집니다.
  - Chroma M.E. : 이 옵션에 체크하면 움직임예측시 Chroma 채널의 정보도 함께 계산됩니다.
  특별한 이유가 없다면 사용하는 편이 좋습니다.
  - M.E. Range : M.E. Algorith의 탐색 범위를 결정하는 옵션입니다. 기본값은 16이고 값이 클수록 탐색의 범위가
  넓어지기 때문에 인코딩 속도는 느려집니다. 16 ~ 24 사이의 값이 주로 사용됩니다.
  단, M.E. Algorith에서 Diamond나 Hexagon을 선택할 경우 M.E. Range는 4 ~ 16 으로 제한됩니다.
  - M.E. Algorithm : 움직임예측 방식을 결정하는 옵션입니다.
  예측하려는 블럭과 시간적, 공간적으로 가까이에 있는 블럭들로부터 대강의 탐색 시작 위치를 결정하고
  그 위치에서부터 탐색을 시작합니다. 이 단계에서 사용되는 탐색의 정확도는 Full-Pel입니다.
  기본값은 Hexagon이고 Hexagon과 Multi Hex가 주로 사용됩니다.
  - Subpixel Refinement : Subpixel(Half-Pel, Quater-Pel)단위의 움직임예측과 관련된 옵션입니다.
  01 ~ 05 사이의 값은 Sub-Pel 움직임예측의 강도를 결정하고 00을 선택하면 Sub-Pel 움직임예측은 사용되지 않습니다.
  06부터는 서브 파티션의 종류 선택에 RDO가 사용됩니다. 08부터는 서브 파티션의 종류 선택 외에
  움직임벡터와 프레임 내 예측 모드 선택에도 RDO가 사용됩니다.
  10에서는 매크로블럭의 QP값을 선택할 때에도 RDO가 사용됩니다.
  11에서는 인코딩 속도를 높이기 위해 적용되는 모든 최적화 알고리즘을 사용하지 않습니다.
  10 이상을 적용하려면 AQ와 trellis=2 를 사용해야 합니다.

Extra
  - MV Prediction mode : 1-1)번 과정에서 매크로블럭을 Inter코딩할 때 코딩해야하는 정보로는 예측된 움직임벡터(PMV),
  실제 움직임벡터와의 차이값(MVD), 예측오류데이터라고 볼 수 있습니다. 여기서 PMV가 산출되는 방식은, 주로 주변 블럭들의
  움직임벡터를 이용해서 Median벡터를 구하는 방식인데 B프레임에서는 추가적으로 Direct 예측 방식이 지원됩니다.
  B프레임의 Direct 예측 방식은 Spatial과 Temporal로 나눠지는데 둘 중에서 어떤 방식을 사용할지 결정하는 옵션입니다.
  Spatial은 동일한 프레임 내에 있는 주변 블럭들의 움직임벡터를 이용해서 PMV를 구하는 방식입니다.
  Temporal은 앞, 뒤에 있는 참조프레임에서 동일한 위치에 있는 블럭의 움직임벡터를 이용해서 PMV를 구하는 방식입니다.
  Auto는 두 가지 모드를 적응적으로 사용합니다. 기본값은 Spatial이고 Spatial과 Auto가 주로 사용됩니다.
  x264의 1패스 모드에서는 Auto를 사용해도 적응적인 선택을 제대로 하지 못하고 대부분은 Spatial이 사용됩니다.
  Auto는 멀티패스 모드에서 가장 잘 작동합니다.
  - Trellis : 3)번 과정에서 사용되는 양자화 방식의 하나입니다.
  RDO기반의 양자화 방식이고 사용 빈도에 따라서 Final MB와 Always로 나뉩니다.
  Trellis가 사용되지 않을 때에는 Deadzones가 대신 사용됩니다.
  기본값은 Final MB이고 주로 Final MB와 Always가 사용됩니다.
  Trellis 옵션을 사용하려면 CABAC을 사용해야 합니다.
  - Psy-RD Strength : RDO에 의한 모드 결정에서 단순히 PSNR같은 수치를 높이는 결정보다는 사람의 눈으로 봤을 때 더 좋은
  결과를 보여주는 모드를 결정하도록 조절해 주는 옵션입니다. 기본값은 1.0이고 기본값을 사용하는 편이 좋습니다.
  RDO와 관계되는 옵션이기 때문에 Subpixel Refinement 옵션에서 06 이상의 값을 사용해야 작동합니다.
  - Psy-Trellis Strength : Trellis에 의한 양자화 과정에서 사람의 눈에 더 좋게 보이는 결과가 나오도록 양자화 방식을
  조절해 주는 옵션입니다. 기본값은 0으로 사용되지 않고 사용되는 경우에는 0.0 ~ 0.4 사이의 값이 주로 사용됩니다.
  Trellis와 관계되는 옵션이기 때문에 Trellis 옵션에서 Final MB 또는 Always를 사용해야 작동합니다.
  - No Mixed Reference Frames : 1-1)번 과정에서 Inter코딩시 각각의 서브 파티션들은 독립적으로 움직임예측을 수행합니다.
  따라서 각각의 서브 파티션들은 서로 다른 참조프레임을 사용하는 것이 가능하지만 이 옵션에 체크하면 매크로블럭 내의
  서브 파티션들이 모두 동일한 참조프레임을 사용하도록 제한합니다.
  이 옵션을 사용하면 인코딩 속도를 높여줄 수 있지만 그만큼 압축 효율이 낮아집니다.
  - No DCT Decimation : 1-1)번 과정에서 Inter코딩시 구해진 예측오류데이터는 2)번 주파수변환 과정을 거쳐서 주파수 계수들로
  이루어진 DCT블럭으로 바뀝니다. 이 때, DCT블럭 내의 주파수 계수들이 무시해도 좋을 만큼 작다고 판단되면 해당 DCT블럭의
  모든 주파수 계수들을 0으로 만드는 옵션이 DCT Decimation입니다.
  이렇게 DCT블럭 내의 주파수 계수들을 모두 제거하면 이후의 양자화 과정이나 엔트로피 과정도 생략되기 때문에 인코딩 속도를
  높여줍니다. 또한 예측오류데이터를 코딩하지 않기 때문에 비트를 절약할 수 있습니다.
  제거된 주파수 계수들로 인해 미세한 손실이 있을 수도 있지만 대부분의 경우에 그 차이는 구별하기 힘듭니다.
  기본적으로 DCT Decimation이 사용되며, 이 옵션에 체크하면 사용하지 않게 됩니다.
  - No Fast P-Skip : 1-1)번 과정에서 매크로블럭을 Inter코딩할 때, MVD와 예측오류데이터가 0인 블럭을 Skip블럭이라고 합니다.
  즉, 예측된 움직임벡터가 실제 움직임벡터와 일치하고 예측오류데이터도 없는 경우에 해당 블럭은 Skip블럭으로 코딩되는데
  따로 코딩해야할 움직임 정보가 없기 때문에 Inter코딩 모드 중에서 가장 경제적인 모드라고 할 수 있습니다.
  Fast P-Skip은 P프레임 내의 매크로블럭을 Inter코딩할 때, MVD가 0이면서 예측오류데이터가 일정 수준을 넘지 않으면
  해당 블럭을 Skip블럭으로 코딩하고 이후의 움직임예측 과정을 생략하는 옵션입니다.
  Skip블럭으로 코딩되는 매크로블럭이 많아지기 때문에 인코딩 속도를 높여주지만 부정확한 모드 결정이 있을 수 있습니다.
  기본적으로 Fast P-Skip이 사용되며, 이 옵션에 체크하면 사용하지 않게 됩니다.
  - No Psychovisual Enhancements : x264에서 사용되는 모든 Psychovisul Enhancements(사람의 눈에 최적화된 작동)를 사용하지
  않게 하는 옵션입니다. 특별한 경우가 아니라면 사용하지 않는 편이 좋습니다.
  - Noise Reduction : x264의 압축 과정에서 일정 수준 이하의 주파수 계수를 제거하는 방식으로 노이즈를 줄여주는 옵션입니다.
  압축 과정 내에서 사용되는 만큼 일반적인 AVS필터들보다 속도면에서 훨씬 빠르지만 그만큼 성능이 떨어집니다.
  기본값은 0으로 사용되지 않고 사용되는 경우에는 100 ~ 1000 사이의 값이 주로 사용됩니다.

Macroblocks
  - Partitions : 1-1), 1-2)번 과정에서 움직임예측과 프레임 내 예측시 사용할 서브 파티션의 종류를 결정하는 옵션입니다.
  기본값은 Default로 P4x4를 제외한 모든 서브 파티션이 선택됩니다. Default와 All이 주로 사용됩니다.
  Custom을 선택하면 서브 파티션의 종류를 사용자가 선택할 수 있습니다.
  - Adaptive DCT : 2)번 과정에서 8x8 정수변환과 4x4 정수변환을 선택적으로 사용하는 옵션입니다.
  I8x8을 사용하려면 이 옵션을 사용해야 합니다. High Profile 이상에서만 사용 가능합니다.
  - I8x8, I4x4, P8x8, P4x4, B8x8 : 사용 가능한 서브 파티션의 종류입니다.
  H.264/AVC 표준에서는 B4x4까지도 사용이 가능하게 되어있지만, x264는 P4x4만큼이나 B4x4도 효율적이지
  못하다는 개발자들의 판단에 따라서 B4x4를 사용하지 않고 있습니다.

Blu-Ray
블루레이 스펙에 맞는 영상으로 인코딩할 때 사용되는 옵션들입니다.
특별한 경우가 아니라면 사용되지 않습니다.
  - HRD Info : CBR을 적용하는 경우에는 비트레이트 모드로 인코딩해야 하고 정해진 비트레이트를 맞추기 위한 Filler 데이터가 삽입됩니다.
  - Use Access Unit Delimiters : AUD 정보를 스트림에 입력하는 옵션입니다.
  - Fake Interlaced : 블루레이 스펙은 25p, 30p 영상을 지원하지 않기 때문에 50i 또는 60i로 인코딩해야하는 단점이 있습니다.
  이 옵션에 체크하면 MBAFF가 적용된 인터레이스 영상인 것처럼 플래그를 삽입하지만 실질적인 인코딩은 프로그레시브 방식으로 진행됩니다.
  - Enable Blu-ray compatibility : 블루레이 스펙을 맞추기 위해서 다른 여러가지 옵션들을 조정해 주는 옵션입니다.


Misc


Custom Command Line
MeGUI에서 지원하지 않는 x264의 옵션들을 사용해야 할 때 직접 옵션값을 입력해 줍니다.

Files
  - Logfile : 멀티패스 인코딩의 첫 번째 패스에서 만들어질 .stats파일의 경로를 지정해 주는 옵션입니다.
  - Use qp File : 특정 구간의 프레임 종류와 QP값을 직접 지정해 주는 옵션입니다.
  .qpf파일을 통해서 사용되는데 .qpf파일은 각각의 라인이 프레임 넘버, 프레임 종류, QP값 순으로 이루어진 .txt파일입니다.
  QP값을 -1로 지정하면 x264가 자동적으로 QP값을 선택하며 프레임의 종류는 I, i, K, P, B, b 중에서 선택이 가능합니다.
  각각 IDR프레임, I프레임, 키프레임, P프레임, 참조B프레임, B프레임을 의미합니다.
  키프레임은 Open GOP의 사용 여부에 따라 IDR-I프레임 또는 Recovery Point SEI가 삽입된 I프레임이 적절히 사용됩니다.

V.U.I.
Video Usability Information의 약자로서 인코딩된 스트림에 여러가지 플래그들을 삽입해 주는 옵션입니다.
인코딩된 스트림을 재생할 때 디코더가 해당 플래그를 읽고 플래그가 의도한대로 디코딩하게 만드는 것이 목적이지만
대부분의 소프트웨어 디코더는 이 플래그들을 무시합니다. 거의 사용되지 않는 옵션입니다.
  - Range : 디코딩시 PC Range(0 ~ 255) 또는 TV Range(16 ~ 235)를 사용하도록 표시하는 플래그가 삽입되는 옵션입니다.
  - Force pic_struct : 스트림에 Picture Timing SEI를 삽입해주는 옵션입니다. Open GOP나 인터레이스 인코딩시 자동 적용됩니다.
  - Color Primaries, Transfer, Color Matrix : 디코딩시 YUV<->RGB 변환 방식을 정해주는 옵션입니다.

Input/Output
Input과 Output 사이의 편차를 나타내는 수치인 PSNR과 SSIM을 계산해 주는 옵션입니다.
  - PSNR calculation : 인코딩을 완료한 후에 PSNR 수치를 Log에 표시합니다.
  - SSIM calculation : 인코딩을 완료한 후에 SSIM 수치를 Log에 표시합니다.
  - Force SAR : 인풋 영상의 SAR(Sample Aspect Ratio)을 정해주는 옵션입니다.

Other
  - Threads (0 = Auto) : 멀티스레딩을 사용하는 경우에 사용할 스레드의 수를 결정하는 옵션입니다.
  기본값은 0으로 x264가 자동으로 스레드의 수를 결정하며 [CPU의 코어 수 * 1.5]가 사용됩니다.
  특별한 이유가 없다면 기본값을 사용하는 편이 좋습니다.
  - Thread-input : 멀티스레딩을 사용하는 경우에 소스의 디코딩을 독립된 스레드에서 작업하게 합니다.
  - Non Deterministic : Threads 값이 1 보다 큰 경우 이 옵션을 사용하면 인코딩 아웃풋이 일정하지 않게 됩니다.
  - Slow first pass : 2패스, 3패스, 4패스 모드 등의 멀티패스 모드에서 사용되는 옵션입니다.
  멀티패스 모드의 첫 번째 패스에서는 .stats파일을 만드는 것이 목적이기 때문에 .stats파일을 만드는 과정에
  크게 영향을 주지 않는 옵션들의 수치를 낮춰 줌으로써 첫 번째 패스의 인코딩 속도를 높여주는 것이 효율적입니다.
  따라서 x264는 자동으로 첫 번째 패스의 옵션들을 아래와 같이 수정해서 인코딩을 수행하는데,
  --ref 1, --no-8x8dct, --partitions none, --me dia, --subme 2, --trellis 0, --fast-pskip
  이 옵션에 체크하면 위와 같은 옵션 조정이 이뤄지지 않고 사용자가 입력한 옵션들이 첫 번째 패스에서도
  그대로 사용됩니다.
  - Fast Decode : x264의 튜닝 옵션으로 --tune fastdecode를 추가합니다.
  - Zero Latency : x264의 튜닝 옵션으로 --tune zerolatency를 추가합니다.

Adjustments
  - Default Settings : 모든 옵션을 x264의 기본값으로 초기화합니다.
  - Preset Settings : 선택된 프리셋에 따라 x264옵션들을 조정합니다.

댓글

이 블로그의 인기 게시물

UNIX C errno 정리( 에러 번호 )

#define EPERM   1   /* Operation not permitted      */ #define ENOENT  2   /* No such file or directory        */ #define ESRCH   3   /* No such process          */ #define EINTR   4   /* interrupted system call      */ #define EIO 5   /* I/O error                */ #define ENXIO   6   /* No such device or address        */ #define E2BIG   7   /* Arg list too long            */ #define ENOEXEC 8   /* Exec format error            */ #define EBADF   9   /* Bad file descriptor   ...

시리얼(Serial) 이란?

출처 - http://www.ni.com/white-paper/2895/ko/#toc4 시리얼은 거의 모든 PC에서 표준으로 사용되는 디바이스 통신 프로토콜입니다. 시리얼의 개념을 USB의 개념과 잘 구분하십시오. 대부분의 컴퓨터에는 2개의 RS232 기반 시리얼 포트가 있습니다. 시리얼은 또한 여러가지 디바이스에서 계측을 위한 일반 통신 프로토콜이며, 여러 GPIB 호환 디바이스에는 RS232 포트가 장착되어 있습니다. 뿐만 아니라, 원격 샘플링 디바이스로 데이터 수집을 하는 경우에도 시리얼 통신을 사용할 수 있습니다. 시리얼 통신의 개념은 간단합니다. 시리얼 포트는 정보의 바이트를 한번에 한 비트씩 순차적으로 송수신합니다. 한번에 전체 바이트를 동시에 전달하는 병렬 통신과 비교하면 시리얼 통신은 속도가 느리지만 훨씬 간단하며 장거리에도 사용할 수 있습니다. 예를 들어, 병렬 통신용 IEEE 488 스펙을 보면 기기간 케이블링은 총 20 m 미만이어야 하며, 두 개의 디바이스간은 2 m 미만이어야 합니다. 반면 시리얼 통신은 최대 1.2 Km의 통신거리를 보장합니다. 통상 엔지니어들은 ASCII 데이터를 전송할 때 시리얼 통신을 사용합니다. 이 때 송신용 (Tx), 수신용 (Rx), 그라운드용 (GND)의 세 가지의 전송 라인을 사용하여 통신합니다. 시리얼은 비동기식이므로 포트는 한 라인에서 데이터를 전송하고 다른 라인에서 데이터를 수신합니다. 핸드쉐이킹용 라인도 사용 가능하지만 필수 요구사항은 아닙니다. 시리얼 통신의 가장 중요한 특징에는 보드 속도 (baud rate), 데이터 비트, 정지 비트, 패리티가 있습니다. 두 개의 포트가 통신하기 위해서는 이러한 파라미터가 반드시 적절하게 맞춰져야 합니다. 보드 속도는 통신의 속도를 측정하는 수치이며 초당 비트 전송 숫자로 표시됩니다. 예를 들어 300 보드 속도는 초당 300 비트를 의미합니다. 엔지니어들이 흔히 말하는 클럭 주기는 보드 속도를 의미합니다. 따라서 프로토콜에 ...

[C언어] epoll 설명

출처 -  http://biscuit.cafe24.com/moniwiki/wiki.php/epoll 1  준비 2  socket 프로그래밍 기본 3  비동기 입출력 (Asyncronous I/O) & 입출력 다중화 (I/O Multiplexing) 4  select 5  select 와  poll  그리고 epoll. 그 차이 6  epoll 프로그래밍 흐름 7  epoll 함수들 8  epoll References 빈폴도 아니고, 이폴이란 대체 무엇일까? 당신은 서버한대로 몇 명의 동시접속자를 수용할 수 있습니까? 최근에 인터넷에 떠돌아다니는  c10k_problem 은 대당 10K, 즉 1만명의 동시접속(concurrent users)을 받아보자는 문제다. 서버 프로그래밍을 해 본 사람이라면 이게 그리 만만한 문제가 아니라는 것을 직감할 듯 --; 요즘의 Massive 온라인게임은 '분산처리'가 기본이라 한 대에서 많은 이용자를 커버하기보다는 여러대가 하나의 세트로써 구성하는 것이 인기가 있고 다수의 커넥션보다는 소수 커넥션에서의 대용량 전송이 더 중요한 요소이기도 하다. c10k problem에 나또한 관심을 가지게 되었고, epoll 이 최근 급부상하는 솔루션으로 인기가 있다기에 한 번 파보자 하고 결심하고 이 글을 시작했다. 마침 wiki에도 관심이 있던 차라, wiki 공부도 할 겸해서 epoll 을 연구하는 과정을 이 wiki에 담아 보고자 한다. 1  준비  # * 누구를 위한 epoll 인가? epoll은 '한 대의 서버에서 아주많은 동시접속자를 처리하기 위한 수단'이다. 이미 당신이 그 수단을 알고 있다면 - epoll 이건 아니건 - 이 글은 별로 도움이 안될듯하다. 동시접속자가 천명을 넘지않는다면 구닥다리 방법을 이용하는 것과 큰 차이...