Skip to content

nlpersECJTU/NLP-Projects-For-Beginner

Repository files navigation

Projects-For-NLP-Bigenner

Typical projects for NLP beginners.

Environment

Python 3.8
PyTorch 1.0 or above

Tutorial

P1 Word Embeddings

Learning Word Embeddings

  • Paper1: Distributed Representations of Words and Phrases and their Compositionality (NIPS 2013)
  • Paper2: Learning Sentiment-Specific Word Embedding for Twitter Sentiment Classification (ACL 2014)
  • Paper3: Improving Implicit Discourse Relation Recognition with Discourse-specificWord Embeddings (ACL 2017)
  1. SimpCBOW: Learning general word embeddings based on unlabeled data using the CBOW model in Paper 1 (simplified here, just for demo).
  2. DSWE: Learn task-specific word embedding via the Connective classification task as that in Paper 3, the labeled data is necessary. DSWE is inspired by the model in Paper2, which is proposed to learn the sentiment-specific word embeddings.
  3. Data: https://pan.baidu.com/s/12uqXtjCBud0-A9Ilda1kOg?pwd=324q, password: 324q https://drive.google.com/file/d/1SeC3OcGI5MZh2G8oF5mTm1KP0OJUwhsQ/view?usp=sharing
  4. Result (call distance.py to show the top-n most similar words). The most similar words in CBOW and DSWE to 'not', 'good' and 'apple' are shown, respectively.

SimpCBOW DSWE

DSWE DSWE

P2 Text Classification

Document-level Sentiment Classificaiton

  • Paper1: Hierarchical Attention Networks for Document Classification (NAACL 2016)
  • Paper2: Learning Semantic Representations of Users and Products for Document Level Sentiment Classification (ACL 2015)
  • Paper3: Improving Review Representations with User Attention and Product Attention for Sentiment Classification (AAAI 2018)
  • Web: https://blog.csdn.net/malefactor/article/details/78767781 (注意力机制)
  1. Hierarchical Attention Model without User and Product Attributes (HAN, Paper1) : SentimentUP/HAN.
  2. Hierarchical Attention Model With User and Product Attributes (HAN_UP, Paper3) : SentimentUP/HAN_UP. Different from the model in Paper3, we leverage User and Prodcut attributes in different ways. Specifically, the User attribute is incorporated at word-level, sentence-level and document level in a fusion way, while the Product attribute is incorporated into word-level and sentence-level attention mechanisms following AAAI 2018.
  3. Data: the Yelp 2013, Yelp 2014, IMDB datasets are provided by authors of Paper2.
  4. Word embeddings: provided by authors of Paper3
  5. Download data and embeddings: https://drive.google.com/file/d/18dXcCXl5txAf-WaxlXgyuPVdUkbXCkmF/view?usp=sharing
  • ACC Results
Model IMDB Yelp 2013 Yelp 2014
HAN 48.4 64.5 65.1
AAAI 2018 55.0 68.3 68.6
HAN_UP 56.6 68.9 69.2

P3 NER&Event

Chinese Named Entity Recognition

  1. BERT + Softmax (Paper1): simply stack a Softmax layer on outputs of BERT for Chinese NER.
  2. BERT + CRF (Paper1): a classific model, using a neural CRF layer to model the dependence of labels (B-PER is usually followed by I-PER).
  3. BERT + Span (Paper2): check out the begin labels and end labels respectively, then pair the nearest begin label and end label with the same entity type as an entity.
  4. BERT + Word-Word (Paper3): https://github.com/ljynlp/W2NER
  • F1 Results (entity)

    Model Resume ClueNer(dev) Weibo
    BERT + Softmax 95.54 78.51 48.58
    BERT + CRF 95.33 78.63 50.22
    BERT + Span 95.97 79.98 51.13

Note that, the F1 results on ClueNer and Weibo are not comparable with the F1 scores reported in recent Papers.

P4 Parser

Dependency Parser

  • Paper1: Simple and Accurate Dependency Parsing Using Bidirectional LSTM Feature Representations (TACL 2016)
  • Paper2: Transition-Based Dependency Parsing with Stack Long Short-Term Memory (ACL 2015)
  • Paper3: Deep biaffine attention for neural dependency parsing (ICLR 2017)
  1. Transition-based model (Paper1): Dependency Parser/transition-parser
  2. Graph-based model (Paper1): Dependency Parser/graph-parser
  3. Data: https://drive.google.com/file/d/1z8Q-dIgqJSA4sWC69AXxJjY3VLtLWdeJ/view?usp=sharing, https://pan.baidu.com/s/121FYYpPqPNHj6wG9EFvFkA password: 6mdh
  4. Reference: https://github.com/elikip/bist-parser/
  • UAS and LAS Results
Model (en-ud-proj) UAS (dev) LAS (dev) UAS (test) LAS (test)
Transition 87.51 85.19 87.27 84.89
Graph 88.25 86.06 87.97 85.82
Model (en-universal) UAS (dev) LAS (dev) UAS (test) LAS (test)
Transition 92.00 90.35 91.99 90.47
Graph 92.32 90.80 92.41 90.92
Model (zh-ud-proj) UAS (dev) LAS (dev) UAS (test) LAS (test)
Transition 81.81 78.55 84.11 80.91
Graph 82.59 79.47 85.02 82.00

As previous studies shown, the Graph-based methods are usually better than the Transition-based methods.

P5 Seq2Seq

Machine Translation

  1. Most of our code is borrowed from Reference2 (Paper2)
  2. The 'beam_search' method in decode.py is borrowed from Reference 1
  3. Data: PyTorch 自带的 Multi30k 数据集
  4. Reference1: https://zhuanlan.zhihu.com/p/114669778 (Beam Search)
  5. Reference2: https://github.com/hyunwoongko/transformer (主要参考这个代码)
  6. Reference3: https://github.com/hemingkx/ChineseNMT (有比较详细的注释,还有多GPU训练)
  • BLEU Scorces on Multi30k (en_de)
Model (beam_size = 3) Dev Test
Transformer + Greedy (batch_size=64) 33.06 32.90
Transformer + Beam (batch_size=64) 34.48 33.85
Transformer + Greedy (batch_size=128) 36.88 35.61
Transformer + Beam (batch_size=128) 37.66 37.07
Transformer + Greedy (batch_size=256) 38.62 37.59
Transformer + Beam (batch_size=256) 39.65 37.57

It seems that both 'larger batch size' and 'Beam Search' are helpful.

Transformer + Beam (batch_size=256) Dev Test
beam_size = 3 39.65 37.57
beam_size = 4 39.60 38.63
beam_size = 5 39.60 38.23
beam_size = 6 39.59 38.13

It seems that the larger 'beam size' is also helpful, and we achieve the best Test bleu score when beam_size = 4.