KTUG 한국 텍 사용자 그룹

Menu

KTUG :: 마당자유글 › 한글의 분해와 조립

nanim | 2015.06.14 20:12:10 | 메뉴 건너뛰기 쓰기

아래 글 http://www.ktug.org/xe/index.php?document_srl=207243&mid=KTUG_open_board 의 과제를 해결하려면, 한글 문자를 초/중/종성으로 분리해야 합니다.


잘 알려진 대로 한글 완성형 음절문자 영역의 11172자는 한글이 사전순으로 배치되어 있기 때문에, 다음 공식으로 초/중/종성 분리가 가능합니다. 나눗셈은 정수 나눗셈입니다.


basecode = 문자코드 - 44032

초성코드 = basecode / 588

중성코드 = (basecode - 588*초성코드) / 28

종성코드 = (basecode - 588*초성코드 - 28*중성코드)


expl3로 다음과 같이 구할 수 있습니다.


\cs_new:Npn \get_lvt_code:n #1
{
    \int_set:Nn \g_cho_int { \int_div_truncate:nn { #1 } { 588 } }
    \int_set:Nn \g_jung_int { \int_div_truncate:nn { #1 - 588 * \g_cho_int } { 28 } }
    \int_set:Nn \g_jong_int { #1 - \g_cho_int * 588 - \g_jung_int * 28 }
}


====


이번에는 자모조합 코드(첫가끝)로 입력된 한글을 완성형 음절문자로 대응시키는 방법입니다.


우선 자모문자의 코드를 각각 얻어서 이로부터 다음 연산을 합니다.


초성코드 = 초성자모문자코드 - 4352

중성코드 = 중성자모문자코드 - 4449

종성코드 = 종성자모문자코드 - 4519


음절문자코드 = (초성코드 * 21 + 중성코드) * 28  + 종성코드 + 44032


====


첨부파일을 참고하십시오. hangultest.tex

메르스가 창궐하는 이 때, 오프라인 스터디 모임은 (아마도) 무기연기되는 것 같습니다.

그래서 지면으로 토론을 대신합니다.


첨부 [1]

댓글 [17]

댓글 쓰기

목록 삭제

KTUG 한국 텍 사용자 그룹