
## LightGCN_TF_amazonbooks_x0

A notebook to benchmark LightGCN on amazonbooks_x0 dataset.

Author: Yi Li, Tsinghua University

Edited by [XUEPAI Team](https://github.com/xue-pai)

### Index
[Environments](#Environments) | [Dataset](#Dataset) | [Code](#Code) | [Results](#Results) | [Logs](#Logs) 

### Environments
* Hardware
```shell
CPU: Intel(R) Xeon(R) Silver 4210 CPU @ 2.20GHz
RAM: 125G
GPU: GeForce RTX 2080Ti, 11G memory
```
* Software
```python
python: 3.6.2
tensorflow: 1.12.0
numpy: 1.13.3
scipy: 0.19.1
sklearn: 0.19.1
cython: 0.26
```

### Dataset
We directly use the `amazon-book` dataset provided in their [repo](https://github.com/kuandeng/LightGCN/tree/master/Data). 

So you need to put the `train.txt` and `test.txt` downloaded from the [LightGCN repo](https://github.com/kuandeng/LightGCN/tree/master/Data/amazon-book) into the data/AmazonBooks/amazonbooks_x0 directory.

### Code

1. The benchmark is implemented based on the original LightGCN code released by the authors at  https://github.com/kuandeng/LightGCN. We use the version with commit hash: b067ec0.

2. We add `hitrate()` function to calculate the hitrate in both the `external/LightGCN_TF/evaluator/python/evaluate_foldout.py` file and the `external/LightGCN_TF/evaluator/cpp/include/evaluate_foldout.h`.

3. Run the following script to reproduce the result.

   ```shell
   python LightGCN.py --dataset AmazonBooks --regs [1e-4] --embed_size 64 --layer_size [64,64] --lr 0.001 --batch_size 8192 --epoch 1000 --Ks [20,50] --gpu_id 1
   ```
   
   `Prompt:`  In our execution process, we use the python evaluator. If you want to use the C++ evaluator，you can read the README.md under the external/LightGCN_TF path.

### Results

```
HR@20 = 0.24233, Recall@20 = 0.04110, NDCG@20 = 0.03179
HR@50 = 0.40193, Recall@50 = 0.07990, NDCG@50 = 0.04614
```

### Logs

```shell
eval_score_matrix_foldout with python
n_users=52643, n_items=91599
n_interactions=2984108
n_train=2380730, n_test=603378, sparsity=0.00062
already load adj matrix (144242, 144242) 0.7344512939453125
use the pre adjcency matrix
using random initialization
without pretraining.
Epoch 1 [65.8s]: train==[0.59049=0.59043 + 0.00006]
Epoch 2 [51.4s]: train==[0.31020=0.30985 + 0.00035]
Epoch 3 [52.2s]: train==[0.23451=0.23397 + 0.00054]
Epoch 4 [51.1s]: train==[0.20297=0.20231 + 0.00066]
Epoch 5 [51.1s]: train==[0.18365=0.18290 + 0.00075]
Epoch 6 [51.9s]: train==[0.16976=0.16894 + 0.00082]
Epoch 7 [50.7s]: train==[0.15790=0.15701 + 0.00088]
Epoch 8 [53.2s]: train==[0.14798=0.14703 + 0.00094]
Epoch 9 [53.2s]: train==[0.13934=0.13834 + 0.00100]
Epoch 10 [53.5s]: train==[0.13077=0.12971 + 0.00105]
Epoch 11 [53.3s]: train==[0.12442=0.12332 + 0.00111]
Epoch 12 [53.0s]: train==[0.11823=0.11707 + 0.00116]
Epoch 13 [52.8s]: train==[0.11240=0.11119 + 0.00121]
Epoch 14 [52.7s]: train==[0.10702=0.10576 + 0.00126]
Epoch 15 [52.2s]: train==[0.10290=0.10160 + 0.00131]
Epoch 16 [52.5s]: train==[0.09858=0.09723 + 0.00135]
Epoch 17 [52.6s]: train==[0.09463=0.09323 + 0.00140]
Epoch 18 [52.5s]: train==[0.09142=0.08998 + 0.00145]
Epoch 19 [54.4s]: train==[0.08841=0.08692 + 0.00149]
Epoch 20: train==[0.08507=0.08353 + 0.00154 + 0.00000], recall=[0.04836, 0.09466], hitrate=[0.65120, 0.82854], precision=[0.08445, 0.06792], ndcg=[0.09456, 0.10329]
Epoch 20 [4505.4s + 2670.5s]: test==[0.21831=0.21677 + 0.00155 + 0.00000], recall=[0.02457, 0.04902], hitrate=[0.16820, 0.29191], precision=[0.01092, 0.00894], ndcg=[0.01930, 0.02833]
Epoch 21 [54.1s]: train==[0.08295=0.08137 + 0.00158]
Epoch 22 [53.3s]: train==[0.08080=0.07918 + 0.00162]
Epoch 23 [68.2s]: train==[0.07789=0.07623 + 0.00166]
Epoch 24 [65.8s]: train==[0.07580=0.07409 + 0.00171]
Epoch 25 [61.8s]: train==[0.07411=0.07236 + 0.00175]
Epoch 26 [69.5s]: train==[0.07226=0.07047 + 0.00179]
Epoch 27 [75.4s]: train==[0.07005=0.06822 + 0.00182]
Epoch 28 [75.3s]: train==[0.06878=0.06692 + 0.00186]
Epoch 29 [77.3s]: train==[0.06707=0.06517 + 0.00190]
Epoch 30 [78.3s]: train==[0.06571=0.06377 + 0.00194]
Epoch 31 [79.5s]: train==[0.06428=0.06231 + 0.00198]
Epoch 32 [80.8s]: train==[0.06263=0.06062 + 0.00201]
Epoch 33 [79.4s]: train==[0.06173=0.05968 + 0.00205]
Epoch 34 [75.8s]: train==[0.06063=0.05855 + 0.00208]
Epoch 35 [79.7s]: train==[0.05909=0.05697 + 0.00212]
Epoch 36 [77.7s]: train==[0.05860=0.05645 + 0.00215]
Epoch 37 [80.0s]: train==[0.05719=0.05500 + 0.00219]
Epoch 38 [76.8s]: train==[0.05619=0.05397 + 0.00222]
Epoch 39 [79.1s]: train==[0.05560=0.05334 + 0.00225]
Epoch 40: train==[0.05434=0.05205 + 0.00229 + 0.00000], recall=[0.06135, 0.12011], hitrate=[0.73413, 0.89043], precision=[0.10566, 0.08497], ndcg=[0.11736, 0.12922]
Epoch 40 [6425.9s + 2679.6s]: test==[0.20379=0.20147 + 0.00232 + 0.00000], recall=[0.02849, 0.05638], hitrate=[0.18838, 0.32354], precision=[0.01243, 0.01011], ndcg=[0.02231, 0.03261]
Epoch 41 [54.0s]: train==[0.05331=0.05099 + 0.00232]
Epoch 42 [53.5s]: train==[0.05265=0.05030 + 0.00235]
Epoch 43 [54.2s]: train==[0.05168=0.04930 + 0.00238]
Epoch 44 [53.5s]: train==[0.05114=0.04873 + 0.00241]
Epoch 45 [53.6s]: train==[0.05060=0.04816 + 0.00244]
Epoch 46 [54.0s]: train==[0.04967=0.04720 + 0.00247]
Epoch 47 [54.0s]: train==[0.04885=0.04635 + 0.00250]
Epoch 48 [53.9s]: train==[0.04841=0.04588 + 0.00253]
Epoch 49 [54.6s]: train==[0.04757=0.04501 + 0.00256]
Epoch 50 [56.1s]: train==[0.04707=0.04448 + 0.00259]
Epoch 51 [57.1s]: train==[0.04654=0.04392 + 0.00262]
Epoch 52 [53.5s]: train==[0.04586=0.04321 + 0.00265]
Epoch 53 [53.1s]: train==[0.04518=0.04250 + 0.00268]
Epoch 54 [53.9s]: train==[0.04487=0.04217 + 0.00270]
Epoch 55 [52.8s]: train==[0.04411=0.04137 + 0.00273]
Epoch 56 [53.7s]: train==[0.04367=0.04091 + 0.00276]
Epoch 57 [53.9s]: train==[0.04301=0.04023 + 0.00279]
Epoch 58 [54.0s]: train==[0.04260=0.03978 + 0.00281]
Epoch 59 [52.9s]: train==[0.04201=0.03917 + 0.00284]
Epoch 60: train==[0.04144=0.03858 + 0.00287 + 0.00000], recall=[0.07227, 0.14058], hitrate=[0.78345, 0.92215], precision=[0.12209, 0.09761], ndcg=[0.13502, 0.14939]
Epoch 60 [4425.9s + 2663.9s]: test==[0.20267=0.19976 + 0.00291 + 0.00000], recall=[0.03066, 0.06058], hitrate=[0.19786, 0.33718], precision=[0.01320, 0.01071], ndcg=[0.02403, 0.03510]
Epoch 61 [53.4s]: train==[0.04119=0.03830 + 0.00289]
Epoch 62 [52.7s]: train==[0.04085=0.03793 + 0.00292]
Epoch 63 [53.1s]: train==[0.04003=0.03709 + 0.00294]
Epoch 64 [53.3s]: train==[0.03967=0.03670 + 0.00297]
Epoch 65 [52.8s]: train==[0.03933=0.03634 + 0.00299]
Epoch 66 [51.5s]: train==[0.03899=0.03597 + 0.00302]
Epoch 67 [53.3s]: train==[0.03866=0.03562 + 0.00304]
Epoch 68 [51.7s]: train==[0.03833=0.03526 + 0.00307]
Epoch 69 [52.9s]: train==[0.03772=0.03463 + 0.00309]
Epoch 70 [52.8s]: train==[0.03749=0.03437 + 0.00312]
Epoch 71 [53.5s]: train==[0.03718=0.03404 + 0.00314]
Epoch 72 [52.5s]: train==[0.03674=0.03357 + 0.00316]
Epoch 73 [52.3s]: train==[0.03659=0.03340 + 0.00319]
Epoch 74 [51.9s]: train==[0.03611=0.03290 + 0.00321]
Epoch 75 [52.4s]: train==[0.03597=0.03274 + 0.00323]
Epoch 76 [52.5s]: train==[0.03544=0.03219 + 0.00326]
Epoch 77 [53.2s]: train==[0.03511=0.03183 + 0.00328]
Epoch 78 [52.3s]: train==[0.03511=0.03181 + 0.00330]
Epoch 79 [52.9s]: train==[0.03442=0.03109 + 0.00332]
Epoch 80: train==[0.03393=0.03058 + 0.00335 + 0.00000], recall=[0.08252, 0.15958], hitrate=[0.82053, 0.94402], precision=[0.13670, 0.10873], ndcg=[0.15118, 0.16797]
Epoch 80 [4413.0s + 2669.7s]: test==[0.20395=0.20055 + 0.00339 + 0.00000], recall=[0.03199, 0.06355], hitrate=[0.20253, 0.34712], precision=[0.01364, 0.01113], ndcg=[0.02503, 0.03670]
Epoch 81 [53.6s]: train==[0.03397=0.03060 + 0.00337]
Epoch 82 [51.7s]: train==[0.03377=0.03038 + 0.00339]
Epoch 83 [52.9s]: train==[0.03316=0.02975 + 0.00341]
Epoch 84 [51.4s]: train==[0.03299=0.02955 + 0.00343]
Epoch 85 [51.6s]: train==[0.03269=0.02923 + 0.00346]
Epoch 86 [52.4s]: train==[0.03237=0.02890 + 0.00348]
Epoch 87 [52.5s]: train==[0.03223=0.02874 + 0.00350]
Epoch 88 [51.0s]: train==[0.03204=0.02852 + 0.00352]
Epoch 89 [50.6s]: train==[0.03182=0.02828 + 0.00354]
Epoch 90 [51.1s]: train==[0.03121=0.02765 + 0.00356]
Epoch 91 [52.3s]: train==[0.03127=0.02769 + 0.00358]
Epoch 92 [53.3s]: train==[0.03099=0.02738 + 0.00360]
Epoch 93 [53.1s]: train==[0.03089=0.02727 + 0.00362]
Epoch 94 [52.0s]: train==[0.03060=0.02696 + 0.00364]
Epoch 95 [52.5s]: train==[0.02998=0.02632 + 0.00366]
Epoch 96 [53.1s]: train==[0.03008=0.02640 + 0.00368]
Epoch 97 [51.4s]: train==[0.03000=0.02630 + 0.00370]
Epoch 98 [51.7s]: train==[0.02965=0.02593 + 0.00372]
Epoch 99 [51.9s]: train==[0.02928=0.02554 + 0.00374]
Epoch 100: train==[0.02913=0.02537 + 0.00376 + 0.00000], recall=[0.09199, 0.17803], hitrate=[0.85033, 0.96049], precision=[0.14979, 0.11902], ndcg=[0.16562, 0.18526]
Epoch 100 [4386.3s + 2665.4s]: test==[0.20376=0.19995 + 0.00381 + 0.00000], recall=[0.03326, 0.06542], hitrate=[0.20709, 0.35202], precision=[0.01403, 0.01139], ndcg=[0.02577, 0.03768]
Epoch 101 [51.7s]: train==[0.02900=0.02522 + 0.00378]
Epoch 102 [53.2s]: train==[0.02895=0.02515 + 0.00380]
Epoch 103 [53.2s]: train==[0.02854=0.02473 + 0.00382]
Epoch 104 [52.2s]: train==[0.02842=0.02458 + 0.00384]
Epoch 105 [52.2s]: train==[0.02813=0.02428 + 0.00385]
Epoch 106 [53.5s]: train==[0.02810=0.02422 + 0.00387]
Epoch 107 [52.5s]: train==[0.02785=0.02396 + 0.00389]
Epoch 108 [51.6s]: train==[0.02764=0.02373 + 0.00391]
Epoch 109 [53.5s]: train==[0.02757=0.02364 + 0.00393]
Epoch 110 [52.8s]: train==[0.02735=0.02340 + 0.00394]
Epoch 111 [49.9s]: train==[0.02718=0.02321 + 0.00396]
Epoch 112 [51.2s]: train==[0.02709=0.02311 + 0.00398]
Epoch 113 [52.6s]: train==[0.02685=0.02285 + 0.00400]
Epoch 114 [49.7s]: train==[0.02660=0.02258 + 0.00402]
Epoch 115 [51.5s]: train==[0.02639=0.02235 + 0.00403]
Epoch 116 [51.0s]: train==[0.02628=0.02223 + 0.00405]
Epoch 117 [52.2s]: train==[0.02608=0.02202 + 0.00407]
Epoch 118 [53.3s]: train==[0.02618=0.02209 + 0.00409]
Epoch 119 [53.5s]: train==[0.02572=0.02162 + 0.00410]
Epoch 120: train==[0.02564=0.02152 + 0.00412 + 0.00000], recall=[0.10176, 0.19687], hitrate=[0.87683, 0.97297], precision=[0.16271, 0.12909], ndcg=[0.17990, 0.20262]
Epoch 120 [4365.8s + 2666.2s]: test==[0.20341=0.19924 + 0.00417 + 0.00000], recall=[0.03401, 0.06732], hitrate=[0.21005, 0.35835], precision=[0.01433, 0.01166], ndcg=[0.02650, 0.03883]
Epoch 121 [51.9s]: train==[0.02573=0.02160 + 0.00413]
Epoch 122 [52.5s]: train==[0.02558=0.02143 + 0.00415]
Epoch 123 [52.6s]: train==[0.02541=0.02124 + 0.00417]
Epoch 124 [49.3s]: train==[0.02532=0.02113 + 0.00418]
Epoch 125 [51.6s]: train==[0.02501=0.02081 + 0.00420]
Epoch 126 [51.3s]: train==[0.02493=0.02071 + 0.00421]
Epoch 127 [53.2s]: train==[0.02476=0.02053 + 0.00423]
Epoch 128 [52.4s]: train==[0.02463=0.02039 + 0.00425]
Epoch 129 [50.8s]: train==[0.02445=0.02019 + 0.00426]
Epoch 130 [51.5s]: train==[0.02428=0.02000 + 0.00428]
Epoch 131 [51.7s]: train==[0.02419=0.01990 + 0.00429]
Epoch 132 [52.5s]: train==[0.02414=0.01983 + 0.00431]
Epoch 133 [52.6s]: train==[0.02402=0.01969 + 0.00433]
Epoch 134 [51.1s]: train==[0.02393=0.01959 + 0.00434]
Epoch 135 [52.0s]: train==[0.02377=0.01941 + 0.00435]
Epoch 136 [51.9s]: train==[0.02366=0.01929 + 0.00437]
Epoch 137 [52.6s]: train==[0.02358=0.01919 + 0.00438]
Epoch 138 [52.8s]: train==[0.02341=0.01901 + 0.00440]
Epoch 139 [51.7s]: train==[0.02330=0.01889 + 0.00441]
Epoch 140: train==[0.02309=0.01866 + 0.00443 + 0.00000], recall=[0.11170, 0.21546], hitrate=[0.89845, 0.98095], precision=[0.17538, 0.13871], ndcg=[0.19408, 0.21973]
Epoch 140 [4353.5s + 2673.8s]: test==[0.20384=0.19936 + 0.00448 + 0.00000], recall=[0.03456, 0.06911], hitrate=[0.21418, 0.36420], precision=[0.01455, 0.01193], ndcg=[0.02698, 0.03974]
Epoch 141 [52.3s]: train==[0.02310=0.01866 + 0.00444]
Epoch 142 [50.6s]: train==[0.02297=0.01851 + 0.00446]
Epoch 143 [52.1s]: train==[0.02285=0.01838 + 0.00447]
Epoch 144 [51.4s]: train==[0.02262=0.01813 + 0.00449]
Epoch 145 [51.7s]: train==[0.02281=0.01830 + 0.00450]
Epoch 146 [52.8s]: train==[0.02263=0.01812 + 0.00451]
Epoch 147 [52.0s]: train==[0.02242=0.01789 + 0.00453]
Epoch 148 [52.6s]: train==[0.02236=0.01782 + 0.00454]
Epoch 149 [51.7s]: train==[0.02219=0.01763 + 0.00455]
Epoch 150 [52.6s]: train==[0.02220=0.01763 + 0.00457]
Epoch 151 [52.8s]: train==[0.02195=0.01737 + 0.00458]
Epoch 152 [52.2s]: train==[0.02190=0.01730 + 0.00460]
Epoch 153 [51.5s]: train==[0.02179=0.01718 + 0.00461]
Epoch 154 [52.1s]: train==[0.02183=0.01720 + 0.00462]
Epoch 155 [51.1s]: train==[0.02161=0.01697 + 0.00464]
Epoch 156 [52.9s]: train==[0.02159=0.01694 + 0.00465]
Epoch 157 [51.0s]: train==[0.02138=0.01672 + 0.00466]
Epoch 158 [51.6s]: train==[0.02145=0.01677 + 0.00468]
Epoch 159 [49.8s]: train==[0.02124=0.01656 + 0.00469]
Epoch 160: train==[0.02120=0.01650 + 0.00470 + 0.00000], recall=[0.12145, 0.23433], hitrate=[0.91678, 0.98653], precision=[0.18754, 0.14833], ndcg=[0.20767, 0.23678]
Epoch 160 [4309.7s + 2628.3s]: test==[0.20435=0.19960 + 0.00475 + 0.00000], recall=[0.03518, 0.07017], hitrate=[0.21689, 0.36752], precision=[0.01476, 0.01209], ndcg=[0.02744, 0.04039]
Epoch 161 [48.7s]: train==[0.02128=0.01657 + 0.00471]
Epoch 162 [47.8s]: train==[0.02105=0.01633 + 0.00473]
Epoch 163 [47.3s]: train==[0.02094=0.01620 + 0.00474]
Epoch 164 [46.6s]: train==[0.02079=0.01604 + 0.00475]
Epoch 165 [45.6s]: train==[0.02071=0.01594 + 0.00477]
Epoch 166 [45.1s]: train==[0.02072=0.01594 + 0.00478]
Epoch 167 [46.6s]: train==[0.02051=0.01572 + 0.00479]
Epoch 168 [46.4s]: train==[0.02046=0.01566 + 0.00480]
Epoch 169 [45.1s]: train==[0.02061=0.01580 + 0.00481]
Epoch 170 [46.2s]: train==[0.02029=0.01547 + 0.00483]
Epoch 171 [47.2s]: train==[0.02015=0.01532 + 0.00484]
Epoch 172 [47.5s]: train==[0.02021=0.01536 + 0.00485]
Epoch 173 [48.0s]: train==[0.02011=0.01524 + 0.00486]
Epoch 174 [48.4s]: train==[0.01987=0.01500 + 0.00487]
Epoch 175 [48.3s]: train==[0.02011=0.01523 + 0.00488]
Epoch 176 [48.0s]: train==[0.01980=0.01491 + 0.00490]
Epoch 177 [48.4s]: train==[0.01991=0.01500 + 0.00491]
Epoch 178 [47.6s]: train==[0.01975=0.01483 + 0.00492]
Epoch 179 [48.0s]: train==[0.01959=0.01465 + 0.00493]
Epoch 180: train==[0.01948=0.01454 + 0.00494 + 0.00000], recall=[0.13166, 0.25355], hitrate=[0.93133, 0.99103], precision=[0.20014, 0.15794], ndcg=[0.22135, 0.25389]
Epoch 180 [4295.4s + 2618.3s]: test==[0.20498=0.19999 + 0.00499 + 0.00000], recall=[0.03597, 0.07121], hitrate=[0.21999, 0.37081], precision=[0.01505, 0.01225], ndcg=[0.02797, 0.04100]
Epoch 181 [49.0s]: train==[0.01958=0.01463 + 0.00495]
Epoch 182 [46.7s]: train==[0.01949=0.01453 + 0.00496]
Epoch 183 [44.9s]: train==[0.01931=0.01434 + 0.00497]
Epoch 184 [46.4s]: train==[0.01952=0.01453 + 0.00498]
Epoch 185 [45.7s]: train==[0.01927=0.01427 + 0.00500]
Epoch 186 [45.7s]: train==[0.01929=0.01429 + 0.00501]
Epoch 187 [45.5s]: train==[0.01923=0.01421 + 0.00502]
Epoch 188 [47.0s]: train==[0.01921=0.01418 + 0.00503]
Epoch 189 [47.5s]: train==[0.01908=0.01404 + 0.00504]
Epoch 190 [47.4s]: train==[0.01899=0.01394 + 0.00505]
Epoch 191 [46.2s]: train==[0.01877=0.01371 + 0.00506]
Epoch 192 [46.1s]: train==[0.01884=0.01377 + 0.00507]
Epoch 193 [46.7s]: train==[0.01884=0.01376 + 0.00508]
Epoch 194 [47.2s]: train==[0.01871=0.01362 + 0.00509]
Epoch 195 [46.9s]: train==[0.01878=0.01368 + 0.00510]
Epoch 196 [48.7s]: train==[0.01867=0.01356 + 0.00511]
Epoch 197 [47.6s]: train==[0.01876=0.01364 + 0.00512]
Epoch 198 [48.0s]: train==[0.01858=0.01345 + 0.00513]
Epoch 199 [48.4s]: train==[0.01857=0.01343 + 0.00514]
Epoch 200: train==[0.01830=0.01315 + 0.00515 + 0.00000], recall=[0.14192, 0.27295], hitrate=[0.94381, 0.99405], precision=[0.21272, 0.16756], ndcg=[0.23522, 0.27114]
Epoch 200 [4270.3s + 2623.8s]: test==[0.20634=0.20115 + 0.00519 + 0.00000], recall=[0.03650, 0.07213], hitrate=[0.22246, 0.37402], precision=[0.01527, 0.01238], ndcg=[0.02828, 0.04144]
Epoch 201 [48.1s]: train==[0.01824=0.01308 + 0.00516]
Epoch 202 [48.8s]: train==[0.01811=0.01294 + 0.00517]
Epoch 203 [48.1s]: train==[0.01826=0.01308 + 0.00518]
Epoch 204 [48.4s]: train==[0.01812=0.01293 + 0.00519]
Epoch 205 [47.4s]: train==[0.01820=0.01301 + 0.00520]
Epoch 206 [45.5s]: train==[0.01805=0.01284 + 0.00521]
Epoch 207 [45.9s]: train==[0.01793=0.01271 + 0.00522]
Epoch 208 [46.9s]: train==[0.01790=0.01268 + 0.00523]
Epoch 209 [48.6s]: train==[0.01797=0.01273 + 0.00523]
Epoch 210 [46.5s]: train==[0.01791=0.01267 + 0.00524]
Epoch 211 [47.8s]: train==[0.01791=0.01266 + 0.00525]
Epoch 212 [46.2s]: train==[0.01790=0.01264 + 0.00526]
Epoch 213 [48.5s]: train==[0.01774=0.01247 + 0.00527]
Epoch 214 [48.0s]: train==[0.01754=0.01226 + 0.00528]
Epoch 215 [48.0s]: train==[0.01762=0.01234 + 0.00529]
Epoch 216 [46.6s]: train==[0.01751=0.01221 + 0.00530]
Epoch 217 [47.3s]: train==[0.01743=0.01212 + 0.00531]
Epoch 218 [47.8s]: train==[0.01745=0.01213 + 0.00531]
Epoch 219 [48.2s]: train==[0.01742=0.01210 + 0.00532]
Epoch 220: train==[0.01735=0.01202 + 0.00533 + 0.00000], recall=[0.15229, 0.29185], hitrate=[0.95551, 0.99620], precision=[0.22502, 0.17696], ndcg=[0.24876, 0.28804]
Epoch 220 [4269.1s + 2632.6s]: test==[0.20681=0.20144 + 0.00537 + 0.00000], recall=[0.03696, 0.07265], hitrate=[0.22377, 0.37449], precision=[0.01543, 0.01246], ndcg=[0.02870, 0.04189]
Epoch 221 [48.0s]: train==[0.01733=0.01199 + 0.00534]
Epoch 222 [48.1s]: train==[0.01722=0.01187 + 0.00535]
Epoch 223 [48.3s]: train==[0.01733=0.01197 + 0.00536]
Epoch 224 [47.2s]: train==[0.01708=0.01171 + 0.00536]
Epoch 225 [47.7s]: train==[0.01716=0.01178 + 0.00537]
Epoch 226 [47.3s]: train==[0.01706=0.01168 + 0.00538]
Epoch 227 [46.5s]: train==[0.01704=0.01165 + 0.00539]
Epoch 228 [46.6s]: train==[0.01696=0.01156 + 0.00540]
Epoch 229 [47.2s]: train==[0.01703=0.01163 + 0.00541]
Epoch 230 [46.0s]: train==[0.01695=0.01154 + 0.00541]
Epoch 231 [46.2s]: train==[0.01692=0.01150 + 0.00542]
Epoch 232 [47.8s]: train==[0.01690=0.01147 + 0.00543]
Epoch 233 [59.8s]: train==[0.01686=0.01142 + 0.00544]
Epoch 234 [61.3s]: train==[0.01689=0.01145 + 0.00544]
Epoch 235 [61.4s]: train==[0.01666=0.01121 + 0.00545]
Epoch 236 [61.8s]: train==[0.01670=0.01124 + 0.00546]
Epoch 237 [60.6s]: train==[0.01661=0.01114 + 0.00547]
Epoch 238 [60.2s]: train==[0.01657=0.01109 + 0.00548]
Epoch 239 [47.0s]: train==[0.01666=0.01117 + 0.00548]
Epoch 240: train==[0.01672=0.01123 + 0.00549 + 0.00000], recall=[0.16219, 0.31078], hitrate=[0.96245, 0.99707], precision=[0.23710, 0.18641], ndcg=[0.26233, 0.30513]
Epoch 240 [4303.5s + 2619.6s]: test==[0.20671=0.20119 + 0.00552 + 0.00000], recall=[0.03739, 0.07385], hitrate=[0.22519, 0.37833], precision=[0.01557, 0.01264], ndcg=[0.02901, 0.04251]
Epoch 241 [48.4s]: train==[0.01653=0.01103 + 0.00550]
Epoch 242 [49.3s]: train==[0.01646=0.01096 + 0.00550]
Epoch 243 [47.9s]: train==[0.01649=0.01098 + 0.00551]
Epoch 244 [46.8s]: train==[0.01628=0.01076 + 0.00552]
Epoch 245 [47.8s]: train==[0.01621=0.01069 + 0.00553]
Epoch 246 [47.6s]: train==[0.01623=0.01069 + 0.00553]
Epoch 247 [47.8s]: train==[0.01629=0.01075 + 0.00554]
Epoch 248 [48.4s]: train==[0.01623=0.01069 + 0.00555]
Epoch 249 [47.1s]: train==[0.01609=0.01054 + 0.00555]
Epoch 250 [48.1s]: train==[0.01618=0.01062 + 0.00556]
Epoch 251 [47.9s]: train==[0.01607=0.01051 + 0.00557]
Epoch 252 [47.9s]: train==[0.01611=0.01053 + 0.00558]
Epoch 253 [46.2s]: train==[0.01608=0.01050 + 0.00558]
Epoch 254 [45.5s]: train==[0.01608=0.01049 + 0.00559]
Epoch 255 [47.1s]: train==[0.01606=0.01047 + 0.00559]
Epoch 256 [44.8s]: train==[0.01600=0.01040 + 0.00560]
Epoch 257 [47.1s]: train==[0.01591=0.01030 + 0.00561]
Epoch 258 [47.3s]: train==[0.01583=0.01021 + 0.00561]
Epoch 259 [47.0s]: train==[0.01585=0.01023 + 0.00562]
Epoch 260: train==[0.01575=0.01012 + 0.00563 + 0.00000], recall=[0.17179, 0.32908], hitrate=[0.96968, 0.99782], precision=[0.24869, 0.19538], ndcg=[0.27498, 0.32122]
Epoch 260 [4238.0s + 2619.7s]: test==[0.20800=0.20235 + 0.00565 + 0.00000], recall=[0.03804, 0.07481], hitrate=[0.22907, 0.38206], precision=[0.01581, 0.01279], ndcg=[0.02949, 0.04308]
Epoch 261 [47.4s]: train==[0.01567=0.01004 + 0.00563]
Epoch 262 [47.6s]: train==[0.01574=0.01010 + 0.00564]
Epoch 263 [49.3s]: train==[0.01570=0.01005 + 0.00565]
Epoch 264 [48.3s]: train==[0.01575=0.01010 + 0.00565]
Epoch 265 [47.4s]: train==[0.01571=0.01005 + 0.00566]
Epoch 266 [47.4s]: train==[0.01562=0.00996 + 0.00566]
Epoch 267 [48.1s]: train==[0.01572=0.01005 + 0.00567]
Epoch 268 [48.2s]: train==[0.01567=0.00999 + 0.00567]
Epoch 269 [47.1s]: train==[0.01562=0.00994 + 0.00568]
Epoch 270 [47.5s]: train==[0.01562=0.00994 + 0.00569]
Epoch 271 [47.8s]: train==[0.01543=0.00974 + 0.00569]
Epoch 272 [47.1s]: train==[0.01547=0.00977 + 0.00570]
Epoch 273 [47.6s]: train==[0.01539=0.00968 + 0.00571]
Epoch 274 [47.4s]: train==[0.01547=0.00976 + 0.00571]
Epoch 275 [47.2s]: train==[0.01537=0.00966 + 0.00572]
Epoch 276 [45.8s]: train==[0.01534=0.00962 + 0.00572]
Epoch 277 [47.0s]: train==[0.01534=0.00961 + 0.00573]
Epoch 278 [45.9s]: train==[0.01523=0.00949 + 0.00573]
Epoch 279 [47.5s]: train==[0.01542=0.00968 + 0.00574]
Epoch 280: train==[0.01527=0.00953 + 0.00575 + 0.00000], recall=[0.18135, 0.34650], hitrate=[0.97430, 0.99867], precision=[0.25991, 0.20398], ndcg=[0.28716, 0.33658]
Epoch 280 [4221.7s + 2629.0s]: test==[0.20807=0.20230 + 0.00577 + 0.00000], recall=[0.03818, 0.07504], hitrate=[0.22829, 0.38314], precision=[0.01582, 0.01281], ndcg=[0.02950, 0.04315]
Epoch 281 [46.7s]: train==[0.01521=0.00946 + 0.00575]
Epoch 282 [45.2s]: train==[0.01523=0.00947 + 0.00576]
Epoch 283 [45.8s]: train==[0.01525=0.00949 + 0.00576]
Epoch 284 [46.4s]: train==[0.01530=0.00953 + 0.00577]
Epoch 285 [44.8s]: train==[0.01517=0.00940 + 0.00577]
Epoch 286 [47.2s]: train==[0.01510=0.00932 + 0.00578]
Epoch 287 [47.8s]: train==[0.01519=0.00941 + 0.00578]
Epoch 288 [46.4s]: train==[0.01510=0.00932 + 0.00579]
Epoch 289 [45.3s]: train==[0.01507=0.00928 + 0.00579]
Epoch 290 [47.0s]: train==[0.01509=0.00929 + 0.00580]
Epoch 291 [49.0s]: train==[0.01493=0.00913 + 0.00581]
Epoch 292 [45.9s]: train==[0.01491=0.00910 + 0.00581]
Epoch 293 [46.5s]: train==[0.01487=0.00906 + 0.00581]
Epoch 294 [45.9s]: train==[0.01494=0.00912 + 0.00582]
Epoch 295 [47.8s]: train==[0.01484=0.00902 + 0.00582]
Epoch 296 [48.3s]: train==[0.01479=0.00896 + 0.00583]
Epoch 297 [47.6s]: train==[0.01487=0.00904 + 0.00583]
Epoch 298 [46.9s]: train==[0.01482=0.00899 + 0.00584]
Epoch 299 [46.5s]: train==[0.01480=0.00895 + 0.00584]
Epoch 300: train==[0.01471=0.00886 + 0.00585 + 0.00000], recall=[0.19087, 0.36352], hitrate=[0.97865, 0.99903], precision=[0.27098, 0.21232], ndcg=[0.29919, 0.35162]
Epoch 300 [4221.5s + 2634.6s]: test==[0.20837=0.20252 + 0.00586 + 0.00000], recall=[0.03831, 0.07575], hitrate=[0.22928, 0.38574], precision=[0.01591, 0.01293], ndcg=[0.02964, 0.04349]
Epoch 301 [48.2s]: train==[0.01470=0.00884 + 0.00585]
Epoch 302 [47.5s]: train==[0.01472=0.00887 + 0.00586]
Epoch 303 [48.6s]: train==[0.01470=0.00883 + 0.00586]
Epoch 304 [48.4s]: train==[0.01466=0.00880 + 0.00587]
Epoch 305 [48.7s]: train==[0.01465=0.00878 + 0.00587]
Epoch 306 [48.4s]: train==[0.01458=0.00871 + 0.00588]
Epoch 307 [48.1s]: train==[0.01479=0.00891 + 0.00588]
Epoch 308 [48.4s]: train==[0.01452=0.00863 + 0.00589]
Epoch 309 [48.0s]: train==[0.01458=0.00870 + 0.00589]
Epoch 310 [47.0s]: train==[0.01456=0.00867 + 0.00589]
Epoch 311 [47.3s]: train==[0.01448=0.00858 + 0.00590]
Epoch 312 [47.2s]: train==[0.01442=0.00852 + 0.00590]
Epoch 313 [45.3s]: train==[0.01447=0.00856 + 0.00591]
Epoch 314 [46.6s]: train==[0.01442=0.00851 + 0.00591]
Epoch 315 [45.6s]: train==[0.01438=0.00847 + 0.00592]
Epoch 316 [46.6s]: train==[0.01447=0.00855 + 0.00592]
Epoch 317 [48.7s]: train==[0.01447=0.00854 + 0.00593]
Epoch 318 [49.8s]: train==[0.01429=0.00836 + 0.00593]
Epoch 319 [48.7s]: train==[0.01438=0.00844 + 0.00593]
Epoch 320: train==[0.01435=0.00841 + 0.00594 + 0.00000], recall=[0.19898, 0.37889], hitrate=[0.98250, 0.99951], precision=[0.28082, 0.21997], ndcg=[0.30991, 0.36523]
Epoch 320 [4212.1s + 2610.5s]: test==[0.20950=0.20355 + 0.00594 + 0.00000], recall=[0.03890, 0.07602], hitrate=[0.23226, 0.38726], precision=[0.01613, 0.01299], ndcg=[0.03007, 0.04381]
Epoch 321 [47.2s]: train==[0.01433=0.00839 + 0.00594]
Epoch 322 [46.8s]: train==[0.01424=0.00830 + 0.00594]
Epoch 323 [46.1s]: train==[0.01426=0.00831 + 0.00595]
Epoch 324 [47.9s]: train==[0.01420=0.00824 + 0.00595]
Epoch 325 [46.7s]: train==[0.01426=0.00830 + 0.00596]
Epoch 326 [47.0s]: train==[0.01417=0.00821 + 0.00596]
Epoch 327 [45.6s]: train==[0.01416=0.00819 + 0.00596]
Epoch 328 [47.4s]: train==[0.01415=0.00818 + 0.00597]
Epoch 329 [45.5s]: train==[0.01416=0.00819 + 0.00597]
Epoch 330 [45.8s]: train==[0.01410=0.00812 + 0.00598]
Epoch 331 [46.8s]: train==[0.01417=0.00818 + 0.00598]
Epoch 332 [47.8s]: train==[0.01412=0.00813 + 0.00599]
Epoch 333 [49.0s]: train==[0.01409=0.00810 + 0.00599]
Epoch 334 [48.4s]: train==[0.01402=0.00802 + 0.00599]
Epoch 335 [48.8s]: train==[0.01414=0.00815 + 0.00599]
Epoch 336 [47.9s]: train==[0.01404=0.00804 + 0.00600]
Epoch 337 [48.3s]: train==[0.01405=0.00804 + 0.00600]
Epoch 338 [48.3s]: train==[0.01392=0.00792 + 0.00601]
Epoch 339 [48.3s]: train==[0.01399=0.00798 + 0.00601]
Epoch 340: train==[0.01403=0.00802 + 0.00601 + 0.00000], recall=[0.20717, 0.39382], hitrate=[0.98484, 0.99958], precision=[0.29032, 0.22737], ndcg=[0.31994, 0.37818]
Epoch 340 [4198.8s + 2606.9s]: test==[0.20899=0.20298 + 0.00601 + 0.00000], recall=[0.03893, 0.07609], hitrate=[0.23253, 0.38785], precision=[0.01613, 0.01298], ndcg=[0.03005, 0.04381]
Epoch 341 [48.3s]: train==[0.01401=0.00799 + 0.00602]
Epoch 342 [48.1s]: train==[0.01399=0.00797 + 0.00602]
Epoch 343 [48.0s]: train==[0.01389=0.00786 + 0.00602]
Epoch 344 [48.0s]: train==[0.01369=0.00767 + 0.00603]
Epoch 345 [46.2s]: train==[0.01398=0.00795 + 0.00603]
Epoch 346 [45.9s]: train==[0.01391=0.00788 + 0.00603]
Epoch 347 [45.3s]: train==[0.01395=0.00791 + 0.00604]
Epoch 348 [45.9s]: train==[0.01385=0.00781 + 0.00604]
Epoch 349 [47.7s]: train==[0.01385=0.00781 + 0.00604]
Epoch 350 [48.1s]: train==[0.01380=0.00775 + 0.00605]
Epoch 351 [48.5s]: train==[0.01378=0.00773 + 0.00605]
Epoch 352 [48.8s]: train==[0.01385=0.00780 + 0.00605]
Epoch 353 [48.0s]: train==[0.01375=0.00769 + 0.00606]
Epoch 354 [48.2s]: train==[0.01375=0.00769 + 0.00606]
Epoch 355 [45.7s]: train==[0.01375=0.00769 + 0.00606]
Epoch 356 [47.4s]: train==[0.01378=0.00771 + 0.00607]
Epoch 357 [45.7s]: train==[0.01367=0.00760 + 0.00607]
Epoch 358 [48.0s]: train==[0.01362=0.00754 + 0.00607]
Epoch 359 [48.2s]: train==[0.01372=0.00764 + 0.00608]
Epoch 360: train==[0.01359=0.00750 + 0.00608 + 0.00000], recall=[0.21465, 0.40742], hitrate=[0.98682, 0.99968], precision=[0.29916, 0.23414], ndcg=[0.32931, 0.39012]
Epoch 360 [4187.9s + 2615.8s]: test==[0.20941=0.20334 + 0.00608 + 0.00000], recall=[0.03936, 0.07695], hitrate=[0.23344, 0.39104], precision=[0.01629, 0.01312], ndcg=[0.03035, 0.04426]
Epoch 361 [48.7s]: train==[0.01358=0.00749 + 0.00608]
Epoch 362 [47.7s]: train==[0.01363=0.00754 + 0.00609]
Epoch 363 [45.0s]: train==[0.01363=0.00754 + 0.00609]
Epoch 364 [46.5s]: train==[0.01366=0.00756 + 0.00609]
Epoch 365 [45.8s]: train==[0.01362=0.00753 + 0.00609]
Epoch 366 [45.5s]: train==[0.01360=0.00750 + 0.00610]
Epoch 367 [45.3s]: train==[0.01356=0.00746 + 0.00610]
Epoch 368 [45.0s]: train==[0.01357=0.00747 + 0.00610]
Epoch 369 [46.9s]: train==[0.01353=0.00742 + 0.00611]
Epoch 370 [46.0s]: train==[0.01343=0.00732 + 0.00611]
Epoch 371 [46.5s]: train==[0.01350=0.00739 + 0.00611]
Epoch 372 [48.8s]: train==[0.01344=0.00733 + 0.00611]
Epoch 373 [48.4s]: train==[0.01338=0.00726 + 0.00612]
Epoch 374 [47.0s]: train==[0.01350=0.00737 + 0.00612]
Epoch 375 [47.2s]: train==[0.01340=0.00728 + 0.00612]
Epoch 376 [47.9s]: train==[0.01346=0.00733 + 0.00613]
Epoch 377 [48.0s]: train==[0.01333=0.00720 + 0.00613]
Epoch 378 [47.8s]: train==[0.01341=0.00728 + 0.00613]
Epoch 379 [48.0s]: train==[0.01340=0.00726 + 0.00614]
Epoch 380: train==[0.01334=0.00721 + 0.00614 + 0.00000], recall=[0.22206, 0.42022], hitrate=[0.98950, 0.99989], precision=[0.30795, 0.24068], ndcg=[0.33855, 0.40145]
Epoch 380 [4180.7s + 2626.4s]: test==[0.20990=0.20377 + 0.00613 + 0.00000], recall=[0.03970, 0.07757], hitrate=[0.23589, 0.39262], precision=[0.01639, 0.01321], ndcg=[0.03060, 0.04462]
Epoch 381 [47.9s]: train==[0.01340=0.00726 + 0.00614]
Epoch 382 [47.9s]: train==[0.01344=0.00729 + 0.00614]
Epoch 383 [48.3s]: train==[0.01338=0.00724 + 0.00615]
Epoch 384 [47.6s]: train==[0.01333=0.00719 + 0.00615]
Epoch 385 [48.0s]: train==[0.01334=0.00719 + 0.00615]
Epoch 386 [48.9s]: train==[0.01334=0.00718 + 0.00615]
Epoch 387 [48.3s]: train==[0.01337=0.00721 + 0.00616]
Epoch 388 [49.0s]: train==[0.01328=0.00713 + 0.00616]
Epoch 389 [47.3s]: train==[0.01331=0.00715 + 0.00616]
Epoch 390 [46.7s]: train==[0.01325=0.00708 + 0.00616]
Epoch 391 [46.7s]: train==[0.01327=0.00711 + 0.00617]
Epoch 392 [45.9s]: train==[0.01323=0.00706 + 0.00617]
Epoch 393 [45.4s]: train==[0.01332=0.00715 + 0.00617]
Epoch 394 [47.9s]: train==[0.01320=0.00703 + 0.00617]
Epoch 395 [47.8s]: train==[0.01315=0.00697 + 0.00618]
Epoch 396 [48.0s]: train==[0.01323=0.00705 + 0.00618]
Epoch 397 [48.2s]: train==[0.01320=0.00702 + 0.00618]
Epoch 398 [48.6s]: train==[0.01317=0.00698 + 0.00618]
Epoch 399 [47.5s]: train==[0.01315=0.00697 + 0.00619]
Epoch 400: train==[0.01311=0.00692 + 0.00619 + 0.00000], recall=[0.22845, 0.43186], hitrate=[0.99026, 0.99989], precision=[0.31547, 0.24658], ndcg=[0.34672, 0.41181]
Epoch 400 [4180.9s + 2627.9s]: test==[0.21133=0.20516 + 0.00617 + 0.00000], recall=[0.03987, 0.07739], hitrate=[0.23638, 0.39338], precision=[0.01645, 0.01320], ndcg=[0.03070, 0.04461]
Epoch 401 [47.9s]: train==[0.01307=0.00688 + 0.00619]
Epoch 402 [47.5s]: train==[0.01319=0.00700 + 0.00619]
Epoch 403 [46.9s]: train==[0.01328=0.00709 + 0.00619]
Epoch 404 [47.1s]: train==[0.01322=0.00702 + 0.00620]
Epoch 405 [48.0s]: train==[0.01312=0.00693 + 0.00620]
Epoch 406 [47.8s]: train==[0.01301=0.00681 + 0.00620]
Epoch 407 [48.4s]: train==[0.01309=0.00689 + 0.00620]
Epoch 408 [48.1s]: train==[0.01317=0.00696 + 0.00621]
Epoch 409 [48.7s]: train==[0.01311=0.00690 + 0.00621]
Epoch 410 [47.7s]: train==[0.01305=0.00684 + 0.00621]
Epoch 411 [47.5s]: train==[0.01302=0.00680 + 0.00621]
Epoch 412 [46.8s]: train==[0.01298=0.00677 + 0.00622]
Epoch 413 [47.2s]: train==[0.01291=0.00669 + 0.00622]
Epoch 414 [48.3s]: train==[0.01291=0.00669 + 0.00622]
Epoch 415 [47.8s]: train==[0.01296=0.00674 + 0.00622]
Epoch 416 [46.5s]: train==[0.01297=0.00674 + 0.00622]
Epoch 417 [48.3s]: train==[0.01290=0.00668 + 0.00622]
Epoch 418 [49.0s]: train==[0.01291=0.00668 + 0.00623]
Epoch 419 [48.0s]: train==[0.01292=0.00669 + 0.00623]
Epoch 420: train==[0.01300=0.00676 + 0.00623 + 0.00000], recall=[0.23495, 0.44284], hitrate=[0.99168, 0.99985], precision=[0.32323, 0.25213], ndcg=[0.35489, 0.42170]
Epoch 420 [4173.6s + 2619.8s]: test==[0.21152=0.20531 + 0.00621 + 0.00000], recall=[0.03991, 0.07767], hitrate=[0.23688, 0.39305], precision=[0.01651, 0.01322], ndcg=[0.03081, 0.04477]
Epoch 421 [47.1s]: train==[0.01297=0.00673 + 0.00623]
Epoch 422 [47.9s]: train==[0.01291=0.00667 + 0.00624]
Epoch 423 [46.3s]: train==[0.01290=0.00666 + 0.00624]
Epoch 424 [46.0s]: train==[0.01295=0.00671 + 0.00624]
Epoch 425 [45.6s]: train==[0.01289=0.00665 + 0.00624]
Epoch 426 [45.1s]: train==[0.01293=0.00668 + 0.00625]
Epoch 427 [46.8s]: train==[0.01293=0.00668 + 0.00625]
Epoch 428 [45.2s]: train==[0.01284=0.00659 + 0.00625]
Epoch 429 [45.6s]: train==[0.01284=0.00659 + 0.00625]
Epoch 430 [46.8s]: train==[0.01281=0.00655 + 0.00625]
Epoch 431 [48.0s]: train==[0.01280=0.00654 + 0.00625]
Epoch 432 [47.2s]: train==[0.01291=0.00665 + 0.00626]
Epoch 433 [47.5s]: train==[0.01287=0.00662 + 0.00626]
Epoch 434 [48.7s]: train==[0.01273=0.00647 + 0.00626]
Epoch 435 [48.3s]: train==[0.01282=0.00656 + 0.00626]
Epoch 436 [48.2s]: train==[0.01283=0.00657 + 0.00626]
Epoch 437 [48.3s]: train==[0.01287=0.00660 + 0.00626]
Epoch 438 [49.1s]: train==[0.01283=0.00656 + 0.00626]
Epoch 439 [48.8s]: train==[0.01264=0.00638 + 0.00627]
Epoch 440: train==[0.01275=0.00648 + 0.00627 + 0.00000], recall=[0.24080, 0.45353], hitrate=[0.99234, 0.99994], precision=[0.33017, 0.25759], ndcg=[0.36206, 0.43095]
Epoch 440 [4162.8s + 2618.4s]: test==[0.21224=0.20599 + 0.00625 + 0.00000], recall=[0.04023, 0.07806], hitrate=[0.23726, 0.39427], precision=[0.01658, 0.01327], ndcg=[0.03097, 0.04495]
Epoch 441 [48.5s]: train==[0.01270=0.00643 + 0.00627]
Epoch 442 [48.3s]: train==[0.01268=0.00641 + 0.00627]
Epoch 443 [48.4s]: train==[0.01271=0.00643 + 0.00628]
Epoch 444 [47.9s]: train==[0.01273=0.00645 + 0.00628]
Epoch 445 [46.9s]: train==[0.01280=0.00652 + 0.00628]
Epoch 446 [47.6s]: train==[0.01275=0.00647 + 0.00628]
Epoch 447 [48.3s]: train==[0.01274=0.00646 + 0.00628]
Epoch 448 [47.4s]: train==[0.01273=0.00645 + 0.00628]
Epoch 449 [48.1s]: train==[0.01261=0.00632 + 0.00629]
Epoch 450 [47.2s]: train==[0.01267=0.00638 + 0.00629]
Epoch 451 [48.8s]: train==[0.01269=0.00640 + 0.00629]
Epoch 452 [47.9s]: train==[0.01267=0.00638 + 0.00629]
Epoch 453 [47.1s]: train==[0.01263=0.00634 + 0.00629]
Epoch 454 [48.3s]: train==[0.01258=0.00629 + 0.00630]
Epoch 455 [48.1s]: train==[0.01261=0.00632 + 0.00630]
Epoch 456 [48.8s]: train==[0.01268=0.00638 + 0.00630]
Epoch 457 [48.5s]: train==[0.01257=0.00627 + 0.00630]
Epoch 458 [47.4s]: train==[0.01259=0.00629 + 0.00630]
Epoch 459 [48.0s]: train==[0.01256=0.00626 + 0.00630]
Epoch 460: train==[0.01269=0.00638 + 0.00631 + 0.00000], recall=[0.24617, 0.46325], hitrate=[0.99326, 0.99992], precision=[0.33652, 0.26250], ndcg=[0.36873, 0.43947]
Epoch 460 [4166.7s + 2614.2s]: test==[0.21224=0.20596 + 0.00628 + 0.00000], recall=[0.04008, 0.07840], hitrate=[0.23771, 0.39541], precision=[0.01656, 0.01334], ndcg=[0.03093, 0.04511]
Epoch 461 [48.4s]: train==[0.01256=0.00625 + 0.00631]
Epoch 462 [47.4s]: train==[0.01261=0.00631 + 0.00631]
Epoch 463 [48.7s]: train==[0.01257=0.00626 + 0.00631]
Epoch 464 [47.5s]: train==[0.01265=0.00634 + 0.00631]
Epoch 465 [48.2s]: train==[0.01252=0.00621 + 0.00631]
Epoch 466 [48.4s]: train==[0.01252=0.00621 + 0.00631]
Epoch 467 [48.0s]: train==[0.01254=0.00622 + 0.00632]
Epoch 468 [47.9s]: train==[0.01256=0.00624 + 0.00632]
Epoch 469 [48.1s]: train==[0.01249=0.00617 + 0.00632]
Epoch 470 [47.8s]: train==[0.01251=0.00619 + 0.00632]
Epoch 471 [47.0s]: train==[0.01252=0.00620 + 0.00632]
Epoch 472 [46.0s]: train==[0.01250=0.00617 + 0.00632]
Epoch 473 [45.3s]: train==[0.01257=0.00625 + 0.00632]
Epoch 474 [45.5s]: train==[0.01243=0.00610 + 0.00633]
Epoch 475 [46.5s]: train==[0.01245=0.00612 + 0.00633]
Epoch 476 [47.7s]: train==[0.01259=0.00626 + 0.00633]
Epoch 477 [48.3s]: train==[0.01243=0.00610 + 0.00633]
Epoch 478 [48.1s]: train==[0.01247=0.00614 + 0.00633]
Epoch 479 [48.5s]: train==[0.01247=0.00614 + 0.00633]
Epoch 480: train==[0.01246=0.00612 + 0.00633 + 0.00000], recall=[0.25073, 0.47116], hitrate=[0.99434, 0.99994], precision=[0.34214, 0.26669], ndcg=[0.37442, 0.44648]
Epoch 480 [4165.9s + 2619.8s]: test==[0.21146=0.20515 + 0.00630 + 0.00000], recall=[0.04052, 0.07875], hitrate=[0.23889, 0.39676], precision=[0.01668, 0.01337], ndcg=[0.03128, 0.04540]
Epoch 481 [46.5s]: train==[0.01250=0.00617 + 0.00634]
Epoch 482 [45.3s]: train==[0.01257=0.00623 + 0.00634]
Epoch 483 [45.6s]: train==[0.01241=0.00607 + 0.00634]
Epoch 484 [46.2s]: train==[0.01248=0.00614 + 0.00634]
Epoch 485 [45.6s]: train==[0.01243=0.00608 + 0.00634]
Epoch 486 [45.5s]: train==[0.01252=0.00618 + 0.00634]
Epoch 487 [48.1s]: train==[0.01249=0.00615 + 0.00635]
Epoch 488 [47.8s]: train==[0.01241=0.00606 + 0.00635]
Epoch 489 [49.1s]: train==[0.01242=0.00607 + 0.00635]
Epoch 490 [47.5s]: train==[0.01236=0.00601 + 0.00635]
Epoch 491 [47.4s]: train==[0.01236=0.00601 + 0.00635]
Epoch 492 [47.9s]: train==[0.01236=0.00601 + 0.00635]
Epoch 493 [48.5s]: train==[0.01247=0.00612 + 0.00635]
Epoch 494 [47.5s]: train==[0.01239=0.00604 + 0.00635]
Epoch 495 [48.5s]: train==[0.01233=0.00598 + 0.00635]
Epoch 496 [48.4s]: train==[0.01242=0.00606 + 0.00636]
Epoch 497 [47.1s]: train==[0.01225=0.00589 + 0.00636]
Epoch 498 [46.8s]: train==[0.01241=0.00605 + 0.00636]
Epoch 499 [46.9s]: train==[0.01237=0.00601 + 0.00636]
Epoch 500: train==[0.01241=0.00605 + 0.00636 + 0.00000], recall=[0.25575, 0.47973], hitrate=[0.99426, 0.99998], precision=[0.34813, 0.27113], ndcg=[0.38060, 0.45407]
Epoch 500 [4145.9s + 2621.3s]: test==[0.21275=0.20642 + 0.00633 + 0.00000], recall=[0.04053, 0.07890], hitrate=[0.23916, 0.39670], precision=[0.01674, 0.01342], ndcg=[0.03130, 0.04547]
Epoch 501 [49.1s]: train==[0.01234=0.00598 + 0.00636]
Epoch 502 [46.7s]: train==[0.01229=0.00593 + 0.00636]
Epoch 503 [47.2s]: train==[0.01238=0.00602 + 0.00636]
Epoch 504 [48.2s]: train==[0.01236=0.00600 + 0.00637]
Epoch 505 [48.3s]: train==[0.01240=0.00604 + 0.00637]
Epoch 506 [47.0s]: train==[0.01238=0.00601 + 0.00637]
Epoch 507 [45.7s]: train==[0.01226=0.00590 + 0.00637]
Epoch 508 [46.2s]: train==[0.01231=0.00594 + 0.00637]
Epoch 509 [46.4s]: train==[0.01240=0.00603 + 0.00637]
Epoch 510 [47.2s]: train==[0.01224=0.00587 + 0.00637]
Epoch 511 [46.7s]: train==[0.01226=0.00588 + 0.00637]
Epoch 512 [46.9s]: train==[0.01229=0.00592 + 0.00637]
Epoch 513 [48.0s]: train==[0.01225=0.00587 + 0.00638]
Epoch 514 [47.3s]: train==[0.01222=0.00584 + 0.00638]
Epoch 515 [46.4s]: train==[0.01231=0.00594 + 0.00638]
Epoch 516 [46.1s]: train==[0.01230=0.00592 + 0.00638]
Epoch 517 [48.4s]: train==[0.01222=0.00584 + 0.00638]
Epoch 518 [47.6s]: train==[0.01227=0.00589 + 0.00638]
Epoch 519 [46.8s]: train==[0.01222=0.00584 + 0.00638]
Epoch 520: train==[0.01221=0.00583 + 0.00638 + 0.00000], recall=[0.25991, 0.48656], hitrate=[0.99451, 0.99998], precision=[0.35288, 0.27474], ndcg=[0.38551, 0.46018]
Epoch 520 [4150.9s + 2621.4s]: test==[0.21363=0.20728 + 0.00634 + 0.00000], recall=[0.04043, 0.07890], hitrate=[0.23908, 0.39684], precision=[0.01668, 0.01342], ndcg=[0.03122, 0.04546]
Epoch 521 [47.9s]: train==[0.01224=0.00585 + 0.00639]
Epoch 522 [48.1s]: train==[0.01222=0.00583 + 0.00639]
Epoch 523 [48.2s]: train==[0.01218=0.00580 + 0.00639]
Epoch 524 [48.1s]: train==[0.01216=0.00577 + 0.00639]
Epoch 525 [47.4s]: train==[0.01223=0.00584 + 0.00639]
Epoch 526 [48.1s]: train==[0.01223=0.00584 + 0.00639]
Epoch 527 [47.7s]: train==[0.01225=0.00586 + 0.00639]
Epoch 528 [48.3s]: train==[0.01222=0.00583 + 0.00639]
Epoch 529 [47.9s]: train==[0.01218=0.00578 + 0.00640]
Epoch 530 [48.2s]: train==[0.01216=0.00577 + 0.00640]
Epoch 531 [47.5s]: train==[0.01208=0.00568 + 0.00640]
Epoch 532 [47.1s]: train==[0.01208=0.00568 + 0.00640]
Epoch 533 [47.6s]: train==[0.01215=0.00575 + 0.00640]
Epoch 534 [48.6s]: train==[0.01218=0.00578 + 0.00640]
Epoch 535 [47.3s]: train==[0.01215=0.00575 + 0.00640]
Epoch 536 [44.6s]: train==[0.01218=0.00578 + 0.00640]
Epoch 537 [46.1s]: train==[0.01224=0.00584 + 0.00640]
Epoch 538 [46.4s]: train==[0.01208=0.00567 + 0.00640]
Epoch 539 [46.2s]: train==[0.01212=0.00572 + 0.00641]
Epoch 540: train==[0.01211=0.00570 + 0.00641 + 0.00000], recall=[0.26340, 0.49224], hitrate=[0.99518, 0.99996], precision=[0.35723, 0.27777], ndcg=[0.38998, 0.46544]
Epoch 540 [4141.4s + 2619.5s]: test==[0.21333=0.20696 + 0.00637 + 0.00000], recall=[0.04083, 0.07915], hitrate=[0.24125, 0.39767], precision=[0.01686, 0.01345], ndcg=[0.03147, 0.04562]
Epoch 541 [47.7s]: train==[0.01218=0.00577 + 0.00641]
Epoch 542 [47.1s]: train==[0.01216=0.00575 + 0.00641]
Epoch 543 [48.9s]: train==[0.01212=0.00571 + 0.00641]
Epoch 544 [47.8s]: train==[0.01215=0.00573 + 0.00641]
Epoch 545 [47.4s]: train==[0.01214=0.00573 + 0.00641]
Epoch 546 [48.6s]: train==[0.01211=0.00570 + 0.00641]
Epoch 547 [48.4s]: train==[0.01215=0.00574 + 0.00641]
Epoch 548 [45.3s]: train==[0.01206=0.00565 + 0.00641]
Epoch 549 [45.5s]: train==[0.01209=0.00568 + 0.00642]
Epoch 550 [46.7s]: train==[0.01212=0.00570 + 0.00642]
Epoch 551 [47.8s]: train==[0.01210=0.00568 + 0.00642]
Epoch 552 [49.0s]: train==[0.01208=0.00566 + 0.00642]
Epoch 553 [47.7s]: train==[0.01207=0.00565 + 0.00642]
Epoch 554 [48.7s]: train==[0.01213=0.00571 + 0.00642]
Epoch 555 [46.6s]: train==[0.01198=0.00556 + 0.00642]
Epoch 556 [46.6s]: train==[0.01205=0.00563 + 0.00642]
Epoch 557 [47.1s]: train==[0.01206=0.00564 + 0.00642]
Epoch 558 [46.6s]: train==[0.01206=0.00564 + 0.00642]
Epoch 559 [46.8s]: train==[0.01204=0.00562 + 0.00642]
Epoch 560: train==[0.01209=0.00566 + 0.00643 + 0.00000], recall=[0.26681, 0.49872], hitrate=[0.99586, 0.99994], precision=[0.36129, 0.28119], ndcg=[0.39380, 0.47069]
Epoch 560 [4141.7s + 2625.4s]: test==[0.21391=0.20753 + 0.00638 + 0.00000], recall=[0.04066, 0.07892], hitrate=[0.24016, 0.39735], precision=[0.01681, 0.01345], ndcg=[0.03134, 0.04549]
Epoch 561 [46.7s]: train==[0.01203=0.00560 + 0.00643]
Epoch 562 [45.0s]: train==[0.01204=0.00562 + 0.00643]
Epoch 563 [45.4s]: train==[0.01208=0.00565 + 0.00643]
Epoch 564 [46.1s]: train==[0.01202=0.00559 + 0.00643]
Epoch 565 [46.1s]: train==[0.01203=0.00560 + 0.00643]
Epoch 566 [45.1s]: train==[0.01201=0.00557 + 0.00643]
Epoch 567 [45.6s]: train==[0.01198=0.00555 + 0.00643]
Epoch 568 [45.1s]: train==[0.01198=0.00555 + 0.00643]
Epoch 569 [46.0s]: train==[0.01203=0.00560 + 0.00643]
Epoch 570 [47.5s]: train==[0.01202=0.00558 + 0.00644]
Epoch 571 [48.0s]: train==[0.01199=0.00556 + 0.00643]
Epoch 572 [48.6s]: train==[0.01191=0.00547 + 0.00644]
Epoch 573 [47.8s]: train==[0.01201=0.00558 + 0.00644]
Epoch 574 [48.8s]: train==[0.01201=0.00558 + 0.00644]
Epoch 575 [49.0s]: train==[0.01198=0.00554 + 0.00644]
Epoch 576 [47.6s]: train==[0.01200=0.00556 + 0.00644]
Epoch 577 [48.1s]: train==[0.01191=0.00547 + 0.00644]
Epoch 578 [46.8s]: train==[0.01196=0.00552 + 0.00644]
Epoch 579 [47.6s]: train==[0.01188=0.00544 + 0.00644]
Epoch 580: train==[0.01191=0.00547 + 0.00644 + 0.00000], recall=[0.26915, 0.50313], hitrate=[0.99630, 0.99998], precision=[0.36437, 0.28350], ndcg=[0.39715, 0.47474]
Epoch 580 [4141.5s + 2615.0s]: test==[0.21443=0.20804 + 0.00639 + 0.00000], recall=[0.04074, 0.07907], hitrate=[0.24075, 0.39763], precision=[0.01686, 0.01347], ndcg=[0.03145, 0.04561]
Epoch 581 [47.6s]: train==[0.01199=0.00555 + 0.00644]
Epoch 582 [48.3s]: train==[0.01203=0.00559 + 0.00644]
Epoch 583 [47.2s]: train==[0.01194=0.00549 + 0.00645]
Epoch 584 [49.0s]: train==[0.01199=0.00555 + 0.00644]
Epoch 585 [48.9s]: train==[0.01180=0.00535 + 0.00645]
Epoch 586 [47.6s]: train==[0.01203=0.00559 + 0.00645]
Epoch 587 [48.1s]: train==[0.01195=0.00550 + 0.00645]
Epoch 588 [48.5s]: train==[0.01192=0.00548 + 0.00645]
Epoch 589 [48.6s]: train==[0.01196=0.00551 + 0.00645]
Epoch 590 [48.0s]: train==[0.01191=0.00546 + 0.00645]
Epoch 591 [48.4s]: train==[0.01191=0.00546 + 0.00645]
Epoch 592 [46.9s]: train==[0.01193=0.00548 + 0.00645]
Epoch 593 [46.6s]: train==[0.01196=0.00551 + 0.00645]
Epoch 594 [46.2s]: train==[0.01195=0.00549 + 0.00645]
Epoch 595 [47.6s]: train==[0.01191=0.00545 + 0.00645]
Epoch 596 [48.9s]: train==[0.01192=0.00546 + 0.00645]
Epoch 597 [47.9s]: train==[0.01185=0.00540 + 0.00645]
Epoch 598 [48.6s]: train==[0.01193=0.00548 + 0.00645]
Epoch 599 [47.6s]: train==[0.01192=0.00547 + 0.00646]
Epoch 600: train==[0.01187=0.00541 + 0.00646 + 0.00000], recall=[0.27259, 0.50881], hitrate=[0.99662, 0.99998], precision=[0.36835, 0.28657], ndcg=[0.40129, 0.47989]
Epoch 600 [4128.4s + 2614.5s]: test==[0.21493=0.20853 + 0.00641 + 0.00000], recall=[0.04102, 0.07931], hitrate=[0.24155, 0.39832], precision=[0.01693, 0.01350], ndcg=[0.03169, 0.04583]
Epoch 601 [49.1s]: train==[0.01195=0.00549 + 0.00646]
Epoch 602 [48.8s]: train==[0.01188=0.00542 + 0.00646]
Epoch 603 [48.1s]: train==[0.01182=0.00536 + 0.00646]
Epoch 604 [48.0s]: train==[0.01192=0.00546 + 0.00646]
Epoch 605 [47.3s]: train==[0.01191=0.00545 + 0.00646]
Epoch 606 [46.7s]: train==[0.01189=0.00543 + 0.00646]
Epoch 607 [47.0s]: train==[0.01192=0.00546 + 0.00646]
Epoch 608 [48.7s]: train==[0.01194=0.00548 + 0.00646]
Epoch 609 [47.7s]: train==[0.01191=0.00545 + 0.00646]
Epoch 610 [47.7s]: train==[0.01178=0.00532 + 0.00647]
Epoch 611 [47.1s]: train==[0.01187=0.00540 + 0.00647]
Epoch 612 [47.4s]: train==[0.01193=0.00547 + 0.00646]
Epoch 613 [46.9s]: train==[0.01186=0.00540 + 0.00647]
Epoch 614 [48.1s]: train==[0.01182=0.00535 + 0.00647]
Epoch 615 [48.3s]: train==[0.01181=0.00534 + 0.00647]
Epoch 616 [47.7s]: train==[0.01190=0.00543 + 0.00647]
Epoch 617 [46.7s]: train==[0.01186=0.00539 + 0.00647]
Epoch 618 [48.2s]: train==[0.01186=0.00538 + 0.00647]
Epoch 619 [48.9s]: train==[0.01179=0.00532 + 0.00647]
Epoch 620: train==[0.01192=0.00545 + 0.00647 + 0.00000], recall=[0.27600, 0.51409], hitrate=[0.99675, 0.99996], precision=[0.37253, 0.28953], ndcg=[0.40558, 0.48482]
Epoch 620 [4133.9s + 2603.3s]: test==[0.21505=0.20863 + 0.00642 + 0.00000], recall=[0.04103, 0.07949], hitrate=[0.24174, 0.39955], precision=[0.01692, 0.01353], ndcg=[0.03175, 0.04599]
Epoch 621 [48.4s]: train==[0.01185=0.00538 + 0.00647]
Epoch 622 [48.1s]: train==[0.01179=0.00532 + 0.00647]
Epoch 623 [47.8s]: train==[0.01178=0.00530 + 0.00647]
Epoch 624 [47.8s]: train==[0.01180=0.00532 + 0.00647]
Epoch 625 [48.1s]: train==[0.01179=0.00532 + 0.00647]
Epoch 626 [48.2s]: train==[0.01183=0.00535 + 0.00648]
Epoch 627 [48.5s]: train==[0.01173=0.00526 + 0.00648]
Epoch 628 [48.8s]: train==[0.01178=0.00530 + 0.00648]
Epoch 629 [48.2s]: train==[0.01182=0.00534 + 0.00648]
Epoch 630 [47.6s]: train==[0.01176=0.00528 + 0.00648]
Epoch 631 [47.6s]: train==[0.01182=0.00534 + 0.00648]
Epoch 632 [47.6s]: train==[0.01174=0.00526 + 0.00648]
Epoch 633 [48.9s]: train==[0.01172=0.00524 + 0.00648]
Epoch 634 [47.2s]: train==[0.01175=0.00527 + 0.00648]
Epoch 635 [47.4s]: train==[0.01179=0.00530 + 0.00648]
Epoch 636 [45.9s]: train==[0.01181=0.00533 + 0.00648]
Epoch 637 [46.5s]: train==[0.01182=0.00534 + 0.00648]
Epoch 638 [47.0s]: train==[0.01176=0.00528 + 0.00648]
Epoch 639 [46.8s]: train==[0.01181=0.00533 + 0.00648]
Epoch 640: train==[0.01174=0.00526 + 0.00648 + 0.00000], recall=[0.27796, 0.51804], hitrate=[0.99666, 0.99996], precision=[0.37492, 0.29166], ndcg=[0.40780, 0.48805]
Epoch 640 [4121.0s + 2617.9s]: test==[0.21460=0.20817 + 0.00643 + 0.00000], recall=[0.04096, 0.07966], hitrate=[0.24229, 0.39993], precision=[0.01689, 0.01353], ndcg=[0.03168, 0.04599]
Epoch 641 [48.0s]: train==[0.01169=0.00521 + 0.00649]
Epoch 642 [47.5s]: train==[0.01178=0.00529 + 0.00649]
Epoch 643 [49.3s]: train==[0.01166=0.00518 + 0.00649]
Epoch 644 [45.6s]: train==[0.01174=0.00526 + 0.00649]
Epoch 645 [46.4s]: train==[0.01180=0.00531 + 0.00649]
Epoch 646 [45.8s]: train==[0.01171=0.00522 + 0.00649]
Epoch 647 [46.8s]: train==[0.01171=0.00522 + 0.00649]
Epoch 648 [47.4s]: train==[0.01173=0.00524 + 0.00649]
Epoch 649 [45.7s]: train==[0.01178=0.00529 + 0.00649]
Epoch 650 [45.2s]: train==[0.01172=0.00523 + 0.00649]
Epoch 651 [45.6s]: train==[0.01166=0.00517 + 0.00649]
Epoch 652 [48.3s]: train==[0.01171=0.00521 + 0.00649]
Epoch 653 [48.2s]: train==[0.01169=0.00519 + 0.00649]
Epoch 654 [48.4s]: train==[0.01176=0.00526 + 0.00649]
Epoch 655 [47.8s]: train==[0.01170=0.00520 + 0.00649]
Epoch 656 [47.0s]: train==[0.01174=0.00524 + 0.00649]
Epoch 657 [46.7s]: train==[0.01163=0.00513 + 0.00650]
Epoch 658 [47.0s]: train==[0.01182=0.00532 + 0.00650]
Epoch 659 [48.1s]: train==[0.01168=0.00518 + 0.00649]
Epoch 660: train==[0.01172=0.00522 + 0.00650 + 0.00000], recall=[0.28053, 0.52144], hitrate=[0.99662, 0.99998], precision=[0.37818, 0.29355], ndcg=[0.41117, 0.49146]
Epoch 660 [4121.2s + 2622.4s]: test==[0.21544=0.20900 + 0.00644 + 0.00000], recall=[0.04079, 0.07955], hitrate=[0.24026, 0.39906], precision=[0.01683, 0.01351], ndcg=[0.03146, 0.04578]
Epoch 661 [47.8s]: train==[0.01167=0.00518 + 0.00650]
Epoch 662 [48.0s]: train==[0.01172=0.00522 + 0.00650]
Epoch 663 [48.2s]: train==[0.01174=0.00524 + 0.00650]
Epoch 664 [47.3s]: train==[0.01164=0.00515 + 0.00650]
Epoch 665 [47.8s]: train==[0.01173=0.00523 + 0.00650]
Epoch 666 [47.6s]: train==[0.01172=0.00522 + 0.00650]
Epoch 667 [45.4s]: train==[0.01171=0.00521 + 0.00650]
Epoch 668 [47.6s]: train==[0.01172=0.00522 + 0.00650]
Epoch 669 [45.8s]: train==[0.01165=0.00515 + 0.00650]
Epoch 670 [45.7s]: train==[0.01169=0.00518 + 0.00650]
Epoch 671 [45.9s]: train==[0.01162=0.00512 + 0.00650]
Epoch 672 [47.3s]: train==[0.01173=0.00523 + 0.00650]
Epoch 673 [45.9s]: train==[0.01171=0.00520 + 0.00650]
Epoch 674 [47.6s]: train==[0.01169=0.00519 + 0.00651]
Epoch 675 [48.5s]: train==[0.01168=0.00517 + 0.00651]
Epoch 676 [49.2s]: train==[0.01165=0.00514 + 0.00650]
Epoch 677 [47.8s]: train==[0.01166=0.00516 + 0.00650]
Epoch 678 [47.8s]: train==[0.01170=0.00520 + 0.00651]
Epoch 679 [47.9s]: train==[0.01174=0.00524 + 0.00651]
Epoch 680: train==[0.01172=0.00521 + 0.00651 + 0.00000], recall=[0.28279, 0.52491], hitrate=[0.99719, 0.99998], precision=[0.38084, 0.29552], ndcg=[0.41389, 0.49472]
Epoch 680 [4129.0s + 2628.2s]: test==[0.21619=0.20975 + 0.00645 + 0.00000], recall=[0.04087, 0.07963], hitrate=[0.24026, 0.39997], precision=[0.01684, 0.01351], ndcg=[0.03153, 0.04586]
Epoch 681 [48.3s]: train==[0.01164=0.00513 + 0.00651]
Epoch 682 [48.0s]: train==[0.01163=0.00512 + 0.00651]
Epoch 683 [47.7s]: train==[0.01169=0.00518 + 0.00651]
Epoch 684 [47.9s]: train==[0.01166=0.00515 + 0.00651]
Epoch 685 [47.3s]: train==[0.01159=0.00508 + 0.00651]
Epoch 686 [46.9s]: train==[0.01161=0.00509 + 0.00651]
Epoch 687 [47.6s]: train==[0.01167=0.00516 + 0.00651]
Epoch 688 [48.1s]: train==[0.01164=0.00513 + 0.00651]
Epoch 689 [48.3s]: train==[0.01165=0.00513 + 0.00651]
Epoch 690 [47.6s]: train==[0.01172=0.00520 + 0.00651]
Epoch 691 [47.2s]: train==[0.01161=0.00510 + 0.00651]
Epoch 692 [47.4s]: train==[0.01170=0.00519 + 0.00651]
Epoch 693 [48.4s]: train==[0.01158=0.00507 + 0.00651]
Epoch 694 [47.6s]: train==[0.01162=0.00511 + 0.00651]
Epoch 695 [48.3s]: train==[0.01166=0.00515 + 0.00651]
Epoch 696 [48.0s]: train==[0.01164=0.00513 + 0.00651]
Epoch 697 [48.5s]: train==[0.01166=0.00515 + 0.00652]
Epoch 698 [48.2s]: train==[0.01156=0.00504 + 0.00652]
Epoch 699 [48.2s]: train==[0.01171=0.00519 + 0.00652]
Epoch 700: train==[0.01161=0.00510 + 0.00652 + 0.00000], recall=[0.28431, 0.52766], hitrate=[0.99721, 0.99998], precision=[0.38274, 0.29693], ndcg=[0.41578, 0.49707]
Epoch 700 [4124.8s + 2618.4s]: test==[0.21654=0.21009 + 0.00646 + 0.00000], recall=[0.04100, 0.07972], hitrate=[0.24235, 0.40027], precision=[0.01691, 0.01354], ndcg=[0.03168, 0.04599]
Epoch 701 [48.2s]: train==[0.01159=0.00507 + 0.00652]
Epoch 702 [47.8s]: train==[0.01161=0.00509 + 0.00652]
Epoch 703 [48.2s]: train==[0.01168=0.00516 + 0.00652]
Epoch 704 [48.0s]: train==[0.01168=0.00516 + 0.00652]
Epoch 705 [48.0s]: train==[0.01156=0.00504 + 0.00652]
Epoch 706 [48.2s]: train==[0.01159=0.00507 + 0.00652]
Epoch 707 [48.8s]: train==[0.01161=0.00509 + 0.00652]
Epoch 708 [48.3s]: train==[0.01164=0.00511 + 0.00652]
Epoch 709 [49.5s]: train==[0.01171=0.00519 + 0.00652]
Epoch 710 [48.1s]: train==[0.01161=0.00509 + 0.00652]
Epoch 711 [47.4s]: train==[0.01155=0.00503 + 0.00652]
Epoch 712 [47.2s]: train==[0.01162=0.00510 + 0.00652]
Epoch 713 [47.6s]: train==[0.01166=0.00514 + 0.00652]
Epoch 714 [56.4s]: train==[0.01158=0.00506 + 0.00652]
Epoch 715 [64.5s]: train==[0.01157=0.00504 + 0.00652]
Epoch 716 [68.1s]: train==[0.01158=0.00506 + 0.00652]
Epoch 717 [53.4s]: train==[0.01163=0.00511 + 0.00653]
Epoch 718 [48.4s]: train==[0.01150=0.00497 + 0.00653]
Epoch 719 [47.8s]: train==[0.01154=0.00501 + 0.00653]
Epoch 720: train==[0.01160=0.00507 + 0.00653 + 0.00000], recall=[0.28555, 0.53047], hitrate=[0.99725, 0.99998], precision=[0.38416, 0.29845], ndcg=[0.41728, 0.49943]
Epoch 720 [4129.6s + 2620.5s]: test==[0.21533=0.20887 + 0.00646 + 0.00000], recall=[0.04110, 0.07990], hitrate=[0.24233, 0.40193], precision=[0.01696, 0.01360], ndcg=[0.03179, 0.04614]
Epoch 721 [47.1s]: train==[0.01150=0.00498 + 0.00653]
Epoch 722 [47.3s]: train==[0.01166=0.00513 + 0.00653]
Epoch 723 [47.1s]: train==[0.01154=0.00501 + 0.00653]
Epoch 724 [48.3s]: train==[0.01158=0.00506 + 0.00653]
Epoch 725 [48.9s]: train==[0.01160=0.00507 + 0.00653]
Epoch 726 [47.0s]: train==[0.01151=0.00499 + 0.00653]
Epoch 727 [47.9s]: train==[0.01147=0.00494 + 0.00653]
Epoch 728 [47.6s]: train==[0.01160=0.00507 + 0.00653]
Epoch 729 [47.1s]: train==[0.01154=0.00501 + 0.00653]
Epoch 730 [48.3s]: train==[0.01168=0.00515 + 0.00653]
Epoch 731 [48.3s]: train==[0.01151=0.00498 + 0.00653]
Epoch 732 [47.7s]: train==[0.01156=0.00503 + 0.00653]
Epoch 733 [47.6s]: train==[0.01151=0.00497 + 0.00653]
Epoch 734 [47.3s]: train==[0.01148=0.00495 + 0.00653]
Epoch 735 [47.7s]: train==[0.01154=0.00501 + 0.00653]
Epoch 736 [48.3s]: train==[0.01158=0.00505 + 0.00653]
Epoch 737 [47.4s]: train==[0.01156=0.00503 + 0.00653]
Epoch 738 [47.8s]: train==[0.01141=0.00487 + 0.00653]
Epoch 739 [46.5s]: train==[0.01156=0.00503 + 0.00654]
Epoch 740: train==[0.01156=0.00503 + 0.00653 + 0.00000], recall=[0.28754, 0.53355], hitrate=[0.99742, 1.00000], precision=[0.38670, 0.30017], ndcg=[0.41940, 0.50190]
Epoch 740 [4120.8s + 2617.2s]: test==[0.21699=0.21052 + 0.00647 + 0.00000], recall=[0.04099, 0.07973], hitrate=[0.24151, 0.39970], precision=[0.01694, 0.01353], ndcg=[0.03179, 0.04606]
Epoch 741 [47.9s]: train==[0.01151=0.00498 + 0.00653]
Epoch 742 [48.5s]: train==[0.01150=0.00497 + 0.00654]
Epoch 743 [47.8s]: train==[0.01150=0.00497 + 0.00654]
Epoch 744 [47.5s]: train==[0.01158=0.00504 + 0.00654]
Epoch 745 [47.5s]: train==[0.01151=0.00498 + 0.00654]
Epoch 746 [47.3s]: train==[0.01159=0.00505 + 0.00654]
Epoch 747 [47.9s]: train==[0.01141=0.00488 + 0.00654]
Epoch 748 [47.2s]: train==[0.01158=0.00505 + 0.00654]
Epoch 749 [48.7s]: train==[0.01156=0.00503 + 0.00654]
Epoch 750 [47.7s]: train==[0.01152=0.00498 + 0.00654]
Epoch 751 [47.4s]: train==[0.01154=0.00500 + 0.00654]
Epoch 752 [48.1s]: train==[0.01148=0.00494 + 0.00654]
Epoch 753 [47.3s]: train==[0.01152=0.00498 + 0.00654]
Epoch 754 [47.9s]: train==[0.01163=0.00509 + 0.00654]
Epoch 755 [48.7s]: train==[0.01154=0.00501 + 0.00654]
Epoch 756 [48.4s]: train==[0.01153=0.00499 + 0.00654]
Epoch 757 [53.9s]: train==[0.01151=0.00497 + 0.00654]
Epoch 758 [66.8s]: train==[0.01152=0.00498 + 0.00654]
Epoch 759 [53.9s]: train==[0.01148=0.00494 + 0.00654]
Epoch 760: train==[0.01146=0.00492 + 0.00654 + 0.00000], recall=[0.28890, 0.53581], hitrate=[0.99734, 0.99998], precision=[0.38841, 0.30148], ndcg=[0.42150, 0.50434]
Epoch 760 [4121.4s + 2613.3s]: test==[0.21680=0.21033 + 0.00647 + 0.00000], recall=[0.04104, 0.07986], hitrate=[0.24176, 0.39967], precision=[0.01698, 0.01356], ndcg=[0.03181, 0.04611]
Epoch 761 [47.8s]: train==[0.01141=0.00487 + 0.00654]
Epoch 762 [48.3s]: train==[0.01157=0.00502 + 0.00654]
Epoch 763 [48.3s]: train==[0.01139=0.00484 + 0.00654]
Epoch 764 [48.6s]: train==[0.01152=0.00497 + 0.00654]
Epoch 765 [47.3s]: train==[0.01150=0.00496 + 0.00654]
Epoch 766 [48.1s]: train==[0.01151=0.00496 + 0.00654]
Epoch 767 [47.9s]: train==[0.01156=0.00502 + 0.00654]
Epoch 768 [47.2s]: train==[0.01146=0.00492 + 0.00654]
Epoch 769 [47.6s]: train==[0.01141=0.00487 + 0.00654]
Epoch 770 [48.0s]: train==[0.01156=0.00502 + 0.00654]
Epoch 771 [47.9s]: train==[0.01146=0.00492 + 0.00654]
Epoch 772 [48.2s]: train==[0.01149=0.00495 + 0.00654]
Epoch 773 [47.7s]: train==[0.01157=0.00502 + 0.00655]
Epoch 774 [48.2s]: train==[0.01155=0.00501 + 0.00654]
Epoch 775 [47.5s]: train==[0.01151=0.00497 + 0.00654]
Epoch 776 [47.2s]: train==[0.01148=0.00493 + 0.00654]
Epoch 777 [48.7s]: train==[0.01153=0.00498 + 0.00655]
Epoch 778 [48.0s]: train==[0.01147=0.00492 + 0.00655]
Epoch 779 [48.1s]: train==[0.01155=0.00501 + 0.00654]
Epoch 780: train==[0.01147=0.00492 + 0.00655 + 0.00000], recall=[0.29101, 0.53921], hitrate=[0.99738, 0.99998], precision=[0.39089, 0.30333], ndcg=[0.42397, 0.50736]
Epoch 780 [4123.8s + 2618.0s]: test==[0.21662=0.21014 + 0.00648 + 0.00000], recall=[0.04095, 0.07986], hitrate=[0.24149, 0.39991], precision=[0.01694, 0.01355], ndcg=[0.03172, 0.04606]
Epoch 781 [47.6s]: train==[0.01149=0.00494 + 0.00655]
Epoch 782 [48.0s]: train==[0.01145=0.00491 + 0.00655]
Epoch 783 [47.8s]: train==[0.01150=0.00495 + 0.00655]
Epoch 784 [47.4s]: train==[0.01143=0.00488 + 0.00655]
Epoch 785 [49.0s]: train==[0.01145=0.00490 + 0.00655]
Epoch 786 [47.9s]: train==[0.01142=0.00487 + 0.00655]
Epoch 787 [48.4s]: train==[0.01142=0.00487 + 0.00655]
Epoch 788 [48.1s]: train==[0.01154=0.00499 + 0.00655]
Epoch 789 [48.0s]: train==[0.01139=0.00484 + 0.00655]
Epoch 790 [47.8s]: train==[0.01140=0.00485 + 0.00655]
Epoch 791 [47.1s]: train==[0.01146=0.00491 + 0.00655]
Epoch 792 [47.3s]: train==[0.01148=0.00493 + 0.00655]
Epoch 793 [47.8s]: train==[0.01141=0.00486 + 0.00655]
Epoch 794 [47.3s]: train==[0.01146=0.00491 + 0.00655]
Epoch 795 [47.9s]: train==[0.01141=0.00486 + 0.00655]
Epoch 796 [47.7s]: train==[0.01144=0.00488 + 0.00655]
Epoch 797 [47.6s]: train==[0.01139=0.00483 + 0.00655]
Epoch 798 [47.6s]: train==[0.01156=0.00501 + 0.00655]
Epoch 799 [47.5s]: train==[0.01141=0.00486 + 0.00655]
Epoch 800: train==[0.01143=0.00488 + 0.00655 + 0.00000], recall=[0.29188, 0.54063], hitrate=[0.99736, 0.99998], precision=[0.39210, 0.30422], ndcg=[0.42508, 0.50865]
Epoch 800 [4119.0s + 2622.6s]: test==[0.21738=0.21089 + 0.00649 + 0.00000], recall=[0.04099, 0.07973], hitrate=[0.24144, 0.39934], precision=[0.01691, 0.01355], ndcg=[0.03172, 0.04603]
Epoch 801 [47.6s]: train==[0.01146=0.00491 + 0.00655]
Epoch 802 [48.3s]: train==[0.01143=0.00488 + 0.00655]
Epoch 803 [47.3s]: train==[0.01145=0.00490 + 0.00655]
Epoch 804 [47.3s]: train==[0.01138=0.00482 + 0.00656]
Epoch 805 [47.8s]: train==[0.01146=0.00491 + 0.00656]
Epoch 806 [47.3s]: train==[0.01139=0.00483 + 0.00655]
Epoch 807 [47.7s]: train==[0.01142=0.00486 + 0.00656]
Epoch 808 [47.9s]: train==[0.01152=0.00497 + 0.00656]
Epoch 809 [47.8s]: train==[0.01144=0.00488 + 0.00656]
Epoch 810 [48.0s]: train==[0.01141=0.00485 + 0.00656]
Epoch 811 [48.2s]: train==[0.01138=0.00483 + 0.00656]
Epoch 812 [48.0s]: train==[0.01138=0.00482 + 0.00656]
Epoch 813 [48.0s]: train==[0.01139=0.00484 + 0.00656]
Epoch 814 [48.7s]: train==[0.01139=0.00484 + 0.00656]
Epoch 815 [47.7s]: train==[0.01143=0.00487 + 0.00656]
Epoch 816 [48.6s]: train==[0.01151=0.00496 + 0.00656]
Epoch 817 [47.4s]: train==[0.01139=0.00483 + 0.00656]
Epoch 818 [47.3s]: train==[0.01143=0.00487 + 0.00656]
Epoch 819 [48.6s]: train==[0.01144=0.00488 + 0.00656]
Epoch 820: train==[0.01143=0.00487 + 0.00656 + 0.00000], recall=[0.29307, 0.54253], hitrate=[0.99738, 0.99998], precision=[0.39355, 0.30526], ndcg=[0.42650, 0.51032]
Epoch 820 [4110.2s + 2614.6s]: test==[0.21777=0.21128 + 0.00649 + 0.00000], recall=[0.04102, 0.07984], hitrate=[0.24172, 0.40014], precision=[0.01691, 0.01356], ndcg=[0.03179, 0.04614]
Early stopping is trigger at step: 5 log:0.04102444648742676
Best Iter=[35]@[320925.1]   recall=[0.04110 0.07990], hitrate=[0.24233 0.40193], precision=[0.01696 0.01360], ndcg=[0.03179 0.04614]
```

