import hydra
from omegaconf import OmegaConf
from utils import parallel, set_seed
import numpy as np
from metric import NDCG_at_k_rank, ensemble_average_accuracy
from market import Market
from user import User
import numpy as np

@hydra.main(version_base=None, config_path='configs', config_name='config')
def main(cfg=None):
    cfg = OmegaConf.to_container(cfg, resolve=True)
    cfg.update(cfg['task'])
    cfg.update(cfg['specification'])
    set_seed(cfg['seed'])
    market = Market(cfg)
    # parallel(cfg['n_learnware'], market.submit_learnware)
    # parallel(cfg['n_user'], User, cfg)
    # return
    for learnware_id in range(1, 1 + cfg['n_learnware']):
        market.submit_learnware(learnware_id)
    print('')
    users = [User(cfg, user_id) for user_id in range(1, 1 + cfg['n_user'])]
    model_perfs = np.array([market.evaluate (user)[0] for user in users])
    rcmd_orders = np.array([market.recommend(user)    for user in users])
    print(NDCG_at_k_rank(cfg, rcmd_orders, model_perfs, k=1))
    # print(NDCG_at_k_rank(cfg, rcmd_orders, model_perfs))
    # if cfg['task'] == 'classification':
    #     print(ensemble_average_accuracy(cfg, rcmd_orders))


if __name__ == '__main__':
    main()

'''
34519 42247 41361 31682 34389 39767 40691 40588 40770 33794
36373 38726 37356 37154 38172 39667 40071 33660 40104 30360
38911 40070 43236 40823 34797 39829 42600 40005 40124 35419
 2434  2673  2511  2862  2492  3140  3281  3257  3055  2457
 2993  3352  3173  3320  3143  3183  2750  3002  2776  3382

NCME and RNCME(m=2000)
1 1 1 2 1 1 1  1 1 1 1  1 2 2 1 1 3 1 1 1
0.9913793103448276

CME
  6 5 1   3 8 19 4 3 4 15 1     9 1 5
0.8775862068965518
'''