All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog.
- Identified URLs are now added in the TEI output #1099
- Added DL models for patent processing #1082
- Copyrights owner and licenses identification models #1078
- Add research infrastructure recognition for funding processing #1085
- Add paragraphs coordinates in the TEI output #1068
- Specify configuration file with DL models enabled for the full docker image #1117
- Support for biblio-glutton 0.3 #1086
- Update affiliation process #1069
- Improved the recognition of URLs using (when available) PDF annotations, such as clickable links
- Updated TEI schema #1084
- Review patent process #1082
- Add Kotlin language to support development and testing #1096
- Avoid splitting URLs between sentences #1097
- Add missing sentence segmentation in funding and acknowledgement #1106
- Docker image was optimized to reduce the needed space #1088
- Fixed OOBE when processing large quantities of notes #1075
- Corrected
<title>
coordinate attribute name #1070 - Fix missing coordinates in paragraph continuation #1076
- Fixed JSON log output
- Fixed notes identification #1124
- Fixed extraneous semicolon in the training data #1133
- Reduced security vulnerabilities in the dependencies #1136 #1137
- Extraction of funder and funding information with a specific new model, see #1046 for details
- Optional consolidation of funder with CrossRef Funder Registry
- Identification of acknowledged entities in the acknowledgement section
- Optional coordinates in title elements
- Dropwizard upgrade to 4.0
- Minimum JDK/JVM requirement for building/running the project is now 1.11
- Logging now with Logback, removal of Log4j2, optional logs in json format
- General review of logs
- Enable Github actions / Disable circleci
- Set dynamic memory limit in pdfalto_server #1038
- Logging in files when training models work now as expected
- Various dependency upgrades
- Fix #1051 with possible problematic PDF
- Fix #1036 for pdfalto memory limit
- fix readthedocs build #1040
- fix for null equation #1030
- Other minor fixes
- Support for JDK beyond 1.11, tested up to Java 17, thanks to removal of dynamic native library loading after the start of the JVM
- Incremental training (all models and ML engines), add this option in training command line and training web service (#971)
- Systematic benchmarking on two new sets: PLOS (1000 artilces) and eLife (984 articles)
- All end-to-end evaluation datasets are now available from the same place: https://zenodo.org/record/7708580
- Option to output coordinates in notes and figure/table captions
- Support for Mac ARM architecture (#975)
- Play With Docker documentation (#962)
- Update to DeLFT version 0.3.3
- Demo now hosted as HuggingFace space
- Additional training data, in particular for citation, reference-segmenter, segmentation, header, etc.
- Update Deep Learning models (and some of the CRF)
- The standard analyzer for sub-lexical tokenization is available in grobid-core, and used for the citation model (in particular for improving CJK references) (#990)
- Update evaluations
- Correct wrong content type in doc for processCitation web service
- Sentence segmentation applied to notes (#995)
- Other minor fixes
- Explicit identification of data/code availability statements (#951) and funding statements (#959), including when they are located in the header
- Link footnote and their "callout" marker in full text (#944)
- Option to consolidate header only with DOI if a DOI is extracted (#742)
- "Window" application of RNN model for reference-segmenter to cover long bibliographical sections
- Add dynamic timeout on pdfalto_server (#926)
- A modest Python script to help to find "interesting" error cases in a repo of JATS/PDF pairs, grobid-home/scripts/select_error_cases.py
- Update to DeLFT version 0.3.2
- Some more training data (authors in reference, segmentation, citation, reference-segmenter) (including #961, #864)
- Update of some models, RNN with feature channels and CRF (segmentation, header, reference-segmenter, citation)
- Review guidelines for segmentation model
- Better URL matching, using in particular PDF URL annotation in account
- Fix unexpected figure and table labeling in short texts
- When matching an ORCID to an author, prioritize Crossref info over extracted ORCID from the PDF (#838)
- Annotation errors for acknowledgement and other minor stuff
- Fix for Python library loading for Mac
- Update docker file to support new CUDA key
- Do not dehyphenize text in superscript or subscript
- Allow absolute temporary paths
- Fix redirected stderr from pdfalto not "gobbled" by the java ProcessBuilder call (#923)
- Other minor fixes
- Web services for training models (#778)
- Some additional training data for bibliographical references from arXiv
- Add a web service to process a list of reference strings, see https://grobid.readthedocs.io/en/processcitationlist/Grobid-service/#apiprocesscitationlist
- Extended processHeaderDocument to get result in bibTeX
- Update to DeLFT version to 0.3.1 and TensorFlow 2.7, with many improvements, see https://github.com/kermitt2/delft/releases/tag/v0.3.0
- Update of Deep Learning models
- Update of JEP and add install script
- Update to new biblio-glutton version 0.2, for improved and faster bibliographical reference matching
- circleci to replace Travis
- Update of processFulltextAssetDocument service to use the same parameters as processFulltextDocument
- Pre-compile regex if not already done
- Review features for header model
- Improved date normalization (#760)
- Fix possible issue with coordinates related to reference markers (#908) and sentence (#811)
- Fix path to bitmap/vector graphics (#836)
- Fix possible catastrophic regex backtracking (#867)
- Other minor fixes
0.7.0 – 2021-07-17
- New YAML configuration: all the settings are in one single yaml file, each model can be fully configured independently
- Improvement of the segmentation and header models (for header, +1 F1-score for PMC evaluation, +4 F1-score for bioRxiv), improvements for body and citations
- Add figure and table pop-up visualization on PDF in the console demo
- Add PDF MD5 digest in the TEI results (service only)
- Language support packages and xpdfrc file for pdfalto (support of CJK and exotic fonts)
- Prometheus metrics
- BidLSTM-CRF-FEATURES implementation available for more models
- Addition of a "How GROBID works" page in the documentation
- JitPack release (RIP jcenter)
- Improved DOI cleaning
- Speed improvement (around +10%), by factorizing some layout token manipulation
- Update CrossRef requests implementation to align to the current usage of CrossRef's
X-Rate-Limit-Limit
response parameter
- Fix base url in demo console
- Add missing pdfalto Graphics information when
-noImage
is used, fix graphics data path in TEI - Fix the tendency to merge tables when they are in close proximity
0.6.2 – 2021-03-20
- Docker image covering both Deep Learning and CRF models, with GPU detection and preloading of embeddings
- For Deep Learning models, labeling is now done by batch: application of the citation DL model is 4 times faster for BidLSTM-CRF (with or without features) and 6 times faster for SciBERT
- More tests for sentence segmentation
- Add orcid of persons when available from the PDF or via consolidation (i.e. if in CrossRef metadata)
- Add BidLSTM-CRF-FEATURES header model (with feature channel)
- Add bioRxiv end-to-end evaluation
- Bounding boxes for optional section titles coordinates
- Reduce the size of docker images
- Improve end-to-end evaluation: multithreaded processing of PDF, progress bar, output the evaluation report in markdown format
- Update of several models covering CRF, BidLSTM-CRF and BidLSTM-CRF-FEATURES, mainly improving citation and author recognitions
- OpenNLP is the default optional sentence segmenter (similar result as Pragmatic Segmenter for scholar documents after benchmarking, but 30 times faster)
- Refine sentence segmentation to exploit layout information and predicted reference callouts
- Update jep version to 3.9.1
- Ignore invalid utf-8 sequences
- Update CrossRef multithreaded calls to avoid using the unreliable time interval returned by the CrossRef REST API service, update usage of
Crossref-Plus-API-Token
and update the deprecated crossref fieldquery.title
- Missing last table or figure when generating training data for the fulltext model
- Fix an error related to the feature value for the reference callout for the fulltext model
- Review/correct DeLFT configuration documentation, with a step-by-step configuration documentation
- Other minor fixes
0.6.1 – 2020-08-12
- Support of line number (typically in preprints)
- End-to-end evaluation and benchmark for preprints using the bioRxiv 10k dataset
- Check whether PDF annotation is orcid and add orcid to author in the TEI result
- Configuration for making sequence labeling engine (CRF Wapiti or Deep Learning) specific to models
- Add a developers guide and a FAQ section in the documentation
- Visualization of formulas on PDF layout in the demo console
- Feature for subscript/superscript style in fulltext model
- New significantly improved header model: with new features, new training data (600 new annotated examples, old training data is entirely removed), new labels and updated data structures in line with the other models
- Update of the segmentation models with more training data
- Removal of heuristics related to the header
- Update to gradle 6.5.1 to support JDK 13 and 14
- TEI schemas
- Windows is not supported in this release
- Preserve affiliations after consolidation of the authors
- Environment variable config override for all properties
- Unfrequent duplication of the abstract in the TEI result
- Incorrect merging of affiliations
- Noisy parentheses in the bibliographical reference markers
- In the console demo, fix the output filename wrongly taken from the input form when the text form is used
- Synchronisation of the language detection singleton initialisation in case of multithread environment
- Other minor fixes
0.6.0 – 2020-04-24
- Table content structuring (thanks to @Vitaliy-1), see PR #546
- Support for
application/x-bibtex
at/api/processReferences
and/api/processCitation
(thanks to @koppor) - Optionally include raw affiliation string in the TEI result
- Add dummy model for facilitating test in Grobid modules
- Allow environment variables for config properties values to ease Docker config
- ChangeLog
- Improve CORS configuration #527 (thank you @lfoppiano)
- Documentation improvements
- Update of segmentation and fulltext model and training data
- Better handling of affiliation block fragments
- Improved DOI string recognition
- More robust n-fold cross validation (case of shared grobid-home)
- Fixed flags of pdf2xml in
Dockerfile
- Some fixes for better TEI result format conformance
- Other minor fixes
0.5.6 – 2019-10-16
- n-fold cross evaluation and better evaluation report (thanks to @lfoppiano)
- Better abstract structuring (with citation contexts)
- Improved PMC ID and PMID recognition
- Improved subscript/superscript and font style recognition (via pdfalto)
- Improved JEP integration (support of python virtual environment for using DeLFT Deep Learning library, thanks @de-code and @lfoppiano)
- Improved dehyphenization (thanks to @lfoppiano)
- Several bug fixes (thanks @de-code, @bnewbold, @Vitaliy-1 and @lfoppiano)
0.5.5 – 2019-05-29
- Using pdfalto instead of pdf2xml for the first PDF parsing stage, with many improvements in robustness, ICU support, unknown glyph/font normalization (thanks in particular to @aazhar)
- Improvement and full review of the integration of consolidation services, supporting biblio-glutton (additional identifiers and Open Access links) and Crossref REST API (add specific user agent, email and token for Crossref Metadata Plus)
- Updated lexicon #396
- Fix bounding box issues for some PDF #330
0.5.4 – 2019-02-12
- Transparent usage of DeLFT deep learning models (BidLSTM-CRF/ELMo) instead of Wapiti CRF models, native integration via JEP
- Support of biblio-glutton as DOI/metadata matching service, alternative to crossref REST API
- Improvement of citation context identification and matching (+9% recall with similar precision, for PMC sample 1943 articles, from 43.35 correct citation contexts per article to 49.98 correct citation contexts per article)
- Citation callout now in abstract, figure and table captions
- Structured abstract (including update of TEI schema)
- Bug fixes and some more parameters: by default using all available threads when training (thanks @de-code) and possibility to load models at the start of the service
0.5.3 – 2018-11-25
- Support of proxy for calling crossref with Apache HttpClient
- Improvement of consolidation options and processing (better handling of CrossRef API, but the best is coming soon ;)
- Better recall for figure and table identification (thanks to @detonator413)
- Minor bug fixing
0.5.2 – 2018-10-17
- Added Grobid clients for Java, Python and NodeJS
- Added metrics in the REST entrypoint (accessible via http://localhost:8071)
- Added counters for consolidation tasks and consolidation results
- Added case sensitiveness option in lexicon/FastMatcher
- Updated documentation
- Corrected back status codes from the REST API when no available engine (503 is back again to inform the client to wait, it was removed by error in version 0.5.0 and 0.5.1 for PDF processing services only, see documentation of the REST API)
- Bugfixing #339, #322, #300, and others
0.5.1 – 2018-01-29
- Various bug fixes
0.5.0 – 2017-11-09
- Migrate from maven to gradle for faster, more flexible and more stable build, release, etc.
- Usage of Dropwizard for web services
- Move the Grobid service manual to readthedocs
- (thanks to @detonator413 and @lfoppiano for this release! future work in versions 0.5.* will focus again on improving PDF parsing and structuring accuracy)
0.4.4 – 2017-10-13
- Fixed issue that was making the release build not working
0.4.3 – 2017-10-07
- New training data and features for bibliographical references, in particular for covering HEP domain (INSPIRE), arXiv identifier, DOI and url (thanks @iorala and @michamos !)
- Support for CrossRef REST API (instead of the slow OpenURL-style API which requires a CrossRef account), in particular for multithreading usage (thanks @Vi-dot)
- Unicode normalisation and more robust body extraction (thanks @aoboturov)
- Updated models: f-score improvement on the PubMed Central sample, bibliographical references +2.5%, header +7%
- Improve training data generation and documentation (thanks @jfix)
- Update of the pdf2xml fork for Windows (thanks @lfoppiano)
- fixes, tests, documentation
0.4.2 – 2017-08-05
- Identification of equations (with PDF coordinates)
- End-to-end evaluation with Pub2TEI conversions
- f-score improvement for the PubMed Central sample: fulltext +10-14%, header +0.5%, citations +0.5%
- More robust PDF parsing
- many fixes and refactoring
0.4.1 – 2016-10-02
- Support for Windows thanks to the contributions of Christopher Boumenot!
- Support for Docker
- New web services for PDF annotation and updated web console application
- Some improvements on figure/table extraction - but still experimental at this stage (work in progress, as the whole full text model)
- Fixes and refactoring.
0.4.0 – 2016-10-02
- Improvement of the recognition of citations thanks to refinements of CRF features - +4% in f-score for the PubMed Central sample.
- Improvement of the full text model, with new features and the introduction of two additional models for figures and tables.
- More robust synchronization of CRF sequence with PDF areas, resulting in improved bounding box calculations for locating annotations in the PDF documents.
- Improved general robustness thanks to better token alignments.