Skip to content

Commit ae49090

Browse files
authored
Merge pull request #713 from openml/fix_687
Adding function to retrieve evaluation measures
2 parents 59f3ff6 + 9d004b9 commit ae49090

File tree

5 files changed

+36
-2
lines changed

5 files changed

+36
-2
lines changed

doc/api.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,7 @@ Modules
8484
:template: function.rst
8585

8686
list_evaluations
87+
list_evaluation_measures
8788

8889
:mod:`openml.flows`: Flow Functions
8990
-----------------------------------

doc/progress.rst

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,8 @@ Changelog
88

99
0.10.0
1010
~~~~~~
11+
12+
* ADD #687: Adds a function to retrieve the list of evaluation measures available.
1113
* ADD #695: A function to retrieve all the data quality measures available.
1214

1315
0.9.0

openml/evaluations/__init__.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
11
from .evaluation import OpenMLEvaluation
2-
from .functions import list_evaluations
2+
from .functions import list_evaluations, list_evaluation_measures
33

4-
__all__ = ['OpenMLEvaluation', 'list_evaluations']
4+
__all__ = ['OpenMLEvaluation', 'list_evaluations', 'list_evaluation_measures']

openml/evaluations/functions.py

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -200,3 +200,29 @@ def __list_evaluations(api_call, output_format='object'):
200200
evals = pd.DataFrame.from_dict(evals, orient='index')
201201

202202
return evals
203+
204+
205+
def list_evaluation_measures() -> List[str]:
206+
""" Return list of evaluation measures available.
207+
208+
The function performs an API call to retrieve the entire list of
209+
evaluation measures that are available.
210+
211+
Returns
212+
-------
213+
list
214+
215+
"""
216+
api_call = "evaluationmeasure/list"
217+
xml_string = openml._api_calls._perform_api_call(api_call, 'get')
218+
qualities = xmltodict.parse(xml_string, force_list=('oml:measures'))
219+
# Minimalistic check if the XML is useful
220+
if 'oml:evaluation_measures' not in qualities:
221+
raise ValueError('Error in return XML, does not contain '
222+
'"oml:evaluation_measures"')
223+
if not isinstance(qualities['oml:evaluation_measures']['oml:measures'][0]['oml:measure'],
224+
list):
225+
raise TypeError('Error in return XML, does not contain '
226+
'"oml:measure" as a list')
227+
qualities = qualities['oml:evaluation_measures']['oml:measures'][0]['oml:measure']
228+
return qualities

tests/test_evaluations/test_evaluation_functions.py

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -116,3 +116,8 @@ def test_evaluation_list_per_fold(self):
116116
for run_id in evaluations.keys():
117117
self.assertIsNotNone(evaluations[run_id].value)
118118
self.assertIsNone(evaluations[run_id].values)
119+
120+
def test_list_evaluation_measures(self):
121+
measures = openml.evaluations.list_evaluation_measures()
122+
self.assertEqual(isinstance(measures, list), True)
123+
self.assertEqual(all([isinstance(s, str) for s in measures]), True)

0 commit comments

Comments
 (0)