Skip to content

The official code of the 2023 ACL paper "Enhancing Grammatical Error Correction Systems with Explanations"

Notifications You must be signed in to change notification settings

lorafei/Explainable_GEC

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Explainable Grammmar Error Correction

This repository provides the dataset and code for the explainable grammmar error correction task as reported in this paper:

Enhancing Grammatical Error Correction Systems with Explanations

Yuejiao Fei∗, Leyang Cui†, Sen Yang, Wai Lam, Zhenzhong Lan, Shuming Shi

2023 The 61st Annual Meeting of the Association for Computational Linguistics(ACL)(Oral)(PDF)

🚀Introduction

To help language learners understand why the Grammmar Error Correction system makes a certain correction, we present EXPECT, a large dataset with evidence words and grammatical error types labeled.

We also put forward several robust benchmarks for this task.

📄Examples

Examples of each error type and corresponding evidence words in EXPECT.

📉Dataset Statistics

Train Dev Test Outputs
Number of sentences 15,187 2,413 2,416 1001
Number of words 435,503 70,111 70,619 27,262
Avg. w.p.s 28.68 29.06 29.23 27.23
With evidence rate 74.15 59.10 59.77 72.73
Total evidence words 29,187 4,280 4,340 1736
Avg. evidence w.p.s 2.59 3.00 3.01 2.38

📝 Dataset Description

data/json/train.json is the training set. data/json/dev.json and data/json/test.json are the dev set and test set, which are splited from the dev set of W&I+LOCNESS. The format of the samples is shown below:

{
"target": ["It", "has", "a", "high", "-", "density", "population", "because", "of", "its", "small", "territory", "."], 
"source": ["It", "has", "a", "high", "-", "density", "population", "because", "[NONE]", "its", "small", "territory", "."], 
"correction_index": [8, 22], 
"evidence_index": [7, 9, 10, 11, 21, 23, 24, 25], 
"error_type": "Preposition", 
"predicted_parsing_order": {"1": 3, "5": 2, "7": 2, "8": 1, "9": 3, "10": 2, "15": 3, "19": 2, "21": 2, "22": 1, "23": 3, "24": 2}, 
"origin": "A"
}
  1. "target" is the corrected sentence, with the corrected words indexed with "correction_index".
  2. "source" is the erroneous sentence, with the erroneous words also indexed with "correction_index".
  3. "correction_index" is the index of corrected and erroneous words, where the target and source sentences are concatenated with a separation token in between.
  4. "evidence_index" is the index of evidence words for both the target and source sentences, where the target and source sentences are concatenated with a separation token in between.
  5. "error_type" is the class of the error type.
  6. "predicted_parsing_order" represents first-order dependent words (Number 2) and second-order dependent words (Number 3) in the dependency parse tree. Number 1 represents the position of the corrections.
  7. "origin" is the learner's CEFR proficiency, which corresponds to W&I+LOCNESS.

📥 How to Use the Data

We provide a script for processing the raw data into NER input format. Specify data_file and save_file in read_jsonl.py .

python read_jsonl.py --data_file data/json/test.json --save_file data/ner/train.pkl

And use the processed data as the input of the model.

📈 Train and Evaluate Models

  1. To train and evaluate Labeling-based Error+Correction model
python run.py cfgs/train_error_correction.py
python run.py cfgs/eval_error_correction.py
  1. To train and evaluate Labeling-based Error+Correction+CE model
python run.py cfgs/train_error_correction_ce.py
python run.py cfgs/eval_error_correction_ce.py
  1. To train and evaluate Labeling-based Error+Correction+CE+Syntax model
python run.py cfgs/train_error_correction_ce_syntax.py
python run.py cfgs/eval_error_correction_ce_syntax.py

📜 License

This dataset is released under the MIT License.

📚 Citation

If you use this dataset in your research, please cite it as follows:

@inproceedings{fei-cui-2023-enhancing,
title = "Enhancing Grammatical Error Correction Systems with Explanations",
author = “Fei, Yuejiao  and
   Cui, Leyang and
   Yang, Sen and
   Lam, Wai and
   Lan, Zhenzhong and
   Shi, Shuming”,
month = jul,
year = "2023”,
address = “Toronto, Canada”,
publisher = "Association for Computational Linguistics",
}

About

The official code of the 2023 ACL paper "Enhancing Grammatical Error Correction Systems with Explanations"

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages