작성자: 16기 이승주
Contents
1. Starting Research
2. Review of Gated Neural Sequence Models
3. MT Topics
4. Research Evaluation, others
5. References
SQuAD question answering이 기본 final project이고 자유 주제도 가능하며 1 ~ 3명의 인원으로 진행하는 프로젝트이다. 언어나 프레임워크의 제한은 없다고 한다.
- 모델의 application을 찾아보고 어떻게 효율적으로 적용할 지 찾는 연구
- 복잡한 neural architecture을 구현해보고 특정 데이터에 대한 성능을 평가하는 연구
- 새롭거나 변형된 NN 모델을 구상 후 구현하여 성능 향상을 보여주는 연구
- 새로운 연구
- 모델의 동작법을 분석하는 연구
모델의 application을 찾아보고 어떻게 효율적으로 적용할 지 찾는 연구
https://web.stanford.edu/class/archive/cs/cs224n/cs224n.1174/reports/2762063.pdf
복잡한 neural architecture을 구현해보고 일부 데이터에 대한 성능을 평가하는 연구
https://web.stanford.edu/class/archive/cs/cs224n/cs224n.1174/reports/2753780.pdf
새롭거나 변형된 NN 모델을 구상 후 구현하여 성능 향상을 보여주는 연구
https://cs224d.stanford.edu/reports/InanKhosravi.pdf
새로운 연구
https://web.stanford.edu/class/archive/cs/cs224n/cs224n.1184/reports/997.pdf
- 논문을 열심히 읽는다.
- NLP논문에 대한 ACL Anthology 참조
- 주요 ML 컨퍼런스들의 논문들을 참조(NeurIPS, ICML, ICLR...)
- 기존 프로젝트 참조
- 출판 전 논문 본다. (http://arxiv.org)
적절한 데이터를 찾는것이 중요하다. ( 최소 10,000개의 레이블된 데이터)
- 기존의 프로젝트에서 구한 데이터 / 기업에서 갖고 있는 데이터
- 실행가능한, 적절한 Task를 찾는것도 중요하다.
- 공개되고, 잘 관리된 dataset 활용하기
Task를 찾으면 이를 평가할 수 있는 자동화된 metric도 있어야함
http://catalog.ldc.upenn.edu/
https://linguistics.stanford.edu/resources/resources-corpora
http://statmt.org
https://universaldependencies.org
온라인에는 더 많은 데이터 셋들이 존재한다.
- 캐글
- 기존 연구 논문에 있는 데이터
- NLP 데이터셋을 모아둔 곳
https://machinelearningmastery.com/datasets-natural-language-processing/
https://github.com/niderhoff/nlp-datasets
- 수동
Adaquacy and fluency
오류 분석
번역 순위 메기기- 자동
BLEU(bilingual evaluation understudy)
BLEU score란 기계 번역 결과와 사람이 직접 번역한 결과가 얼마나 유사한지 비교하여 번역에 대한 성능을 측정하는 성과지표이다. 데이터의 X가 순서정보를 가진 단어들로 이루어져 있고, y또한 단어들의 시리즈(문장)로 이루어진 경우에 사용되며 3가지 요소는 아래와 같다.
보통 Blue4를 활용하는데 n-gram 길이가 4까지 계산한다.
4단어 미만 문장은 bleu 0점.
아래 예시의 bleu score를 계산하면 다음과 같다.
- Define Task
- Define Dataset (Summarization이라는 task을 정하자)
- Dataset hygiene (Dataset을 정하자)
- Define your metric (평가 metric을 정하자)
- Establish a baseline (Baseline을 정하자)
- Implement existing neural net model
- Always be close to your data
visualize the dataset
collect summary datset
look at erros
analyze how different hyperparameters affect performance- Try out different models and model variants Aim to iterate quickly via having a good experimental setup (다른 시도도 많이 하자)
- Many publicly available datasets are released with a train/dev/test structure. We're all on the honor system to do test-set runs only when development is complete.
: (보통 데이터셋은 Train/dev/test 데이터셋이 있다. 연구자 윤리를 위해서 개발이 끝난 후에만 test set을 사용하자.)- Splits like this presuppose a fairly large dataset.
: (이렇게 분리하면 데이터셋이 꽤 크다)- If there is no dev set or you want a separate tune set, then you create one by splitting the training data, though you have to weigh its size/usefulness against the reduction in train-set size. Having a fixed test set ensures that all systems are assessed against the same gold data. This is generally good, but it is problematic where the test set turns out to have unusual properties that distort progress on the task.
: (만약 데이터 셋이 없으면 알아서 분리해라. 이렇게 데이터 셋을 분리하면 모든 사람들이 같은 데이터를 가지고 평가를 진행해서 좋지만 만약 하나의 데이터셋에만 이상값들이 많이 존재하면 문제가 생길 수 있다.)- You build (estimate/train) a model on a training set.
: (Training set에서 트레이닝을 진행한다.)- Often, you then set further hyperparameters on another,independent set of data, the tuning set
The tuning set is the training set for the hyperparameters!
: (Tuning set에서 하이퍼파라미터 튜닝을 한다.)- You measure progress as you go on a dev set (development test set or validation set)
If you do that a lot you overfit to the dev set so it can be good to have a second dev set, the dev2 set
: (Dev set에서 트레이닝이 잘되었는지 확인한다. 단 dev set을 많이 쓰면 오버피팅이 있을 수 있다.)- Only at the end, you evaluate and present final numbers on a test set
: (마지막에만 test set을 쓴다. 한두번만 쓰는게 좋다고 한다.)
Use the final test set extremely few times … ideally only once
: (모든 데이터 셋들은 독립적이어야 한다.)
- Use an LSTM or GRU: it makes your life so much simpler!
(LSTM 또는 GRU를 사용하자)- Initialize recurrent matrices to be orthogonal (recurrent matrices을 직교하게 초기화하자)
- Initialize other matrices with a sensible (small!) scale (다른 행렬들을 small scale로 초기화하자)
- Initialize forget gate bias to 1: default to remembering (forget gate bias 를 1로 두자.)
- Use adaptive learning rate algorithms: Adam, AdaDelta, …
- Clip the norm of the gradient: 1–5 seems to be a reasonable threshold when used together with Adam or AdaDelta.(1부터 5가 적당한 threshold이다.)
- Either only dropout vertically or look into using Bayesian Dropout (Gal and Gahramani – not natively in PyTorch) (dropout을 vertical하게 사용하거나, Bayesian Dropout을 사용하자)
- Be patient! Optimization takes time (학습은 인내심을 갖고 기다리자)
- Work incrementally! (점진적으로 한단계씩 연구를 진행하는게 좋다.)
- Start with a very simple model and get it to work (처음에는 아주 간단한 모델에서 부터 시작하자)
- Add bells and whistles one-by-one and get the model working with each of them (or abandon them) (그 다음에 간단한 모델에 점차 많은 것들을 추가하며 학습하자.)
- Initially run on a tiny amount of data (처음엔 아주 작은 데이터 셋으로 학습해보자)
You will see bugs much more easily on a tiny dataset
Something like 8 examples is good
Often synthetic data is useful for this (인위적으로 제작한 데이터도 좋다.)
Make sure you can get 100% on this data
Otherwise your model is definitely either not powerful enough or it is broken- Run your model on a large dataset (데이터 셋의 크기를 점차 키우자.)
- It should still score close to 100% on the training data after optimization (데이터 셋을 키우고 100프로에 가까운 정확도가 나와야한다)
Otherwise, you probably want to consider a more powerful model (만약 100프로 정확도 달성이 안되면 모델을 바꿔봐라)
Overfitting to training data is not something to be scared of when doing deep learning (딥러닝에서는 training set의 오버피팅은 괜찮다.)
These models are usually good at generalizing because of the way distributed representations share statistical strength regardless of overfitting to training data- But, still, you now want good generalization performance:
Regularize your model until it doesn’t overfit on dev data
Strategies like L2 regularization can be useful
But normally generous dropout is the secret to success
- Look at your data, collect summary statistics
- Look at your model’s outputs, do error analysis (모델의 출력값을 보고 오류 분석을 진행하자)
- Tuning hyperparameters is really important to almost all of the successes of NNets (하이퍼 파라미터 튜닝은 성공적인 NNets 모델에 아주 중요한 요소 중 하나이다.)