Skip to content

Latest commit

 

History

History
89 lines (65 loc) · 9.26 KB

README.md

File metadata and controls

89 lines (65 loc) · 9.26 KB

nlp-ml-repo-clean

Introduction

This repository documents stages of a project using computational methods in natural language processing and machine learning to support the Knowledge Commons. The project covers steps like data acquisition, text extraction, preprocessing, and vectorization. The end goal is to improve search functionality, offer related record recommendations, and implement subject tagging. Future steps, such as the validation of vectorization and its implementation to achieve these end goals, are left for future endeavor.

Stage 1: Data Acquisition and Testing Python Libraries

1.1: Basics about InvenioRDM, API, Docker

1.2: Testing libraries for the next step: text extraction

As part of the overall process, extracting textual data from the data source plays a crucial role. Since the files come in various formats, it is essential to test different Python libraries to determine which ones are most effective for text extraction.

Deliverables:

  1. Markdown file: tutorial1-textout.md - a comparison of text extraction using various Python libraries across different file formats.
  2. Testing materials: located in the text4test folder within the stage1 subfolder.

Stage 2: Text extraction and validation

Stage 2 focuses on extracting metadata and textual information from Invenio RDM. This involves accessing files via API, downloading them, converting files from various formats into text, and removing processed files locally. Any files that cannot be processed are flagged and stored separately for further review. The converted data is then evaluated to ensure quality, and a clean DataFrame is produced for subsequent processing steps.

2.1: Text extraction

This step involves accessing and downloading files from the Invenio API and extracting text data from the downloaded files. Since the files come in various formats (e.g., PDF, DOCX, PPTX, JPG, etc.), I developed a tailored strategy for text extraction based on each format. To optimize local storage, successfully processed files are deleted afterward. Note: Invenio imposes a strict limit of 10,000 records, which will be addressed in the future.

Deliverables:

  1. Script: apiinvenio_ninth.py - used for text extraction.
  2. CSV file: output9.csv - stored in OneDrive for data security.
  3. Files that cannot be processed: stored under the folder unable_to_process_files in OneDrive for data security.

2.2: Validation: checking the quality of the output

This step involves examining the CSV file generated in the previous stage to understand its data structure, identify any missing values, and review files that could not be processed.

Deliverables:

  1. Scripts to Examine CSV: examine_output9.py - run this in terminal and it generates a CSV report.
  2. Reports in CSV file: output9_analysis_report.csv - non-sensitive information, stored in Github repo.

Stage 3: Initial exploration of data; light data preprocessing and validation

At this stage, I received a CSV file from the previous stage. Traditional data preprocessing tasks at this point often include tokenization, lemmatization, stop word and punctuation removal, lowercasing, and combining results into a single preprocessed string. This was exactly what I did using SpaCy library. However, as I continued to learn, I realized that some of these steps (e.g., stop word removal or lemmatization) might not be necessary for models like BERT, which handle raw text effectively. I have documented the preprocessing process here to provide future researchers with flexibility in deciding what steps are most relevant for their work.

3.1: Data preprocessing

After comparing NLTK and SpaCy for data preprocessing, I chose SpaCy due to its lightweight design, up-to-date features, and manageable learning curve. The goal of this step was to produce a clean, processed CSV file for future use. Since some files contained over 3 million tokens, I developed strategies to process them in chunks, preventing out-of-memory (OOM) errors.

After learning about BERT and its robust ability of applying embeddings to raw text, I decided to take a different approaches to preprocess the output9.csv. Minimal data preprocessing, I only took files that are in English and successfully processed, turning 'Extracted Text' into 'Processed Text' (containing two things: handling NaN value and trimming whitespace.).

Deliverables:

  1. Script1: csv_preprocessing_minimal.py - used for minimal data preprocessing because BERT prefers it.
  2. CSV file1: processed_output.csv - results generated from csv_preprocessing_minimal.py, stored in OneDrive for data security, contains 6000+ files, 'Extracted Text' got turned into 'Processed Text.'

3.2: Validation: examine the preprocessed output

This step validates the preprocessed dataset for quality and consistency. Key tasks included checking for missing or null values in the Processed Text column and analyzing the text length distribution to identify potential outliers or anomalies. Additionally, the dataset’s language distribution was examined to verify that the processed records align with the intended multilingual scope. For further analysis, specific records were investigated based on their Record ID to ensure accurate processing and traceability. These validation steps ensure that the preprocessed data is ready for downstream applications.

Deliverables:

  1. Script2: examine_processed_outputcsv.py - main task here: completed deduplication. Duplicates are selected based on 'Record ID' and 'DOI'.
  2. CSV file2: deduplicated_output.csv - stored in OneDrive for data security, contains 6000+ files in English, no duplicates, clean and ready for stage 4.
  3. CSV file3: duplicates_review.csv - stored in OneDrive for data security, currently only has 12 files that are duplicated, in case we want to examine the duplicates.

Stage 4: Vectorization (learning and testing on a subset)

At this stage, I worked on applying vectorization to the preprocessed output to enable the development of future applications. Embedding/vectorization is a complex field, and I have been learning and testing along the way. To keep the process manageable, I focused on a subset of 100 records for initial testing.

4.1: Learning about vectorization

I studied embeddings and vectorization from a theoretical perspective to gain a deeper understanding of what happens behind the scenes. This approach helped me avoid applying tools without comprehension. While I initially considered continuing with SpaCy for vectorization, I decided to move forward with the BERT method due to SpaCy’s limitations in this area.

Deliverable:

  1. Markdown file: learningnotes.md - contains notes on different types of embeddings.

4.2: Applying vectorization to the testing subset

Vectorization is computationally intensive and time-consuming. To optimize this stage, I created a subset of 100 records to test and evaluate the vectorization process.

Deliverable:

  1. Script1: bert_embedding_test.py - used to generate embeddings to the subset, with BERT.
  2. CSV file1:bert_embeddings_subset.csv - stored in OneDrive for data security, it contains a subset of 100 data entries.

4.3: Quality check of the results from 4.2

This step marks the point where my work on embeddings concluded. I performed initial quality checks on the subset results, leaving room for future researchers to expand upon this work. Once the subset passes a full quality check, the process can be scaled to train the entire dataset.

Deliverables:

  1. Script2: examine_bert_embedding_test.py - used to examine and validate the embeddings generated from the subset. This script produces the following outputs:
  2. Plot1: embedding_distribution.png - Gaussian Plot; the more it looks like a bell the better
  3. Plot2: kmeans_clusters.png - Check if the clusters are well-separated or overlapping
  4. CVS Stats1: embedding_statistics_report.csv - Summary statistics (mean, standard deviation)
  5. CVS Stats2: text_similarity_report.csv - Using cosine similarity to test

Acknowledgements and Reflection

Acknowledgements

Author Tianyi (Titi) Kou-Herrema is a German Studies PhD candidate who is interested in applying computational methods to assist scholarly work. She was hired as a research assistant for the Knowledge Commons (KC) Project from Summer 2023 to Fall 2024 where she developed this project while primarily working with Ian Scott and Stephanie Vasko (with much support from the rest of the tech team including Mike Thicke, Cassie Lem, Dimitrios Tzouris, and Bonnie Russell).

Reflection

While computational methods were central to this project, the significant role of human decisions at each step cannot be overlooked. As a trained humanist, Titi has developed her coding skills through hands-on experience. Some early steps may, in hindsight, appear naive; however, they reflect the knowledge and tools available to her at the time. This document illustrates how she navigated learning curves, made thoughtful decisions, and continuously refined her approach.