레플리
글 수 284

문장을 벡터로 변환하는 방법들

조회 수 931 추천 수 0 2021.09.16 15:57:52


 

https://ichi.pro/ko/sentence-bertleul-sayonghan-pungbuhan-munjang-imbeding-pateu-i-226626600899395

 

 

 

보통 챗봇에서 많이 사용하는 방법 중 하나가 문장의 유사도를 비교하는 것입니다. 만약 사용자가 U라는 질문을 했다면, DB에서 U와 가장 비슷한 질문 Q를 찾습니다. 그리고 거기에 해당하는 대답 A를 출력합니다. 이런 유사도는 자카드 유사도(Jaccard similarity)처럼 문자열 단위로 비교할 수도 있습니다. 하지만 신경망에서는 무조건 벡터 단위로 처리해야 합니다.

 

문장을 벡터로 표현하는 가장 간단한 방법은 BoW(Bag of Words)입니다. OHE(One Hot Encoding)과 거의 유사하지만 문장안에 있는 모든 단어를 하나의 벡터로 나타낼 수 있습니다. 이때 벡터의 차원은 단어사전의 개수입니다. 전체 코퍼스의 단어가 1만개라면 1만차원의 벡터가 됩니다. 각 차원의 위치는 하나의 단어와 매칭됩니다. 처음에는 벡터를 모두 0으로 초기화 하고, 문장에 나온 모든 단어의 차원에 1을 넣습니다. 보통 다음과 같이 표현됩니다.

 

(0, 1, 1, 0, 0, 0, ... , 0, 1, 0)

 

중복을 허용해도 됩니다. 한 문장에 같은 단어가 여러번 나오면 그 숫자만큼 차원의 위치에 넣습니다. 계속 반복되는 단어는 그만큼 더 중요하다는 의미가 됩니다.

 

(0, 1, 5, 0, 0, 2, ... , 0, 1, 0)

 

하지만 BoW는 큰 단점이 있습니다. 반복되는 단어가 다른 문장들에도 흔하게 나오는 것이라면, 오히려 그 문장만의 차별성이 사라지게 됩니다. TF-IDF는 이런 문제점을 조금 완화시켜 줍니다. 흔한 단어들은 수치를 낮춰 특징을 떨어뜨리고, 그 문장에만 나오는 독특한 단어들은 수치를 높여 문장 구분이 더 잘되게 합니다.

 

 

 

Word2Vec이나 GloVe 같은 단어 임베딩으로 문장 벡터를 만드는 것도 가능합니다. 문장의 각 단어를 임베딩으로 변환하고 모두 합하여 평균을 냅니다. 이렇게 하면 하나의 벡터로 문장을 나타낼 수 있습니다. BERT도 비슷한 방법을 씁니다. 문장을 입력에 넣고 출력으로 나온 각 토큰의 벡터를 평균냅니다. 또는 분류를 위해 사용되는 가장 앞의 CLS 토큰만 쓰기도 합니다. 그러나 실험 결과를 보면 BERT 평균값이나 CLS 토큰을 사용했을 때, GloVe 평균값을 썼을 때보다 오히려 정확도가 더 낮다고 합니다.

 

이런 BERT의 문장 임베딩을 더 강화한 것이 Sentence-BERT입니다. 기존 사전훈련된 BERT를 별도의 모델 구조로 다시 훈련시킵니다. 이렇게 한번 파인튜닝을 거치면 문장의 임베딩 성능이 훨씬 높아집니다. 카카오브레인에서 공개한 Pororo에도 문장 임베딩 기능이 있습니다. 몇 줄의 코드만으로 간단하게 문장을 벡터로 변환할 수 있습니다.

 

https://kakaobrain.github.io/pororo/text_cls/sent2vec.html

 

엮인글 :
List of Articles
제목 글쓴이 날짜sort 조회 수
최신 자연어처리 모델 소개 file 깊은바다 2022-07-11 1180
러시아의 구글 얀덱스, 100B 초거대모델 무료 공개 깊은바다 2022-06-26 806
구글의 초거대모델 PaLM의 추론과 상식 능력 file 깊은바다 2022-05-20 838
글자, 사진, 영상을 동시에 처리하는 딥마인드의 딥러닝 모델 - Flamingo file 깊은바다 2022-05-10 1434
메타, GPT-3와 동급인 175B의 초거대모델 무료 공개 깊은바다 2022-05-04 1191
GPT-3보다 3배 더 큰 구글의 초거대모델, PaLM file 깊은바다 2022-04-07 1408
초거대모델의 파인튜닝 방법 - P-tuning과 LoRA file 깊은바다 2022-04-05 12115
교육용 챗봇의 미래!? 구글 람다 (LaMDA) 깊은바다 2022-03-11 1362
하이퍼클로바 활용예 및 사용가이드 file 깊은바다 2022-03-05 3570
네이버의 초거대모델인 하이퍼클로바 사용 후기 깊은바다 2022-02-14 3170
구글의 대화기반 초거대모델 LaMDA, 논문 공개 file 깊은바다 2022-02-08 1361
프로그램을 작성하는 딥마인드의 알파코드 file 깊은바다 2022-02-04 1005
GPT-3를 강화학습으로 업그레이드한 InstructGPT file 깊은바다 2022-01-30 2569
DALL-E를 능가하는 OpenAI의 GLIDE 깊은바다 2021-12-27 838
검색기반 거대모델인 딥마인드의 RETRO 깊은바다 2021-12-20 511