Skip to main content

Finetune_Eval_Harness

Project description

Finetune-Evaluation-Harness

Build Status Build Status

Overview

This project is a unified framework for evaluation of various LLMs on a large number of different evaluation tasks. Some of the features of this framework:

  • Different types of tasks supported: Classification, NER tagging, Question-Answering
  • Support for parameter efficient tuning (PEFT)
  • Running mutliple tasks altogether

Getting Started

To evaluate a model (eg GERMAN-BERT) on task, please use something like this:

import finetune_eval_harness


finetune-eval-harness --model_name_or_path bert-base-german-cased \
--task_list germeval2018 \
--results_logging_dir /sample/directory/results \
--output_dir /sample/directory/results

Please refer to the latest package details here: https://pypi.org/project/finetune-eval-harness/

This framework is build on top of Huggingface, hence all the keyword arguments used in regular HF transformers library work here as well: https://github.com/huggingface/transformers/blob/main/src/transformers/trainer.py.

Some Important Arguments

--model_name_or_path MODEL_NAME_OR_PATH
    Path to pretrained model or model identifier from huggingface.co/models (default: None)

--task_list TASK_LIST [TASK_LIST ...]
    List of tasks passed in order. (default: None) eg germeval2018, germeval2017, gnad10, german_europarl

--results_logging_dir RESULTS_LOGGING_DIR
   Where do you want to save the results of the run as a json file (default: None)

--output_dir OUTPUT_DIR
	The output directory where the model predictions and checkpoints will be written. (default: None)

--num_train_epochs NUM_TRAIN_EPOCHS
    Total number of training epochs to perform. (default: 1.0)

--per_device_train_batch_size PER_DEVICE_TRAIN_BATCH_SIZE
    Batch size per GPU/TPU core/CPU for training. (default: 8)

--use_fast_tokenizer [USE_FAST_TOKENIZER]
    Whether to use one of the fast tokenizer (backed by the tokenizers library) or not. (default: True)

If you fail to understand what any of the paramater does, --help is your friend.

Some of the Tasks

For a detailed list of tasks, please use

finetune_eval_harness.get_all_tasks()


['germeval2018', 'germeval2017', 'gnad10', 'german_ner_legal', 'german_europarl', 'german_quad', 'spanish_quad', 'wiki_cat_es', 'spanish_conll', 'flue', 'spanish_ehealth', 'szeged_ner', 'polish_dyk', 'mapa', 'eur_lux', 'ehealth_kd', 'rucola', 'klej_dyk', 'croatian_sentiment', 'finish_sentiment', 'swedish_ner', 'greek_legal', 'bulgarian_sentiment', 'czech_subjectivity', 'danish_misogyny', 'slovak_sentiment', 'maltese_sentiment', 'dutch_social']

Implementing New Tasks

To implement a new task in eval harness, see this guide.

Evaluating the Coverage of the Current Code

Please go to Github Actions sections of this repository and start the build named "Evaluate", this would check if the coverage on existing code is more than 80%. The build status is also visible on the main repo page.

Guidelines On Running Tasks

  • In some instances for specific tasks, please make sure to specify the exact dataset config depending on your needs
  • If text sequence processing fails for some tasks such as classification, please try with setting --use_fast_tokenizer as False
  • Please make sure that the dataset (i.e task) url is publically visible on huggingface datasets

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

finetune_eval_harness-0.6.12.dev1.tar.gz (58.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

finetune_eval_harness-0.6.12.dev1-py3-none-any.whl (77.6 kB view details)

Uploaded Python 3

File details

Details for the file finetune_eval_harness-0.6.12.dev1.tar.gz.

File metadata

File hashes

Hashes for finetune_eval_harness-0.6.12.dev1.tar.gz
Algorithm Hash digest
SHA256 86f8edd4dda24a3ee6ec6f9db4888696683e0ea5c5c88633ee4fed3e58ac81e0
MD5 1d5af2e4f1289a6ab89dd5365fe6fcaa
BLAKE2b-256 5e160453cead6dfc15428888df03104358408929b7556d078ff6424134ba1c8b

See more details on using hashes here.

File details

Details for the file finetune_eval_harness-0.6.12.dev1-py3-none-any.whl.

File metadata

File hashes

Hashes for finetune_eval_harness-0.6.12.dev1-py3-none-any.whl
Algorithm Hash digest
SHA256 1bd47a9084eb7087bb3e95912fc66d018fc9a07b124fe4c62cc4d854fb4b1304
MD5 398864f358dff1c5aa3fa2bb6db75631
BLAKE2b-256 3f3d9e165c2bb6493a77c2ce1844305177683d8adfe2ab5f26730d5d728e12d4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page