From 6f7a0d4040329f56afe4f9043c1bec1b20bb248b Mon Sep 17 00:00:00 2001 From: Muhammad Satrio Wicaksono Date: Sun, 24 Dec 2023 09:15:39 +0700 Subject: [PATCH] Closes #90 | Add Dataloader for UDHR-LID (#134) * update: adjust test_example.sh and test_example_source_only.sh * add: UDHR-LID dataloader * update: license based on constant * fix: minor bug * fix: change to _URL * add: __init__.py * update: add LANGUAGE_IDENTIFICATION task * update: based on review * update: change anonym for LANGUAGE_IDENTIFICATION * fix: based on review --- seacrowd/sea_datasets/udhr_lid/__init__.py | 0 seacrowd/sea_datasets/udhr_lid/udhr_lid.py | 160 +++++++++++++++++++++ seacrowd/utils/constants.py | 2 + test_example.sh | 31 +++- test_example_source_only.sh | 33 ++++- 5 files changed, 219 insertions(+), 7 deletions(-) create mode 100644 seacrowd/sea_datasets/udhr_lid/__init__.py create mode 100644 seacrowd/sea_datasets/udhr_lid/udhr_lid.py diff --git a/seacrowd/sea_datasets/udhr_lid/__init__.py b/seacrowd/sea_datasets/udhr_lid/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/seacrowd/sea_datasets/udhr_lid/udhr_lid.py b/seacrowd/sea_datasets/udhr_lid/udhr_lid.py new file mode 100644 index 000000000..9cbe94e2a --- /dev/null +++ b/seacrowd/sea_datasets/udhr_lid/udhr_lid.py @@ -0,0 +1,160 @@ +# coding=utf-8 +# Copyright 2022 The HuggingFace Datasets Authors and the current dataset script contributor. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +from pathlib import Path +from typing import Dict, List, Tuple + +import datasets +import pandas as pd + +from seacrowd.utils import schemas +from seacrowd.utils.configs import SEACrowdConfig +from seacrowd.utils.constants import Licenses, Tasks + +_CITATION = r"""\ +@inproceedings{ + kargaran2023glotlid, + title={{GlotLID}: Language Identification for Low-Resource Languages}, + author={Kargaran, Amir Hossein and Imani, Ayyoob and Yvon, Fran{\c{c}}ois and Sch{\"u}tze, Hinrich}, + booktitle={The 2023 Conference on Empirical Methods in Natural Language Processing}, + year={2023}, + url={https://openreview.net/forum?id=dl4e3EBz5j} +} +""" + +_LANGUAGES = [ + "sun", + "ace", + "mad", + "lao", + "cfm", + "hnj", + "min", + "zlm", + "tha", + "blt", + "hni", + "jav", + "tdt", + "cnh", + "khm", + "ban", + "ind", + "mya", + "ccp", + "duu", + "tet", + "kkh", + "bug", + "vie", +] # We follow ISO639-3 language code (https://iso639-3.sil.org/code_tables/639/data) +_LOCAL = False + +_DATASETNAME = "udhr_lid" + +_DESCRIPTION = """\ +The UDHR-LID dataset is a refined version of the Universal Declaration of Human Rights, tailored for language identification tasks. +It removes filler texts, repeated phrases, and inaccuracies from the original UDHR, focusing only on cleaned paragraphs. +Each entry in the dataset is associated with a specific language, providing long, linguistically rich content. +This dataset is particularly useful for non-parallel, language-specific text analysis in natural language processing. +""" + +_HOMEPAGE = "https://huggingface.co/datasets/cis-lmu/udhr-lid" + +_LICENSE = Licenses.CC0_1_0.value + +_URL = "https://huggingface.co/datasets/cis-lmu/udhr-lid/raw/main/udhr-lid.csv" + +_SUPPORTED_TASKS = [Tasks.LANGUAGE_IDENTIFICATION] + +_SOURCE_VERSION = "1.0.0" + +_SEACROWD_VERSION = "1.0.0" + + +class UDHRLID(datasets.GeneratorBasedBuilder): + SOURCE_VERSION = datasets.Version(_SOURCE_VERSION) + SEACROWD_VERSION = datasets.Version(_SEACROWD_VERSION) + + BUILDER_CONFIGS = [ + SEACrowdConfig( + name=f"{_DATASETNAME}_source", + version=SOURCE_VERSION, + description=f"{_DATASETNAME} source schema", + schema="source", + subset_id=f"{_DATASETNAME}", + ), + SEACrowdConfig( + name=f"{_DATASETNAME}_seacrowd_text", + version=SEACROWD_VERSION, + description=f"{_DATASETNAME} SEACrowd Schema", + schema="seacrowd_text", + subset_id=f"{_DATASETNAME}", + ), + ] + + DEFAULT_CONFIG_NAME = f"{_DATASETNAME}_source" + + def _info(self) -> datasets.DatasetInfo: + + if self.config.schema == "source": + features = datasets.Features( + { + "id": datasets.Value("string"), + "sentence": datasets.Value("string"), + "iso639-3": datasets.Value("string"), + "iso15924": datasets.Value("string"), + "language": datasets.Value("string"), + } + ) + elif self.config.schema == "seacrowd_text": + features = schemas.text_features(_LANGUAGES) + + else: + raise NotImplementedError(f"Schema '{self.config.schema}' is not defined.") + + return datasets.DatasetInfo( + description=_DESCRIPTION, + features=features, + homepage=_HOMEPAGE, + license=_LICENSE, + citation=_CITATION, + ) + + def _split_generators(self, dl_manager: datasets.DownloadManager) -> List[datasets.SplitGenerator]: + """Returns SplitGenerators.""" + data_path = dl_manager.download(_URL) + + return [ + datasets.SplitGenerator( + name=datasets.Split.TRAIN, + gen_kwargs={ + "filepath": data_path, + }, + ), + ] + + def _generate_examples(self, filepath: Path) -> Tuple[int, Dict]: + + datas = pd.read_csv(filepath) + + for i, row in datas.iterrows(): + if row["iso639-3"] in _LANGUAGES: + if self.config.schema == "source": + yield i, {"id": str(i), "sentence": row["sentence"], "iso639-3": row["iso639-3"], "iso15924": row["iso15924"], "language": row["language"]} + elif self.config.schema == "seacrowd_text": + yield i, {"id": str(i), "text": row["sentence"], "label": row["iso639-3"]} + else: + raise ValueError(f"Invalid config: {self.config.name}") diff --git a/seacrowd/utils/constants.py b/seacrowd/utils/constants.py index 4bf588a6e..d4888fef1 100644 --- a/seacrowd/utils/constants.py +++ b/seacrowd/utils/constants.py @@ -37,6 +37,7 @@ class Tasks(Enum): # Single Text Classification ASPECT_BASED_SENTIMENT_ANALYSIS = "ABSA" EMOTION_CLASSIFICATION = "EC" + LANGUAGE_IDENTIFICATION = "LI" HOAX_NEWS_CLASSIFICATION = "HNC" INTENT_CLASSIFICATION = "INT" LEGAL_CLASSIFICATION = "LC" @@ -224,6 +225,7 @@ class Licenses(Enum): Tasks.SENTIMENT_ANALYSIS: "TEXT", Tasks.TAX_COURT_VERDICT: "TEXT", Tasks.EMOTION_CLASSIFICATION: "TEXT", + Tasks.LANGUAGE_IDENTIFICATION: "TEXT", Tasks.LEGAL_CLASSIFICATION: "TEXT", Tasks.INTENT_CLASSIFICATION: "TEXT", Tasks.RHETORIC_MODE_CLASSIFICATION: "TEXT", diff --git a/test_example.sh b/test_example.sh index c12b07555..955e60785 100755 --- a/test_example.sh +++ b/test_example.sh @@ -4,14 +4,39 @@ if [[ "$1" == "" ]]; then exit fi -# Test for inputed dataset +if [[ "$2" == "--number_fold" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing number of fold" + echo "./test_example.sh --number_fold " + exit + fi -if [[ "$2" -ne "" ]]; then - for ((i=0; i < $2; i++ )); + for ((i=0; i < $3; i++ )); do python -m tests.test_seacrowd seacrowd/sea_datasets/$1/$1.py --subset_id "$1_fold$i" done exit fi +if [[ "$2" == "--subset_id" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing subset_id" + echo "./test_example.sh --subset_id " + exit + fi + + python -m tests.test_seacrowd seacrowd/sea_datasets/$1/$1.py --subset_id $3 + exit + +elif [[ "$2" == "--data_dir" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing data_dir" + echo "./test_example.sh --data_dir " + exit + fi + + python -m tests.test_seacrowd seacrowd/sea_datasets/$1/$1.py --data_dir $3 + exit +fi + python -m tests.test_seacrowd seacrowd/sea_datasets/$1/$1.py diff --git a/test_example_source_only.sh b/test_example_source_only.sh index 632a452f9..ba77555b0 100755 --- a/test_example_source_only.sh +++ b/test_example_source_only.sh @@ -4,14 +4,39 @@ if [[ "$1" == "" ]]; then exit fi -# Test for inputed dataset +if [[ "$2" == "--number_fold" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing number of fold" + echo "./test_example_source_only.sh --number_fold " + exit + fi -if [[ "$2" -ne "" ]]; then - for ((i=0; i < $2; i++ )); + for ((i=0; i < $3; i++ )); do python -m tests.test_seacrowd_source_only seacrowd/sea_datasets/$1/$1.py --subset_id "$1_fold$i" done exit fi -python -m tests.test_seacrowd_source_only seacrowd/sea_datasets/$1/$1.py +if [[ "$2" == "--subset_id" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing subset_id" + echo "./test_example_source_only.sh --subset_id " + exit + fi + + python -m tests.test_seacrowd_source_only seacrowd/sea_datasets/$1/$1.py --subset_id $3 + exit + +elif [[ "$2" == "--data_dir" ]]; then + if [[ "$3" == "" ]]; then + echo "Error: Missing data_dir" + echo "./test_example_source_only.sh --data_dir " + exit + fi + + python -m tests.test_seacrowd_source_only seacrowd/sea_datasets/$1/$1.py --data_dir $3 + exit +fi + +python -m tests.test_seacrowd_source_only seacrowd/sea_datasets/$1/$1.py \ No newline at end of file