| --- |
| language: en |
| datasets: |
| - conll2003 |
| license: mit |
| model-index: |
| - name: dslim/bert-base-NER |
| results: |
| - task: |
| type: token-classification |
| name: Token Classification |
| dataset: |
| name: conll2003 |
| type: conll2003 |
| config: conll2003 |
| split: test |
| metrics: |
| - name: Accuracy |
| type: accuracy |
| value: 0.9118041001560013 |
| verified: true |
| - name: Precision |
| type: precision |
| value: 0.9211550382257732 |
| verified: true |
| - name: Recall |
| type: recall |
| value: 0.9306415698281261 |
| verified: true |
| - name: F1 |
| type: f1 |
| value: 0.9258740048459675 |
| verified: true |
| - name: loss |
| type: loss |
| value: 0.48325642943382263 |
| verified: true |
| --- |
| # bert-base-NER |
|
|
| If my open source models have been useful to you, please consider supporting me in building small, useful AI models for everyone (and help me afford med school / help out my parents financially). Thanks! |
|
|
| <a href="https://www.buymeacoffee.com/dslim" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/arial-yellow.png" alt="Buy Me A Coffee" style="height: 60px !important;width: 217px !important;" ></a> |
|
|
| ## Model description |
|
|
| **bert-base-NER** is a fine-tuned BERT model that is ready to use for **Named Entity Recognition** and achieves **state-of-the-art performance** for the NER task. It has been trained to recognize four types of entities: location (LOC), organizations (ORG), person (PER) and Miscellaneous (MISC). |
|
|
| Specifically, this model is a *bert-base-cased* model that was fine-tuned on the English version of the standard [CoNLL-2003 Named Entity Recognition](https://www.aclweb.org/anthology/W03-0419.pdf) dataset. |
|
|
| If you'd like to use a larger BERT-large model fine-tuned on the same dataset, a [**bert-large-NER**](https://huggingface.co/dslim/bert-large-NER/) version is also available. |
|
|
| ### Available NER models |
| | Model Name | Description | Parameters | |
| |-------------------|-------------|------------------| |
| | [distilbert-NER](https://huggingface.co/dslim/distilbert-NER) **(NEW!)** | Fine-tuned DistilBERT - a smaller, faster, lighter version of BERT | 66M | |
| | [bert-large-NER](https://huggingface.co/dslim/bert-large-NER/) | Fine-tuned bert-large-cased - larger model with slightly better performance | 340M | |
| | [bert-base-NER](https://huggingface.co/dslim/bert-base-NER)-([uncased](https://huggingface.co/dslim/bert-base-NER-uncased)) | Fine-tuned bert-base, available in both cased and uncased versions | 110M | |
|
|
|
|
| ## Intended uses & limitations |
|
|
| #### How to use |
|
|
| You can use this model with Transformers *pipeline* for NER. |
|
|
| ```python |
| from transformers import AutoTokenizer, AutoModelForTokenClassification |
| from transformers import pipeline |
| |
| tokenizer = AutoTokenizer.from_pretrained("dslim/bert-base-NER") |
| model = AutoModelForTokenClassification.from_pretrained("dslim/bert-base-NER") |
| |
| nlp = pipeline("ner", model=model, tokenizer=tokenizer) |
| example = "My name is Wolfgang and I live in Berlin" |
| |
| ner_results = nlp(example) |
| print(ner_results) |
| ``` |
|
|
| #### Limitations and bias |
|
|
| This model is limited by its training dataset of entity-annotated news articles from a specific span of time. This may not generalize well for all use cases in different domains. Furthermore, the model occassionally tags subword tokens as entities and post-processing of results may be necessary to handle those cases. |
|
|
| ## Training data |
|
|
| This model was fine-tuned on English version of the standard [CoNLL-2003 Named Entity Recognition](https://www.aclweb.org/anthology/W03-0419.pdf) dataset. |
|
|
| The training dataset distinguishes between the beginning and continuation of an entity so that if there are back-to-back entities of the same type, the model can output where the second entity begins. As in the dataset, each token will be classified as one of the following classes: |
|
|
| Abbreviation|Description |
| -|- |
| O|Outside of a named entity |
| B-MISC |Beginning of a miscellaneous entity right after another miscellaneous entity |
| I-MISC | Miscellaneous entity |
| B-PER |Beginning of a person’s name right after another person’s name |
| I-PER |Person’s name |
| B-ORG |Beginning of an organization right after another organization |
| I-ORG |organization |
| B-LOC |Beginning of a location right after another location |
| I-LOC |Location |
|
|
|
|
| ### CoNLL-2003 English Dataset Statistics |
| This dataset was derived from the Reuters corpus which consists of Reuters news stories. You can read more about how this dataset was created in the CoNLL-2003 paper. |
| #### # of training examples per entity type |
| Dataset|LOC|MISC|ORG|PER |
| -|-|-|-|- |
| Train|7140|3438|6321|6600 |
| Dev|1837|922|1341|1842 |
| Test|1668|702|1661|1617 |
| #### # of articles/sentences/tokens per dataset |
| Dataset |Articles |Sentences |Tokens |
| -|-|-|- |
| Train |946 |14,987 |203,621 |
| Dev |216 |3,466 |51,362 |
| Test |231 |3,684 |46,435 |
|
|
| ## Training procedure |
|
|
| This model was trained on a single NVIDIA V100 GPU with recommended hyperparameters from the [original BERT paper](https://arxiv.org/pdf/1810.04805) which trained & evaluated the model on CoNLL-2003 NER task. |
|
|
| ## Eval results |
| metric|dev|test |
| -|-|- |
| f1 |95.1 |91.3 |
| precision |95.0 |90.7 |
| recall |95.3 |91.9 |
|
|
| The test metrics are a little lower than the official Google BERT results which encoded document context & experimented with CRF. More on replicating the original results [here](https://github.com/google-research/bert/issues/223). |
|
|
| ### BibTeX entry and citation info |
|
|
| ``` |
| @article{DBLP:journals/corr/abs-1810-04805, |
| author = {Jacob Devlin and |
| Ming{-}Wei Chang and |
| Kenton Lee and |
| Kristina Toutanova}, |
| title = {{BERT:} Pre-training of Deep Bidirectional Transformers for Language |
| Understanding}, |
| journal = {CoRR}, |
| volume = {abs/1810.04805}, |
| year = {2018}, |
| url = {http://arxiv.org/abs/1810.04805}, |
| archivePrefix = {arXiv}, |
| eprint = {1810.04805}, |
| timestamp = {Tue, 30 Oct 2018 20:39:56 +0100}, |
| biburl = {https://dblp.org/rec/journals/corr/abs-1810-04805.bib}, |
| bibsource = {dblp computer science bibliography, https://dblp.org} |
| } |
| ``` |
| ``` |
| @inproceedings{tjong-kim-sang-de-meulder-2003-introduction, |
| title = "Introduction to the {C}o{NLL}-2003 Shared Task: Language-Independent Named Entity Recognition", |
| author = "Tjong Kim Sang, Erik F. and |
| De Meulder, Fien", |
| booktitle = "Proceedings of the Seventh Conference on Natural Language Learning at {HLT}-{NAACL} 2003", |
| year = "2003", |
| url = "https://www.aclweb.org/anthology/W03-0419", |
| pages = "142--147", |
| } |
| ``` |
|
|