Update org-results
This commit is contained in:
parent
e1224d6883
commit
d13e847778
@ -1 +1 @@
|
|||||||
Subproject commit 70c84cbc77e52bea67e4528d6f79e2e462a4ffa6
|
Subproject commit 5e5fc2451d1702f08e2fa933107aa45b6356b6ed
|
@ -3,7 +3,7 @@
|
|||||||
#####################################################
|
#####################################################
|
||||||
# python exps/trading/organize_results.py #
|
# python exps/trading/organize_results.py #
|
||||||
#####################################################
|
#####################################################
|
||||||
import re, sys, argparse
|
import os, re, sys, argparse
|
||||||
import numpy as np
|
import numpy as np
|
||||||
from typing import List, Text
|
from typing import List, Text
|
||||||
from collections import defaultdict, OrderedDict
|
from collections import defaultdict, OrderedDict
|
||||||
@ -22,12 +22,27 @@ from qlib.workflow import R
|
|||||||
|
|
||||||
|
|
||||||
class QResult:
|
class QResult:
|
||||||
def __init__(self):
|
"""A class to maintain the results of a qlib experiment."""
|
||||||
|
|
||||||
|
def __init__(self, name):
|
||||||
self._result = defaultdict(list)
|
self._result = defaultdict(list)
|
||||||
|
self._name = name
|
||||||
|
self._recorder_paths = []
|
||||||
|
|
||||||
def append(self, key, value):
|
def append(self, key, value):
|
||||||
self._result[key].append(value)
|
self._result[key].append(value)
|
||||||
|
|
||||||
|
def append_path(self, xpath):
|
||||||
|
self._recorder_paths.append(xpath)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
return self._name
|
||||||
|
|
||||||
|
@property
|
||||||
|
def paths(self):
|
||||||
|
return self._recorder_paths
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def result(self):
|
def result(self):
|
||||||
return self._result
|
return self._result
|
||||||
@ -72,8 +87,10 @@ class QResult:
|
|||||||
head_str = separate.join([self.full_str(x, space) for x in avaliable_keys])
|
head_str = separate.join([self.full_str(x, space) for x in avaliable_keys])
|
||||||
values = []
|
values = []
|
||||||
for key in avaliable_keys:
|
for key in avaliable_keys:
|
||||||
# current_values = self._result[key]
|
if "IR" in key:
|
||||||
current_values = [x * 100 for x in self._result[key]]
|
current_values = [x * 100 for x in self._result[key]]
|
||||||
|
else:
|
||||||
|
current_values = self._result[key]
|
||||||
mean = np.mean(current_values)
|
mean = np.mean(current_values)
|
||||||
std = np.std(current_values)
|
std = np.std(current_values)
|
||||||
# values.append("{:.4f} $\pm$ {:.4f}".format(mean, std))
|
# values.append("{:.4f} $\pm$ {:.4f}".format(mean, std))
|
||||||
@ -122,25 +139,13 @@ def filter_finished(recorders):
|
|||||||
return returned_recorders, not_finished
|
return returned_recorders, not_finished
|
||||||
|
|
||||||
|
|
||||||
def query_info(save_dir, verbose, name_filter):
|
def query_info(save_dir, verbose, name_filter, key_map):
|
||||||
R.set_uri(save_dir)
|
R.set_uri(save_dir)
|
||||||
experiments = R.list_experiments()
|
experiments = R.list_experiments()
|
||||||
|
|
||||||
key_map = {
|
|
||||||
# "RMSE": "RMSE",
|
|
||||||
"IC": "IC",
|
|
||||||
"ICIR": "ICIR",
|
|
||||||
"Rank IC": "Rank_IC",
|
|
||||||
"Rank ICIR": "Rank_ICIR",
|
|
||||||
# "excess_return_with_cost.annualized_return": "Annualized_Return",
|
|
||||||
# "excess_return_with_cost.information_ratio": "Information_Ratio",
|
|
||||||
# "excess_return_with_cost.max_drawdown": "Max_Drawdown",
|
|
||||||
}
|
|
||||||
all_keys = list(key_map.values())
|
|
||||||
|
|
||||||
if verbose:
|
if verbose:
|
||||||
print("There are {:} experiments.".format(len(experiments)))
|
print("There are {:} experiments.".format(len(experiments)))
|
||||||
head_strs, value_strs, names = [], [], []
|
qresults = []
|
||||||
for idx, (key, experiment) in enumerate(experiments.items()):
|
for idx, (key, experiment) in enumerate(experiments.items()):
|
||||||
if experiment.id == "0":
|
if experiment.id == "0":
|
||||||
continue
|
continue
|
||||||
@ -158,9 +163,12 @@ def query_info(save_dir, verbose, name_filter):
|
|||||||
len(recorders) + not_finished,
|
len(recorders) + not_finished,
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
result = QResult()
|
result = QResult(experiment.name)
|
||||||
for recorder_id, recorder in recorders.items():
|
for recorder_id, recorder in recorders.items():
|
||||||
result.update(recorder.list_metrics(), key_map)
|
result.update(recorder.list_metrics(), key_map)
|
||||||
|
result.append_path(
|
||||||
|
os.path.join(recorder.uri, recorder.experiment_id, recorder.id)
|
||||||
|
)
|
||||||
if not len(result):
|
if not len(result):
|
||||||
print("There are no valid recorders for {:}".format(experiment))
|
print("There are no valid recorders for {:}".format(experiment))
|
||||||
continue
|
continue
|
||||||
@ -170,15 +178,8 @@ def query_info(save_dir, verbose, name_filter):
|
|||||||
len(recorders), experiment.name
|
len(recorders), experiment.name
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
head_str, value_str = result.info(all_keys, verbose=verbose)
|
qresults.append(result)
|
||||||
head_strs.append(head_str)
|
return qresults
|
||||||
value_strs.append(value_str)
|
|
||||||
names.append(experiment.name)
|
|
||||||
info_str_dict = compare_results(
|
|
||||||
head_strs, value_strs, names, space=10, verbose=verbose
|
|
||||||
)
|
|
||||||
info_value_dict = dict(heads=head_strs, values=value_strs, names=names)
|
|
||||||
return info_str_dict, info_value_dict
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
@ -210,15 +211,37 @@ if __name__ == "__main__":
|
|||||||
provider_uri = "~/.qlib/qlib_data/cn_data"
|
provider_uri = "~/.qlib/qlib_data/cn_data"
|
||||||
qlib.init(provider_uri=provider_uri, region=REG_CN)
|
qlib.init(provider_uri=provider_uri, region=REG_CN)
|
||||||
|
|
||||||
all_info_dict = []
|
"""
|
||||||
|
key_map = {
|
||||||
|
# "RMSE": "RMSE",
|
||||||
|
"IC": "IC",
|
||||||
|
"ICIR": "ICIR",
|
||||||
|
"Rank IC": "Rank_IC",
|
||||||
|
"Rank ICIR": "Rank_ICIR",
|
||||||
|
# "excess_return_with_cost.annualized_return": "Annualized_Return",
|
||||||
|
# "excess_return_with_cost.information_ratio": "Information_Ratio",
|
||||||
|
# "excess_return_with_cost.max_drawdown": "Max_Drawdown",
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
key_map = dict()
|
||||||
|
for xset in ("train", "valid", "test"):
|
||||||
|
key_map["{:}-mean-IC".format(xset)] = "IC ({:})".format(xset)
|
||||||
|
key_map["{:}-mean-ICIR".format(xset)] = "ICIR ({:})".format(xset)
|
||||||
|
|
||||||
|
all_qresults = []
|
||||||
for save_dir in args.save_dir:
|
for save_dir in args.save_dir:
|
||||||
_, info_dict = query_info(save_dir, args.verbose, args.name_filter)
|
qresults = query_info(save_dir, args.verbose, args.name_filter, key_map)
|
||||||
all_info_dict.append(info_dict)
|
all_qresults.extend(qresults)
|
||||||
info_dict = QResult.merge_dict(all_info_dict)
|
names, head_strs, value_strs = [], [], []
|
||||||
|
for result in all_qresults:
|
||||||
|
head_str, value_str = result.info(list(key_map.values()), verbose=args.verbose)
|
||||||
|
head_strs.append(head_str)
|
||||||
|
value_strs.append(value_str)
|
||||||
|
names.append(result.name)
|
||||||
compare_results(
|
compare_results(
|
||||||
info_dict["heads"],
|
head_strs,
|
||||||
info_dict["values"],
|
value_strs,
|
||||||
info_dict["names"],
|
names,
|
||||||
space=18,
|
space=18,
|
||||||
verbose=True,
|
verbose=True,
|
||||||
sort_key=True,
|
sort_key=True,
|
||||||
|
Loading…
Reference in New Issue
Block a user