Skip to content

NLP models for Custering and NER, Sentiment classification

Notifications You must be signed in to change notification settings

WordWarrior-NLP/Kordata-nlp-models

Repository files navigation

Kordata-nlp-models

NLP models for Clustering, Extracting keywords, Connecting clusters, NER, and Sentiment classification


Issue

  • 본 프로젝트에서 Mecab는 Google Colab 환경을 기준으로 구동되었음.
  • Mecab는 window 환경에서 구동되지 않음.
  • Mecab가 사용된 코드는 이탤릭체로 표시.

Dataset

NaverNewsScraping

  • 코드 파일: naverscrapingnews1.py
  • 매일 오전 10시에 전날의 뉴스를 수집.
  • 네이버 뉴스의 정치 섹션 뉴스를 수집.

PreSum

  • 코드 파일: PreSum.ipynb
  • v1.0:
    • 포토 기사는 수집하지 않는다.
    • summary: 기사 본문 중 가장 기사 제목과 유사한 세 문장을 추출하여 요약. SentenceTransformer로 벡터화, cosine similarity 계산
    • pre_main_text: 특수문자를 제거하고 '%'는 '퍼센트'로 바꿔준다.
  • v1.1 (2023/07/30): reporter, photo 추가
    • reporter: 기자 이름
    • photo: 사진 유무 (True or False)
    • main_text: 기사 부제가 중복되게 추가되지 않도록 수정
  • v1.2 (2023/08/07): 사회면 기사 수집
    • 멀티사회기사긁어오기

SaveToDB

  • 코드 파일: SaveToDB.ipynb
  • DB에 저장시 중복 저장을 피하기 위해 INSERT IGNORE 사용.
  • photo 컬럼은 8월 10일부터 available.

Clustering

  • 코드 파일: kpfSBERT_clustering.ipynb
  • model: KPF-SBERT로 임베딩
  • 매일 수집한 기사의 summary를 SBERT embedding을 통해 벡터화하고, umap을 통해 차원 축소 (n_components = 10)
  • 이후 HDBSCAN으로 클러스터링 (min_cluster_size = 5, min_sample = 3)

Extracting keywords per cluster

  • 코드 파일: kpf_keybert.py
  • model: KPF-SBERT로 임베딩
  • 클러스터별 키워드 추출
  • v1.0(2023-08-20)
    • 기사 제목에서 기사 제목과 유사도가 높은 키워드를 추출
    • 키워드의 다양성을 높이기 위해 MMR (Maximum Marginal Relevance) 기법을 사용
  • v1.1(2023-08-21)
    • 불용어 목록 수정 (안해, 않았어야 등)
  • v1.2(2023-08-22)
    • 불용어 목록 수정 (vs, 안돼 등)
    • 에러 수정
  • v1.3(2023-08-23)
    • 불용어 목록 수정 (없어 등)
    • 숫자로만 이루어진 키워드는 제외

Choose best title per cluster

  • 코드 파일: kpfSBERT_clustering.ipynb
  • 클러스터별 키워드가 가장 많이 포함된 기사의 제목을 클러스터별 대표 기사 제목으로 채택
  • 이후 연결될 클러스터들끼리 정렬하여 가장 최근 클러스터의 대표 기사 제목을 사건의 소제목으로 활용함

SaveToDB_clustering

  • 코드 파일: SaveToDB_clustering.ipynb
  • 클러스터링 결과를 DB에 저장

Connecting clusters & Issuing a new event

initial

  • 코드 파일: ConnectingClusters.ipynb
  • model: KPF-SBERT로 임베딩
  • 기준 날짜로부터 가장 최근의 20개 클러스터들의 키워드와 비교해서 코사인 유사도가 임계치를 넘으면 과거의 클러스터와 같은 사건이라고 판단하고, 동일 사건으로 묶이도록 함
  • 임계치를 넘지 못할 경우 새로운 사건으로 판단하여 발행함

Naming a new event

  • 코드 파일: BranchingEntropy.py
  • Branching Entropy 이용
  • 클러스터로 묶인 기사별 요약에서 명사만 추출하여 사건 이름으로 작성
  • 등장 빈도가 높은 순, Branching Entropy 점수가 낮은 순, 문자 길이가 긴 순의 3가지 기준을 차례로 적용한 후, 상위 3개의 단어를 골라 사건 이름으로 선정

Named Entity Recognition

  • 코드 파일: ner_module.ipynb
  • model: KPF-BERT-NER,Tokenizer: KPFbert
  • NER 다음 BIO태깅을 사용하여 I-name + I-position인 이름+직책, 기관(OGG)를 사용
  • 자카드 유사도를 사용하여 임계치를 0.6 < i <1.0 으로 설정하고 유사한 딕셔너리 추출
  • 딕셔너리의 쌍이 맞는 경우 추출 e.g. 문 대통령 - 문재인 대통령 , 문재인 대통령- 문 대통령 -> 문재인 대통령 - 문대통령
  • 기사의 특성상 풀네임이 먼저 언급되고 약어가 사용됨 더 긴 글자가 대표하는 단어가 된다고 판단 (최장일치법) e.g. 윤석열 대통령 - > 윤 대통령
  • 토크나이저로 인해서 NER의 결과가 잘못된 것 (e.g. 재명더불어민주당)은 summary에서 실제로 그 개체가 있는지 확인 후 없을 경우 동의어에서 제거
  • 이렇게 전처리를 진행 한 후 날짜별로 클러스별 상위 주체 5개를 뽑은 후, 동의어를 main_word에 대치 후 형식을 맞춰 (word, nc_id, label, desc, nid, datetime, main_word) DB에 저장

Target Sentiment Analysis

  • 코드 파일: SA_dict.ipynb
  • PMI 이용
  • 주체명이 형태소 분석되지 않도록 (e.g. 국민의힘 -> 국민, 의, 힘) 모든 주체명을 사용자 정의 사전에 추가해야 함. (mecab_install.sh 파일 참고)
  • 긍정 체언 감성 사전과 부정 체언 감성 사전을 각각 체언 20개로 구축함.
  • NER의 결과인 개체들과 그 개체들이 등장한 문장들을 input으로, PMI 행렬을 구성.
  • PMI 행렬에서 긍/부정 단어와 주체 간의 PMI 수치를 계산하여, 0보다 작을 경우 주체가 뉴스에서 부정적으로 다루어졌음을, 0보다 클 경우 주체가 뉴스에서 긍정적으로 다루어졌음을 표현함.

About

NLP models for Custering and NER, Sentiment classification

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •