Skip to content

Latest commit

 

History

History
181 lines (110 loc) · 8.2 KB

README.md

File metadata and controls

181 lines (110 loc) · 8.2 KB

针对 LCSTS 的数据预处理

执行如下命令可以对 LCSTS 的数据进行处理

python2 data/make_datafiles_lcsts_remake.py /DATASETS/datasets/LCSTS_ORIGIN/DATA/

文件默认输出于 finaldata_files 中,若要修改文件输出位置可以在 data/make_datafiles.py 中修改变量 finished_files_dir

针对中文的特殊处理

  • 为了避免 pyrouge 无法处理中文内容,将中文转换为了整数,不同字/词间用空格隔开。在 make_datafiles_lcsts_remake.py 中修改变量 read_charc_type 可以控制中文是按照词划分或逐字划分

  • 整数与中文对应词典被保存在 char2int.pkl int2cahr.pkl 中,前者为字典,用于查询文本对应整数;后者为列表,用于查询整数对应文本

  • 若希望使用 CoreNLP 做中文分词,需要使用 CoreNLP 的 server 模式,具体操作方法可以参考 相关文档

其他说明

  • 为了尽可能与原本 make_datafiles 兼容,尽可能使用了原本文件中的相关处理函数。但是还是有对该文件做简单修改,可以在该文件中搜索 modify 注释信息查看

  • 在数据预处理完毕后,需要修改 scripts 目录下各脚本中,数据所在位置,并依次执行 selector(train&eval),rewriter,end2end

  • 在 end2end 的脚本 scripts/end2end.sh 中,注释掉了参数中的预训练模型 checkpoint 路径。这是因为如果不手动指定,模型会选择默认路径下最新的预训练模型 为了方便调试,在调试过程中注释了相关内容

  • make_datafiles_lcsts_remake.py 文件中的中文注释内容可能与实际情况不符(尤其是生成器函数)

Unified Summarization

This is the official codes for the paper: A Unified Model for Extractive and Abstractive Summarization using Inconsistency Loss.

Requirements

Note: Stanford CoreNLP 3.7.0 can be downloaded from here.

Note: To use ROUGE evaluation, you need to download the ROUGE-1.5.5 package from here. Next, follow the instrunction from here to install pyrouge and set the ROUGE path to your absolute path of ROUGE-1.5.5 directory.

Error Handling: If you encounter the error message Cannot open exception db file for reading: /path/to/ROUGE-1.5.5/data/WordNet-2.0.exc.db when using pyrouge, the problem can be solved from here.

CNN/Daily Mail dataset

Codes for generating the dataset is in data folder.

We modified the preprocessing code from this repository.

You can use our preprocessing codes (data/make_datafiles.py and data/rouge_not_a_wrapper.py) and follow their instrunctions of Option 2 to obtain the preprocessed data for our model.

How to train

Use the sample scripts in scripts folder.

I will use ${XXX} to indicates the value you set in the script for the variable XXX.

Pretrain the exatrctor

sh scripts/selector.sh

The trained models will be saved in log/selector/${EXP_NAME} directory.

Pretrain the abstracter

sh scripts/rewriter.sh

The trained models will be saved in log/rewriter/${EXP_NAME} directory.

End-to-end training the unified model

Set the path of pretrained extractor and abstractor to SELECTOR_PATH and REWRITER_PATH in the script.

sh scripts/end2end.sh

The trained models will be saved in log/end2end/${EXP_NAME} directory.

Note: In our paper, we use the best extractor model on validation set for the pretrained extractor and the last abstracter model (after training with coverage mechanism for 1k iterations) for the pretrained abstracter in end-to-end training.

How to evaluate (concurrent)

To evaluate the model during training, change the MODE in the script to eval (i.e., MODE='eval') and run the script simutanously with train script (i.e., MODE='train'). This script will keep testing the latest training model and save the model as a new best model if the evaluation result is better than the previous best model.

For evaluating the abstracter and the unified model, you can choose to evaluate the loss or ROUGE scores. Just switch the EVAL_METHOD in the script between loss and rouge.

For the ROUGE evaluation, you can use greedy search or beam search. Just switch the DECODE_METHOD in the script between greedy and beam.

We highly recommend you to use greedy search for concurrent ROUGE evaluation since greedy search is much faster than beam search. It takes about 30 minutes for greedy search while 7 hours for beam search on CNN/Daily Mail test set.

The current best models will be saved in log/${MODEL}/${EXP_NAME}/eval(_${EVAL_METHOD}).

How to evaluate with ROUGE on test set

Change the MODE in the script to evalall (i.e., MODE='evalall') and set CKPT_PATH as the model path that you want to test.

If you want to use the best evaluation model, set LOAD_BEST_EVAL_MODEL as True to load the best model in eval(_${EVAL_METHOD}) directory. The default of LOAD_BEST_EVAL_MODEL is False.

If you didn't set the CKPT_PATH or turn on LOAD_BEST_EVAL_MODEL, it will automatically load the latest model in train directory.

The evalutation results will be saved under your experiment directory log/${MODEL}/${EXP_NAME}/.

Expected results

By following the scripts we provided, you should get comparable performance as below:

Extractor (best evaluation model)

ROUGE-1 recall ROUGE-2 recall ROUGE-L recall
73.5 35.6 68.6

Abstracter (model of 81000 iteration)

ROUGE-1 F-1 score ROUGE-2 F-1 score ROUGE-L F-1 score
   45.4     21.8     42.1

Unified model with inconsistency loss (best evaluation model)

ROUGE-1 F-1 score ROUGE-2 F-1 score ROUGE-L F-1 score
   40.68     17.97     37.13

Note: Our abstracter takes ground-truth extracted sentences as input when both training and testing, so the ROUGE F-1 scores are higher than the unified model.

Our pretrained models

We provide our pretrained models as the following:

If you want to get the results of the pretrained models, set two arguments in the scripts:

  1. set the MODE to evalall (i.e., MODE='evalall').
  2. set the CKPT_PATH to our pretrained model (e.g., CKPT_PATH="pretrained/bestmodel-xxxx").

Our test set outputs

Test set outputs of our unified model can be downloaded from here.

Each pickle file (e.g., result_000000.pkl) contains the output of one article.

The output format is a dictionary:

{
    'article': list of article sentences,
    'reference': list of reference summary sentences,
    'gt_ids': indices of ground-truth extracted sentences,
    'decoded': list of output summary sentences
}

Citation

If you find this repository useful, please cite:

@InProceedings{hsu2018unified,
  title={A Unified Model for Extractive and Abstractive Summarization using Inconsistency Loss},
  author={Hsu, Wan-Ting and Lin, Chieh-Kai and Lee, Ming-Ying and Min, Kerui and Tang, Jing and Sun, Min},
  booktitle={Proceedings of the 56th Annual Meeting of the Association for Computational Linguistics (Volume 1: Long Papers)},
  year={2018}
}