Sequential Recommendation for cold-start users with meta transitional learning
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.py 2.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. from trainer import *
  2. from utils import *
  3. from sampler import *
  4. import json
  5. import torch
  6. import argparse
  7. def get_params():
  8. args = argparse.ArgumentParser()
  9. args.add_argument("-data", "--dataset", default="electronics", type=str)
  10. args.add_argument("-seed", "--seed", default=7, type=int)
  11. args.add_argument("-K", "--K", default=3, type=int) #NUMBER OF SHOT
  12. args.add_argument("-dim", "--embed_dim", default=256, type=int)
  13. args.add_argument("-bs", "--batch_size", default=1024, type=int)
  14. args.add_argument("-lr", "--learning_rate", default=0.001, type=float)
  15. args.add_argument("-epo", "--epoch", default=100000, type=int)
  16. args.add_argument("-prt_epo", "--print_epoch", default=100, type=int)
  17. args.add_argument("-eval_epo", "--eval_epoch", default=500, type=int)
  18. args.add_argument("-b", "--beta", default=5, type=float)
  19. args.add_argument("-m", "--margin", default=1, type=float)
  20. args.add_argument("-p", "--dropout_p", default=0.5, type=float)
  21. args.add_argument("-gpu", "--device", default=0, type=int)
  22. args.add_argument("--number_of_neg",default=2,type=int)
  23. args = args.parse_args()
  24. params = {}
  25. for k, v in vars(args).items():
  26. params[k] = v
  27. params['device'] = torch.device('cuda:'+str(args.device))
  28. # params['device'] = args.device
  29. # params['device'] = torch.device('cpu')
  30. return params, args
  31. if __name__ == '__main__':
  32. print(torch.__version__)
  33. print(torch.cuda.is_available())
  34. params, args = get_params()
  35. params['varset_size'] = 1000
  36. params['alpha'] = 0.5
  37. params['S1'] = 40
  38. params['S2_div_S1'] = 1
  39. params['temperature'] = 1.0
  40. params['warmup'] = 20.0
  41. if params['seed'] is not None:
  42. SEED = params['seed']
  43. torch.manual_seed(SEED)
  44. torch.cuda.manual_seed(SEED)
  45. torch.backends.cudnn.deterministic = True
  46. np.random.seed(SEED)
  47. random.seed(SEED)
  48. print("===============", torch.cuda.device_count(), "=======")
  49. user_train, usernum_train, itemnum, user_input_test, user_test, user_input_valid, user_valid = data_load(args.dataset, args.K)
  50. sampler = WarpSampler(user_train, usernum_train, itemnum, batch_size=args.batch_size, maxlen=args.K, n_workers=3)
  51. sampler_test = DataLoader(user_input_test, user_test, itemnum, params)
  52. sampler_valid = DataLoader(user_input_valid, user_valid, itemnum, params)
  53. print("===============", torch.cuda.device_count(), "=======")
  54. trainer = Trainer([sampler, sampler_valid, sampler_test], itemnum, params,usernum_train,user_train)
  55. print("===============", torch.cuda.device_count(), "=======")
  56. trainer.train()
  57. sampler.close()