Evaluation as a Service for Natural Language Processing
Project description
EaaS_API
Documentation
Documentation at https://expressai.github.io/EaaS_API_dev/. Some references for writing docs can refer to
- https://www.sphinx-doc.org/en/master/usage/restructuredtext/basics.html#rst-primer
- https://sphinx-tutorial.readthedocs.io/step-1/
- https://sphinx-themes.org/sample-sites/furo/
Usage
To install the API, simply run
pip install eaas
To use the API, You should go through the following two steps.
- Step 1: You should load the default configurations and make modifications based on your own needs.
from eaas import Config
config = Config()
# To see the metrics we support, run
print(config.metrics())
# dict_keys(['bart_score_summ', 'bart_score_mt', 'bert_score', 'bleu', 'chrf', 'comet', 'comet_qe', 'mover_score', 'prism', 'prism_qe', 'rouge1', 'rouge2', 'rougeL'])
# To see the default configuration of a metric, run
print(config.bleu.to_dict())
# {'smooth_method': 'exp', 'smooth_value': None, 'force': False, 'lowercase': False, 'use_effective_order': False}
# To modify the config, run
config.bleu.set_property("smooth_method", "floor")
print(config.bleu.to_dict())
# {'smooth_method': 'floor', 'smooth_value': None, 'force': False, 'lowercase': False, 'use_effective_order': False}
- Step 2: Initialize the client and send your inputs.
from eaas import Client
client = Client()
client.load_config(config) # The config you have created above
# To use this API for scoring, you need to format your input as list of dictionary.
# Each dictionary consists of `source` (string, optional), `references` (list of string, optional)
# and `hypothesis` (string, required). `source` and `references` are optional based on the metrics
# you want to use. Please do not conduct any preprocessing on `source`, `references` or `hypothesis`,
# we expect normal-cased detokenized texts. All the preprocessing steps are taken by the metrics.
# Below is a simple example.
inputs = [{"source": "This is the source.",
"references": ["This is the reference one.", "This is the reference two."],
"hypothesis": "This is the generated hypothesis."}]
metrics = ["bleu", "chrf"] # Can be None for simplicity if you consider using all metrics
score_dic = client.score(inputs, task="sum", metrics=metrics, lang="en")
# inputs is a list of Dict, task is the name of task, metrics is metric list, lang is the two-letter code language
The output is like
# sample_level is a list of dict, corpus_level is a dict
{
'sample_level': [
{'bleu': 32.46679154750991,
'attr_compression': 1.2,
'attr_copy_len': 2.0,
'attr_coverage': 0.8,
'attr_density': 2.0,
'attr_hypothesis_len': 5,
'attr_novelty': 0.5,
'attr_repetition': 0.0,
'attr_source_len': 6,
'chrf': 38.56890099861521}
],
'corpus_level': {
'corpus_bleu': 32.46679154750991,
'corpus_attr_compression': 1.2,
'corpus_attr_copy_len': 2.0,
'corpus_attr_coverage': 0.8,
'corpus_attr_density': 2.0,
'corpus_attr_hypothesis_len': 5.0,
'corpus_attr_novelty': 0.5,
'corpus_attr_repetition': 0.0,
'corpus_attr_source_len': 6.0,
'corpus_chrf': 38.56890099861521
}
}
Long-term TODO
- 完善功能
- 只给aws的ip (起一个api.eaas类似这样的域名)
- 打包成package
- metric corpus-level指标计算; BLEU corpus-level的计算检查(是否其他metric也有类似的);我们可能要设计下返回结果的json格式
- 我们弄个文档,总结每个指标的默认预处理方法,超参数使用,考虑是否预留个接口给用户设置
- Confidence interval计算功能
- Fine-grained analysis功能
- 优化API访问效率
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
eaas-0.1.7.tar.gz
(6.7 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file eaas-0.1.7.tar.gz.
File metadata
- Download URL: eaas-0.1.7.tar.gz
- Upload date:
- Size: 6.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.0 pkginfo/1.5.0.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.7.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2eaf07a77da8116c3ac596d7191025396c5b019b536e135802804a4ceab61401
|
|
| MD5 |
b6f6241da23b33921bc6b9979c93c976
|
|
| BLAKE2b-256 |
d1dc76f9097c13543bf034cc309057295e2889b728a4d75b621e1c716f75fd93
|
File details
Details for the file eaas-0.1.7-py2.py3-none-any.whl.
File metadata
- Download URL: eaas-0.1.7-py2.py3-none-any.whl
- Upload date:
- Size: 8.5 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.0 pkginfo/1.5.0.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.7.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0bcd0c0df8a23204aeb0fa9f668843166459a53161f28429e627ab33f12cdb5b
|
|
| MD5 |
a1519accf2a3c7f59d44d7a3b1fa2c10
|
|
| BLAKE2b-256 |
16eb606719a4b013ae694320ce57ba4a048ccdeb6da1027be4001840b567e332
|