
## LightGCN_TF_gowalla_x0

A notebook to benchmark LightGCN on gowalla_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
```python
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 `gowalla` 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/gowalla) into the data/Gowalla/gowalla_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.

   ```python
   python LightGCN.py --dataset Gowalla --regs [1e-4] --embed_size 64 --layer_size [64,64,64,64] --lr 0.001 --batch_size 2048 --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

```python
HR@20 = 0.59237, Recall@20 = 0.18202, NDCG@20 = 0.15474
HR@50 = 0.72945, Recall@50 = 0.28217, NDCG@50 = 0.18585
```

### Logs

```shell
eval_score_matrix_foldout with python
n_users=29858, n_items=40981
n_interactions=1027370
n_train=810128, n_test=217242, sparsity=0.00084
already load adj matrix (70839, 70839) 0.29894590377807617
use the pre adjcency matrix
using random initialization
without pretraining.
Epoch 1 [35.9s]: train==[0.46090=0.46074 + 0.00016]
Epoch 2 [24.6s]: train==[0.23611=0.23562 + 0.00050]
Epoch 3 [24.7s]: train==[0.18034=0.17966 + 0.00068]
Epoch 4 [24.8s]: train==[0.15101=0.15020 + 0.00081]
Epoch 5 [24.8s]: train==[0.13224=0.13132 + 0.00092]
Epoch 6 [24.9s]: train==[0.11884=0.11783 + 0.00102]
Epoch 7 [24.9s]: train==[0.10812=0.10701 + 0.00110]
Epoch 8 [24.8s]: train==[0.10061=0.09942 + 0.00119]
Epoch 9 [24.7s]: train==[0.09377=0.09251 + 0.00126]
Epoch 10 [24.9s]: train==[0.08993=0.08860 + 0.00133]
Epoch 11 [24.9s]: train==[0.08420=0.08280 + 0.00140]
Epoch 12 [24.7s]: train==[0.08080=0.07934 + 0.00147]
Epoch 13 [24.9s]: train==[0.07766=0.07614 + 0.00153]
Epoch 14 [24.8s]: train==[0.07544=0.07386 + 0.00158]
Epoch 15 [24.8s]: train==[0.07334=0.07171 + 0.00163]
Epoch 16 [24.7s]: train==[0.07025=0.06856 + 0.00169]
Epoch 17 [25.0s]: train==[0.06802=0.06628 + 0.00174]
Epoch 18 [24.9s]: train==[0.06703=0.06524 + 0.00179]
Epoch 19 [24.8s]: train==[0.06506=0.06323 + 0.00184]
Epoch 20: train==[0.06328=0.06139 + 0.00189 + 0.00000], recall=[0.11045, 0.19172], hitrate=[0.80280, 0.91185], precision=[0.11218, 0.08071], ndcg=[0.15618, 0.17806]
Epoch 20 [1434.2s + 764.0s]: test==[0.12572=0.12381 + 0.00191 + 0.00000], recall=[0.12334, 0.19212], hitrate=[0.47334, 0.60620], precision=[0.03868, 0.02434], ndcg=[0.10745, 0.12854]
Epoch 21 [24.7s]: train==[0.06163=0.05970 + 0.00193]
Epoch 22 [24.9s]: train==[0.06027=0.05829 + 0.00198]
Epoch 23 [24.9s]: train==[0.05906=0.05704 + 0.00202]
Epoch 24 [25.0s]: train==[0.05710=0.05503 + 0.00207]
Epoch 25 [25.0s]: train==[0.05598=0.05387 + 0.00211]
Epoch 26 [25.0s]: train==[0.05544=0.05329 + 0.00216]
Epoch 27 [24.6s]: train==[0.05422=0.05202 + 0.00220]
Epoch 28 [24.8s]: train==[0.05302=0.05078 + 0.00224]
Epoch 29 [24.8s]: train==[0.05248=0.05020 + 0.00228]
Epoch 30 [24.9s]: train==[0.05092=0.04860 + 0.00233]
Epoch 31 [24.7s]: train==[0.04968=0.04732 + 0.00237]
Epoch 32 [24.7s]: train==[0.04954=0.04713 + 0.00241]
Epoch 33 [24.7s]: train==[0.04828=0.04583 + 0.00245]
Epoch 34 [24.9s]: train==[0.04707=0.04458 + 0.00249]
Epoch 35 [24.6s]: train==[0.04686=0.04433 + 0.00253]
Epoch 36 [24.8s]: train==[0.04664=0.04407 + 0.00257]
Epoch 37 [24.9s]: train==[0.04457=0.04196 + 0.00261]
Epoch 38 [24.9s]: train==[0.04467=0.04202 + 0.00265]
Epoch 39 [24.8s]: train==[0.04432=0.04163 + 0.00269]
Epoch 40: train==[0.04330=0.04057 + 0.00273 + 0.00000], recall=[0.13070, 0.23026], hitrate=[0.85026, 0.94494], precision=[0.13048, 0.09497], ndcg=[0.18048, 0.20897]
Epoch 40 [1410.7s + 767.2s]: test==[0.11641=0.11365 + 0.00275 + 0.00000], recall=[0.13839, 0.21651], hitrate=[0.51038, 0.64602], precision=[0.04313, 0.02721], ndcg=[0.11961, 0.14363]
Epoch 41 [24.8s]: train==[0.04316=0.04040 + 0.00276]
Epoch 42 [24.8s]: train==[0.04224=0.03944 + 0.00280]
Epoch 43 [24.6s]: train==[0.04244=0.03960 + 0.00283]
Epoch 44 [24.5s]: train==[0.04130=0.03843 + 0.00287]
Epoch 45 [24.8s]: train==[0.04063=0.03772 + 0.00291]
Epoch 46 [24.6s]: train==[0.04055=0.03761 + 0.00294]
Epoch 47 [24.7s]: train==[0.03936=0.03638 + 0.00298]
Epoch 48 [24.8s]: train==[0.04046=0.03745 + 0.00301]
Epoch 49 [24.7s]: train==[0.03909=0.03605 + 0.00304]
Epoch 50 [24.8s]: train==[0.03866=0.03559 + 0.00307]
Epoch 51 [24.8s]: train==[0.03798=0.03488 + 0.00311]
Epoch 52 [24.8s]: train==[0.03782=0.03468 + 0.00314]
Epoch 53 [24.8s]: train==[0.03750=0.03432 + 0.00318]
Epoch 54 [24.7s]: train==[0.03750=0.03429 + 0.00321]
Epoch 55 [24.8s]: train==[0.03651=0.03328 + 0.00324]
Epoch 56 [24.7s]: train==[0.03619=0.03292 + 0.00327]
Epoch 57 [25.0s]: train==[0.03568=0.03238 + 0.00330]
Epoch 58 [24.8s]: train==[0.03624=0.03291 + 0.00333]
Epoch 59 [24.9s]: train==[0.03558=0.03222 + 0.00336]
Epoch 49 [24.7s]: train==[0.03909=0.03605 + 0.00304]
Epoch 50 [24.8s]: train==[0.03866=0.03559 + 0.00307]
Epoch 51 [24.8s]: train==[0.03798=0.03488 + 0.00311]
Epoch 52 [24.8s]: train==[0.03782=0.03468 + 0.00314]
Epoch 53 [24.8s]: train==[0.03750=0.03432 + 0.00318]
Epoch 54 [24.7s]: train==[0.03750=0.03429 + 0.00321]
Epoch 55 [24.8s]: train==[0.03651=0.03328 + 0.00324]
Epoch 56 [24.7s]: train==[0.03619=0.03292 + 0.00327]
Epoch 57 [25.0s]: train==[0.03568=0.03238 + 0.00330]
Epoch 58 [24.8s]: train==[0.03624=0.03291 + 0.00333]
Epoch 59 [24.9s]: train==[0.03558=0.03222 + 0.00336]
poch 60: train==[0.03491=0.03152 + 0.00339 + 0.00000], recall=[0.14466, 0.25854], hitrate=[0.87280, 0.96105], precision=[0.14239, 0.10478], ndcg=[0.19599, 0.23014]
Epoch 60 [1411.8s + 760.4s]: test==[0.11393=0.11050 + 0.00343 + 0.00000], recall=[0.14687, 0.22901], hitrate=[0.52790, 0.66327], precision=[0.04550, 0.02863], ndcg=[0.12661, 0.15192]
Epoch 61 [24.5s]: train==[0.03588=0.03246 + 0.00342]
Epoch 62 [24.8s]: train==[0.03409=0.03064 + 0.00345]
Epoch 63 [24.8s]: train==[0.03420=0.03073 + 0.00348]
Epoch 64 [24.8s]: train==[0.03418=0.03068 + 0.00351]
Epoch 65 [24.6s]: train==[0.03385=0.03032 + 0.00354]
Epoch 66 [25.1s]: train==[0.03372=0.03015 + 0.00356]
Epoch 67 [24.7s]: train==[0.03283=0.02924 + 0.00359]
Epoch 68 [24.8s]: train==[0.03365=0.03003 + 0.00362]
Epoch 69 [24.6s]: train==[0.03252=0.02887 + 0.00365]
Epoch 70 [25.0s]: train==[0.03265=0.02897 + 0.00368]
Epoch 71 [24.7s]: train==[0.03208=0.02837 + 0.00371]
Epoch 72 [24.7s]: train==[0.03208=0.02835 + 0.00373]
Epoch 73 [24.9s]: train==[0.03207=0.02831 + 0.00376]
Epoch 74 [24.6s]: train==[0.03142=0.02764 + 0.00379]
Epoch 75 [24.7s]: train==[0.03106=0.02725 + 0.00381]
Epoch 76 [24.6s]: train==[0.03132=0.02748 + 0.00384]
Epoch 77 [24.7s]: train==[0.03055=0.02669 + 0.00387]
Epoch 78 [24.9s]: train==[0.03070=0.02681 + 0.00389]
Epoch 79 [24.7s]: train==[0.03077=0.02685 + 0.00392]
Epoch 80: train==[0.03039=0.02644 + 0.00395 + 0.00000], recall=[0.15691, 0.28414], hitrate=[0.89142, 0.97120], precision=[0.15270, 0.11333], ndcg=[0.20885, 0.24833]
Epoch 80 [1398.9s + 765.8s]: test==[0.11422=0.11024 + 0.00398 + 0.00000], recall=[0.15286, 0.23804], hitrate=[0.53965, 0.67433], precision=[0.04715, 0.02965], ndcg=[0.13137, 0.15763]
Epoch 81 [24.9s]: train==[0.03017=0.02620 + 0.00397]
Epoch 82 [24.6s]: train==[0.03002=0.02603 + 0.00399]
Epoch 83 [24.8s]: train==[0.02973=0.02571 + 0.00402]
Epoch 84 [24.8s]: train==[0.02959=0.02554 + 0.00405]
Epoch 85 [24.8s]: train==[0.02953=0.02546 + 0.00407]
Epoch 86 [24.6s]: train==[0.02890=0.02481 + 0.00409]
Epoch 87 [24.6s]: train==[0.02901=0.02489 + 0.00412]
Epoch 88 [24.9s]: train==[0.02876=0.02462 + 0.00415]
Epoch 89 [24.8s]: train==[0.02869=0.02452 + 0.00417]
Epoch 90 [24.8s]: train==[0.02823=0.02404 + 0.00419]
Epoch 91 [24.8s]: train==[0.02865=0.02443 + 0.00422]
Epoch 92 [24.6s]: train==[0.02798=0.02374 + 0.00424]
Epoch 93 [24.7s]: train==[0.02773=0.02347 + 0.00427]
Epoch 94 [24.8s]: train==[0.02803=0.02374 + 0.00429]
Epoch 95 [24.6s]: train==[0.02752=0.02320 + 0.00431]
Epoch 96 [24.8s]: train==[0.02770=0.02336 + 0.00434]
Epoch 97 [24.6s]: train==[0.02706=0.02270 + 0.00436]
Epoch 98 [24.7s]: train==[0.02715=0.02276 + 0.00438]
Epoch 99 [24.5s]: train==[0.02711=0.02271 + 0.00440]
Epoch 100: train==[0.02680=0.02237 + 0.00443 + 0.00000], recall=[0.16868, 0.31053], hitrate=[0.90689, 0.97974], precision=[0.16176, 0.12151], ndcg=[0.22021, 0.26585]
Epoch 100 [1399.0s + 803.1s]: test==[0.11466=0.11020 + 0.00446 + 0.00000], recall=[0.15706, 0.24442], hitrate=[0.54655, 0.68337], precision=[0.04837, 0.03039], ndcg=[0.13492, 0.16186]
Epoch 101 [48.9s]: train==[0.02662=0.02217 + 0.00445]
Epoch 102 [47.7s]: train==[0.02650=0.02202 + 0.00447]
Epoch 103 [49.1s]: train==[0.02630=0.02181 + 0.00449]
Epoch 104 [49.3s]: train==[0.02616=0.02164 + 0.00452]
Epoch 105 [42.1s]: train==[0.02626=0.02172 + 0.00454]
Epoch 106 [47.7s]: train==[0.02618=0.02162 + 0.00456]
Epoch 107 [50.1s]: train==[0.02614=0.02156 + 0.00458]
Epoch 108 [49.0s]: train==[0.02548=0.02088 + 0.00461]
Epoch 109 [50.4s]: train==[0.02584=0.02121 + 0.00462]
Epoch 110 [47.0s]: train==[0.02538=0.02073 + 0.00464]
Epoch 111 [45.7s]: train==[0.02566=0.02100 + 0.00467]
Epoch 112 [44.4s]: train==[0.02534=0.02065 + 0.00469]
Epoch 113 [45.1s]: train==[0.02528=0.02057 + 0.00471]
Epoch 114 [45.9s]: train==[0.02518=0.02045 + 0.00473]
Epoch 115 [47.9s]: train==[0.02499=0.02024 + 0.00475]
Epoch 116 [34.2s]: train==[0.02496=0.02019 + 0.00477]
Epoch 117 [25.0s]: train==[0.02459=0.01980 + 0.00479]
Epoch 118 [25.1s]: train==[0.02467=0.01986 + 0.00481]
Epoch 119 [24.9s]: train==[0.02468=0.01985 + 0.00483]
Epoch 120: train==[0.02448=0.01963 + 0.00485 + 0.00000], recall=[0.18252, 0.33878], hitrate=[0.92367, 0.98680], precision=[0.17200, 0.13003], ndcg=[0.23247, 0.28415]
Epoch 120 [2287.6s + 1053.0s]: test==[0.11536=0.11048 + 0.00488 + 0.00000], recall=[0.16141, 0.24955], hitrate=[0.55519, 0.69017], precision=[0.04949, 0.03104], ndcg=[0.13807, 0.16531]
Epoch 121 [46.6s]: train==[0.02432=0.01945 + 0.00487]
Epoch 122 [48.0s]: train==[0.02393=0.01904 + 0.00489]
Epoch 123 [47.5s]: train==[0.02366=0.01874 + 0.00491]
Epoch 124 [48.9s]: train==[0.02379=0.01886 + 0.00493]
Epoch 125 [48.1s]: train==[0.02407=0.01912 + 0.00495]
Epoch 126 [48.7s]: train==[0.02425=0.01928 + 0.00497]
Epoch 127 [42.8s]: train==[0.02359=0.01860 + 0.00499]
Epoch 128 [25.2s]: train==[0.02352=0.01851 + 0.00501]
Epoch 129 [25.2s]: train==[0.02376=0.01874 + 0.00503]
Epoch 130 [24.9s]: train==[0.02346=0.01842 + 0.00504]
Epoch 131 [25.0s]: train==[0.02339=0.01833 + 0.00506]
Epoch 132 [24.8s]: train==[0.02297=0.01789 + 0.00508]
Epoch 133 [25.1s]: train==[0.02309=0.01799 + 0.00510]
Epoch 134 [25.0s]: train==[0.02326=0.01814 + 0.00512]
Epoch 135 [25.2s]: train==[0.02328=0.01814 + 0.00513]
Epoch 136 [24.9s]: train==[0.02276=0.01761 + 0.00516]
Epoch 137 [24.7s]: train==[0.02271=0.01753 + 0.00518]
Epoch 138 [24.8s]: train==[0.02233=0.01714 + 0.00519]
Epoch 139 [24.7s]: train==[0.02245=0.01724 + 0.00521]
Epoch 140: train==[0.02227=0.01705 + 0.00523 + 0.00000], recall=[0.19571, 0.36638], hitrate=[0.93687, 0.99169], precision=[0.18127, 0.13811], ndcg=[0.24387, 0.30178]
Epoch 140 [1388.2s + 764.3s]: test==[0.11632=0.11106 + 0.00526 + 0.00000], recall=[0.16364, 0.25275], hitrate=[0.55814, 0.69352], precision=[0.05017, 0.03143], ndcg=[0.14005, 0.16763]
Epoch 141 [25.5s]: train==[0.02222=0.01697 + 0.00525]
Epoch 142 [25.5s]: train==[0.02230=0.01703 + 0.00527]
Epoch 143 [25.5s]: train==[0.02210=0.01682 + 0.00528]
Epoch 144 [25.4s]: train==[0.02232=0.01702 + 0.00530]
Epoch 145 [25.5s]: train==[0.02210=0.01678 + 0.00531]
Epoch 146 [25.5s]: train==[0.02192=0.01658 + 0.00533]
Epoch 147 [25.4s]: train==[0.02217=0.01682 + 0.00535]
Epoch 148 [25.4s]: train==[0.02201=0.01664 + 0.00537]
Epoch 149 [25.3s]: train==[0.02171=0.01633 + 0.00538]
Epoch 150 [25.2s]: train==[0.02164=0.01624 + 0.00540]
Epoch 151 [25.2s]: train==[0.02162=0.01620 + 0.00541]
Epoch 152 [25.1s]: train==[0.02152=0.01609 + 0.00543]
Epoch 153 [25.1s]: train==[0.02212=0.01667 + 0.00545]
Epoch 154 [25.1s]: train==[0.02123=0.01577 + 0.00546]
Epoch 155 [27.7s]: train==[0.02086=0.01536 + 0.00551]
Epoch 156 [28.8s]: train==[0.02125=0.01573 + 0.00552]
Epoch 157 [31.5s]: train==[0.02115=0.01561 + 0.00553]
Epoch 158 [25.9s]: train==[0.02100=0.01546 + 0.00555]
Epoch 159 [30.2s]: train==[0.02111=0.01555 + 0.00557]
Epoch 160: train==[0.02072=0.01514 + 0.00558 + 0.00000], recall=[0.21082, 0.39611], hitrate=[0.94795, 0.99521], precision=[0.19152, 0.14641], ndcg=[0.25674, 0.32087]
Epoch 160 [1335.1s + 761.3s]: test==[0.11695=0.11134 + 0.00561 + 0.00000], recall=[0.16599, 0.25747], hitrate=[0.56390, 0.69981], precision=[0.05089, 0.03199], ndcg=[0.14184, 0.17014]
Epoch 161 [26.7s]: train==[0.02095=0.01535 + 0.00559]
Epoch 162 [26.1s]: train==[0.02085=0.01524 + 0.00561]
Epoch 163 [26.6s]: train==[0.02061=0.01499 + 0.00562]
Epoch 164 [26.0s]: train==[0.02059=0.01495 + 0.00564]
Epoch 165 [25.9s]: train==[0.02072=0.01507 + 0.00565]
Epoch 166 [25.9s]: train==[0.02046=0.01479 + 0.00567]
Epoch 167 [25.1s]: train==[0.02049=0.01483 + 0.00566]
Epoch 168 [25.3s]: train==[0.02047=0.01479 + 0.00568]
Epoch 169 [25.2s]: train==[0.02031=0.01462 + 0.00569]
Epoch 170 [25.2s]: train==[0.02064=0.01494 + 0.00570]
Epoch 171 [25.5s]: train==[0.02026=0.01454 + 0.00572]
Epoch 172 [25.4s]: train==[0.02044=0.01471 + 0.00573]
Epoch 173 [25.2s]: train==[0.02034=0.01460 + 0.00575]
Epoch 174 [25.0s]: train==[0.02013=0.01437 + 0.00576]
Epoch 175 [25.0s]: train==[0.02014=0.01437 + 0.00577]
Epoch 176 [24.9s]: train==[0.01988=0.01409 + 0.00579]
Epoch 177 [24.6s]: train==[0.02014=0.01434 + 0.00580]
Epoch 178 [25.0s]: train==[0.01998=0.01417 + 0.00581]
Epoch 179 [25.1s]: train==[0.01996=0.01413 + 0.00583]
Epoch 180: train==[0.01986=0.01402 + 0.00584 + 0.00000], recall=[0.22460, 0.42087], hitrate=[0.95777, 0.99685], precision=[0.20096, 0.15392],
 ndcg=[0.26821, 0.33729]
Epoch 180 [1368.9s + 761.3s]: test==[0.11917=0.11330 + 0.00587 + 0.00000], recall=[0.16774, 0.25943], hitrate=[0.56625, 0.70199], precision=[
0.05147, 0.03223], ndcg=[0.14345, 0.17182]
Epoch 181 [25.0s]: train==[0.01975=0.01389 + 0.00586]
Epoch 182 [24.9s]: train==[0.01993=0.01406 + 0.00587]
Epoch 183 [24.9s]: train==[0.01939=0.01350 + 0.00589]
Epoch 184 [24.6s]: train==[0.01942=0.01352 + 0.00590]
Epoch 185 [24.8s]: train==[0.01937=0.01346 + 0.00591]
Epoch 186 [25.3s]: train==[0.01947=0.01355 + 0.00592]
Epoch 187 [25.2s]: train==[0.01968=0.01375 + 0.00594]
Epoch 188 [25.4s]: train==[0.01960=0.01365 + 0.00595]
Epoch 189 [25.4s]: train==[0.01933=0.01337 + 0.00596]
Epoch 190 [25.4s]: train==[0.01958=0.01360 + 0.00597]
Epoch 191 [25.3s]: train==[0.01943=0.01345 + 0.00598]
Epoch 192 [25.6s]: train==[0.01915=0.01316 + 0.00599]
Epoch 193 [25.1s]: train==[0.01905=0.01305 + 0.00600]
Epoch 194 [25.1s]: train==[0.01931=0.01329 + 0.00602]
Epoch 195 [25.4s]: train==[0.01900=0.01297 + 0.00603]
Epoch 196 [25.1s]: train==[0.01890=0.01285 + 0.00604]
Epoch 197 [25.3s]: train==[0.01915=0.01309 + 0.00605]
Epoch 198 [25.3s]: train==[0.01880=0.01274 + 0.00606]
Epoch 199 [24.8s]: train==[0.01912=0.01304 + 0.00608]
Epoch 200: train==[0.01911=0.01302 + 0.00609 + 0.00000], recall=[0.23806, 0.44444], hitrate=[0.96611, 0.99776], precision=[0.20993, 0.16053], ndcg=[0.27924, 0.35266]
Epoch 200 [1365.4s + 767.1s]: test==[0.12116=0.11506 + 0.00611 + 0.00000], recall=[0.16974, 0.26295], hitrate=[0.57020, 0.70537], precision=[0.05208, 0.03268], ndcg=[0.14488, 0.17372]
Epoch 201 [24.8s]: train==[0.01898=0.01288 + 0.00610]
Epoch 202 [24.9s]: train==[0.01883=0.01272 + 0.00611]
Epoch 203 [24.8s]: train==[0.01871=0.01259 + 0.00612]
Epoch 204 [24.7s]: train==[0.01857=0.01244 + 0.00613]
Epoch 205 [24.8s]: train==[0.01893=0.01278 + 0.00614]
Epoch 206 [24.9s]: train==[0.01854=0.01239 + 0.00615]
Epoch 207 [24.8s]: train==[0.01884=0.01268 + 0.00616]
Epoch 208 [25.1s]: train==[0.01849=0.01231 + 0.00618]
Epoch 209 [25.1s]: train==[0.01866=0.01247 + 0.00619]
Epoch 210 [25.3s]: train==[0.01867=0.01247 + 0.00620]
Epoch 211 [25.2s]: train==[0.01859=0.01238 + 0.00621]
Epoch 212 [25.3s]: train==[0.01846=0.01224 + 0.00622]
Epoch 213 [25.4s]: train==[0.01834=0.01211 + 0.00623]
Epoch 214 [25.3s]: train==[0.01857=0.01233 + 0.00624]
Epoch 215 [25.3s]: train==[0.01846=0.01222 + 0.00625]
Epoch 216 [25.2s]: train==[0.01826=0.01200 + 0.00626]
Epoch 217 [25.2s]: train==[0.01840=0.01213 + 0.00627]
Epoch 218 [25.1s]: train==[0.01828=0.01200 + 0.00628]
Epoch 219 [25.5s]: train==[0.01850=0.01221 + 0.00629]
Epoch 220: train==[0.01831=0.01201 + 0.00630 + 0.00000], recall=[0.25094, 0.46690], hitrate=[0.97254, 0.99866], precision=[0.21821, 0.16714], ndcg=[0.28995, 0.36781]
Epoch 220 [1372.3s + 758.6s]: test==[0.12151=0.11520 + 0.00631 + 0.00000], recall=[0.17081, 0.26437], hitrate=[0.57154, 0.70721], precision=[0.05246, 0.03284], ndcg=[0.14562, 0.17455]
Epoch 221 [24.9s]: train==[0.01814=0.01184 + 0.00630]
Epoch 222 [24.9s]: train==[0.01811=0.01179 + 0.00632]
Epoch 223 [25.0s]: train==[0.01814=0.01182 + 0.00633]
Epoch 224 [25.2s]: train==[0.01829=0.01196 + 0.00634]
Epoch 225 [25.1s]: train==[0.01832=0.01198 + 0.00634]
Epoch 226 [24.8s]: train==[0.01797=0.01162 + 0.00635]
Epoch 227 [25.1s]: train==[0.01826=0.01190 + 0.00636]
Epoch 228 [25.4s]: train==[0.01831=0.01194 + 0.00637]
Epoch 229 [25.3s]: train==[0.01808=0.01171 + 0.00638]
Epoch 230 [25.3s]: train==[0.01788=0.01149 + 0.00639]
Epoch 231 [25.5s]: train==[0.01775=0.01136 + 0.00640]
Epoch 232 [25.5s]: train==[0.01795=0.01153 + 0.00641]
Epoch 233 [25.4s]: train==[0.01770=0.01128 + 0.00642]
Epoch 234 [25.2s]: train==[0.01798=0.01155 + 0.00643]
Epoch 235 [25.2s]: train==[0.01789=0.01146 + 0.00643]
Epoch 236 [25.3s]: train==[0.01809=0.01165 + 0.00644]
Epoch 237 [25.3s]: train==[0.01780=0.01135 + 0.00645]
Epoch 238 [25.3s]: train==[0.01765=0.01118 + 0.00646]
Epoch 239 [25.3s]: train==[0.01750=0.01103 + 0.00647]
Epoch 240: train==[0.01762=0.01114 + 0.00648 + 0.00000], recall=[0.26146, 0.48594], hitrate=[0.97652, 0.99903], precision=[0.22507, 0.17261], ndcg=[0.29858, 0.38030]
Epoch 240 [1370.8s + 774.3s]: test==[0.12228=0.11579 + 0.00649 + 0.00000], recall=[0.17146, 0.26573], hitrate=[0.57341, 0.70989], precision=[0.05269, 0.03298], ndcg=[0.14636, 0.17550]
Epoch 241 [25.0s]: train==[0.01740=0.01092 + 0.00648]
Epoch 242 [24.9s]: train==[0.01760=0.01111 + 0.00649]
Epoch 243 [24.9s]: train==[0.01751=0.01101 + 0.00650]
Epoch 244 [24.7s]: train==[0.01735=0.01084 + 0.00651]
Epoch 245 [24.8s]: train==[0.01734=0.01082 + 0.00652]
Epoch 246 [25.0s]: train==[0.01753=0.01101 + 0.00653]
Epoch 247 [24.8s]: train==[0.01745=0.01092 + 0.00654]
Epoch 248 [24.9s]: train==[0.01761=0.01107 + 0.00654]
Epoch 249 [25.1s]: train==[0.01750=0.01095 + 0.00655]
Epoch 250 [25.3s]: train==[0.01752=0.01097 + 0.00656]
Epoch 251 [24.9s]: train==[0.01741=0.01085 + 0.00656]
Epoch 252 [24.9s]: train==[0.01720=0.01064 + 0.00657]
Epoch 253 [25.1s]: train==[0.01727=0.01069 + 0.00658]
Epoch 254 [25.4s]: train==[0.01719=0.01061 + 0.00659]
Epoch 255 [25.4s]: train==[0.01712=0.01053 + 0.00659]
Epoch 256 [25.2s]: train==[0.01716=0.01056 + 0.00660]
Epoch 257 [25.4s]: train==[0.01726=0.01065 + 0.00661]
Epoch 258 [25.2s]: train==[0.01728=0.01067 + 0.00661]
Epoch 259 [25.3s]: train==[0.01725=0.01063 + 0.00662]
Epoch 260: train==[0.01742=0.01079 + 0.00663 + 0.00000], recall=[0.27454, 0.50504], hitrate=[0.98158, 0.99940], precision=[0.23368, 0.17837], ndcg=[0.30896, 0.39348]
Epoch 260 [1365.2s + 766.1s]: test==[0.12353=0.11690 + 0.00663 + 0.00000], recall=[0.17288, 0.26716], hitrate=[0.57619, 0.71100], precision=[0.05311, 0.03326], ndcg=[0.14732, 0.17651]
Epoch 261 [25.3s]: train==[0.01694=0.01031 + 0.00663]
Epoch 262 [25.4s]: train==[0.01708=0.01044 + 0.00664]
Epoch 263 [25.2s]: train==[0.01715=0.01050 + 0.00665]
Epoch 264 [25.2s]: train==[0.01687=0.01022 + 0.00665]
Epoch 265 [25.4s]: train==[0.01719=0.01053 + 0.00666]
Epoch 266 [25.3s]: train==[0.01696=0.01029 + 0.00667]
Epoch 267 [25.4s]: train==[0.01676=0.01009 + 0.00667]
Epoch 268 [25.3s]: train==[0.01694=0.01026 + 0.00668]
Epoch 269 [25.4s]: train==[0.01701=0.01032 + 0.00669]
Epoch 270 [25.4s]: train==[0.01675=0.01006 + 0.00670]
Epoch 271 [25.3s]: train==[0.01666=0.00996 + 0.00670]
Epoch 272 [25.5s]: train==[0.01699=0.01028 + 0.00671]
Epoch 273 [25.2s]: train==[0.01687=0.01015 + 0.00672]
Epoch 274 [25.0s]: train==[0.01695=0.01023 + 0.00672]
Epoch 275 [24.9s]: train==[0.01686=0.01013 + 0.00673]
Epoch 276 [24.7s]: train==[0.01689=0.01016 + 0.00673]
Epoch 277 [25.1s]: train==[0.01704=0.01030 + 0.00674]
Epoch 278 [24.8s]: train==[0.01683=0.01008 + 0.00674]
Epoch 279 [25.2s]: train==[0.01654=0.00979 + 0.00675]
Epoch 280: train==[0.01667=0.00991 + 0.00676 + 0.00000], recall=[0.28481, 0.52091], hitrate=[0.98382, 0.99956], precision=[0.24016, 0.18311], ndcg=[0.31721, 0.40442]
Epoch 280 [1364.1s + 760.5s]: test==[0.12374=0.11698 + 0.00676 + 0.00000], recall=[0.17313, 0.26785], hitrate=[0.57583, 0.71200], precision=[0.05316, 0.03337], ndcg=[0.14773, 0.17713]
Epoch 281 [24.9s]: train==[0.01666=0.00990 + 0.00676]
Epoch 282 [24.8s]: train==[0.01681=0.01004 + 0.00677]
Epoch 283 [24.8s]: train==[0.01663=0.00986 + 0.00678]
Epoch 284 [25.0s]: train==[0.01668=0.00989 + 0.00678]
Epoch 285 [24.9s]: train==[0.01667=0.00988 + 0.00679]
Epoch 286 [25.2s]: train==[0.01644=0.00965 + 0.00680]
Epoch 287 [24.8s]: train==[0.01666=0.00986 + 0.00680]
Epoch 288 [25.1s]: train==[0.01665=0.00985 + 0.00681]
Epoch 289 [25.1s]: train==[0.01660=0.00980 + 0.00681]
Epoch 290 [25.1s]: train==[0.01669=0.00987 + 0.00682]
Epoch 291 [24.9s]: train==[0.01661=0.00979 + 0.00682]
Epoch 292 [25.2s]: train==[0.01646=0.00963 + 0.00683]
Epoch 293 [25.1s]: train==[0.01649=0.00966 + 0.00683]
Epoch 294 [25.4s]: train==[0.01662=0.00978 + 0.00684]
Epoch 295 [25.3s]: train==[0.01668=0.00983 + 0.00684]
Epoch 296 [25.5s]: train==[0.01637=0.00952 + 0.00685]
Epoch 297 [24.9s]: train==[0.01657=0.00972 + 0.00685]
Epoch 298 [25.1s]: train==[0.01664=0.00978 + 0.00686]
Epoch 299 [24.7s]: train==[0.01657=0.00971 + 0.00686]
Epoch 300: train==[0.01669=0.00982 + 0.00687 + 0.00000], recall=[0.29580, 0.53650], hitrate=[0.98637, 0.99973], precision=[0.24721, 0.18789], ndcg=[0.32631, 0.41577]
Epoch 300 [1366.5s + 764.2s]: test==[0.12537=0.11850 + 0.00686 + 0.00000], recall=[0.17380, 0.26896], hitrate=[0.57750, 0.71251], precision=[0.05340, 0.03344], ndcg=[0.14840, 0.17784]
Epoch 301 [25.0s]: train==[0.01646=0.00959 + 0.00687]
Epoch 302 [24.8s]: train==[0.01644=0.00957 + 0.00687]
Epoch 303 [24.9s]: train==[0.01650=0.00962 + 0.00688]
Epoch 304 [25.1s]: train==[0.01629=0.00940 + 0.00688]
Epoch 305 [25.2s]: train==[0.01637=0.00947 + 0.00689]
Epoch 306 [25.0s]: train==[0.01632=0.00943 + 0.00690]
Epoch 307 [24.8s]: train==[0.01654=0.00964 + 0.00690]
Epoch 308 [24.7s]: train==[0.01626=0.00935 + 0.00691]
Epoch 309 [24.7s]: train==[0.01641=0.00949 + 0.00691]
Epoch 310 [24.8s]: train==[0.01633=0.00941 + 0.00692]
Epoch 311 [24.8s]: train==[0.01608=0.00915 + 0.00693]
Epoch 312 [24.9s]: train==[0.01622=0.00929 + 0.00693]
Epoch 313 [24.9s]: train==[0.01626=0.00933 + 0.00694]
Epoch 314 [25.0s]: train==[0.01620=0.00926 + 0.00694]
Epoch 315 [24.8s]: train==[0.01618=0.00923 + 0.00694]
Epoch 316 [25.0s]: train==[0.01592=0.00897 + 0.00695]
Epoch 317 [25.2s]: train==[0.01609=0.00914 + 0.00695]
Epoch 318 [24.9s]: train==[0.01623=0.00927 + 0.00696]
Epoch 319 [24.9s]: train==[0.01607=0.00911 + 0.00696]
Epoch 320: train==[0.01617=0.00920 + 0.00697 + 0.00000], recall=[0.30320, 0.54821], hitrate=[0.98808, 0.99970], precision=[0.25208, 0.19158], ndcg=[0.33246, 0.42409]
Epoch 320 [1364.5s + 754.7s]: test==[0.12453=0.11757 + 0.00696 + 0.00000], recall=[0.17409, 0.26959], hitrate=[0.57897, 0.71418], precision=[0.05342, 0.03355], ndcg=[0.14855, 0.17819]
Epoch 321 [24.8s]: train==[0.01611=0.00914 + 0.00697]
Epoch 322 [25.1s]: train==[0.01601=0.00904 + 0.00697]
Epoch 323 [25.2s]: train==[0.01601=0.00903 + 0.00698]
Epoch 324 [25.4s]: train==[0.01603=0.00904 + 0.00698]
Epoch 325 [25.2s]: train==[0.01576=0.00877 + 0.00699]
Epoch 326 [25.3s]: train==[0.01622=0.00923 + 0.00700]
Epoch 327 [25.2s]: train==[0.01588=0.00888 + 0.00700]
Epoch 328 [25.0s]: train==[0.01595=0.00895 + 0.00701]
Epoch 329 [25.3s]: train==[0.01582=0.00881 + 0.00701]
Epoch 330 [25.2s]: train==[0.01600=0.00899 + 0.00701]
Epoch 331 [25.1s]: train==[0.01603=0.00901 + 0.00701]
Epoch 332 [25.5s]: train==[0.01609=0.00908 + 0.00702]
Epoch 333 [25.5s]: train==[0.01600=0.00898 + 0.00702]
Epoch 334 [25.2s]: train==[0.01601=0.00898 + 0.00703]
Epoch 335 [25.6s]: train==[0.01606=0.00903 + 0.00703]
Epoch 336 [25.4s]: train==[0.01571=0.00868 + 0.00703]
Epoch 337 [25.3s]: train==[0.01584=0.00880 + 0.00704]
Epoch 338 [25.1s]: train==[0.01581=0.00876 + 0.00705]
Epoch 339 [25.2s]: train==[0.01602=0.00897 + 0.00705]
Epoch 340: train==[0.01608=0.00903 + 0.00705 + 0.00000], recall=[0.31360, 0.56099], hitrate=[0.98958, 0.99977], precision=[0.25914, 0.19582], ndcg=[0.34161, 0.43436]
Epoch 340 [1355.2s + 758.4s]: test==[0.12498=0.11793 + 0.00705 + 0.00000], recall=[0.17523, 0.27112], hitrate=[0.58169, 0.71612], precision=[0.05381, 0.03376], ndcg=[0.14949, 0.17922]
Epoch 341 [25.4s]: train==[0.01580=0.00874 + 0.00706]
Epoch 342 [25.3s]: train==[0.01588=0.00881 + 0.00707]
Epoch 343 [25.2s]: train==[0.01579=0.00872 + 0.00707]
Epoch 344 [25.1s]: train==[0.01583=0.00875 + 0.00707]
Epoch 345 [25.6s]: train==[0.01594=0.00887 + 0.00707]
Epoch 346 [25.2s]: train==[0.01601=0.00893 + 0.00708]
Epoch 347 [25.1s]: train==[0.01566=0.00857 + 0.00708]
Epoch 348 [25.3s]: train==[0.01579=0.00870 + 0.00709]
Epoch 349 [25.5s]: train==[0.01602=0.00893 + 0.00709]
Epoch 350 [25.6s]: train==[0.01584=0.00875 + 0.00709]
Epoch 351 [25.3s]: train==[0.01566=0.00857 + 0.00709]
Epoch 352 [25.3s]: train==[0.01584=0.00874 + 0.00710]
Epoch 353 [25.4s]: train==[0.01584=0.00874 + 0.00710]
Epoch 354 [25.5s]: train==[0.01567=0.00856 + 0.00711]
Epoch 355 [25.5s]: train==[0.01561=0.00850 + 0.00711]
Epoch 356 [25.4s]: train==[0.01557=0.00845 + 0.00711]
Epoch 357 [25.4s]: train==[0.01569=0.00858 + 0.00712]
Epoch 358 [25.3s]: train==[0.01569=0.00857 + 0.00712]
Epoch 359 [25.4s]: train==[0.01564=0.00851 + 0.00713]
Epoch 360: train==[0.01584=0.00871 + 0.00713 + 0.00000], recall=[0.32211, 0.57229], hitrate=[0.99062, 0.99987], precision=[0.26469, 0.19959], ndcg=[0.34856, 0.44281]
Epoch 360 [1356.7s + 762.7s]: test==[0.12743=0.12031 + 0.00712 + 0.00000], recall=[0.17528, 0.27130], hitrate=[0.58209, 0.71562], precision=[0.05395, 0.03383], ndcg=[0.14951, 0.17928]
Epoch 361 [25.1s]: train==[0.01571=0.00858 + 0.00713]
Epoch 362 [25.2s]: train==[0.01575=0.00862 + 0.00713]
Epoch 363 [25.4s]: train==[0.01569=0.00855 + 0.00714]
Epoch 364 [25.3s]: train==[0.01574=0.00860 + 0.00714]
Epoch 365 [25.0s]: train==[0.01573=0.00859 + 0.00714]
Epoch 366 [25.1s]: train==[0.01566=0.00851 + 0.00715]
Epoch 367 [25.2s]: train==[0.01543=0.00827 + 0.00716]
Epoch 368 [25.3s]: train==[0.01570=0.00854 + 0.00716]
Epoch 369 [25.4s]: train==[0.01575=0.00859 + 0.00716]
Epoch 370 [25.3s]: train==[0.01549=0.00833 + 0.00716]
Epoch 371 [25.4s]: train==[0.01554=0.00837 + 0.00716]
Epoch 372 [25.6s]: train==[0.01555=0.00838 + 0.00717]
Epoch 373 [25.5s]: train==[0.01556=0.00839 + 0.00717]
Epoch 374 [25.2s]: train==[0.01575=0.00857 + 0.00718]
Epoch 375 [25.4s]: train==[0.01569=0.00851 + 0.00718]
Epoch 376 [25.3s]: train==[0.01533=0.00815 + 0.00718]
Epoch 377 [25.0s]: train==[0.01530=0.00811 + 0.00719]
Epoch 378 [25.0s]: train==[0.01532=0.00813 + 0.00719]
Epoch 379 [25.4s]: train==[0.01539=0.00820 + 0.00719]
Epoch 380: train==[0.01542=0.00822 + 0.00720 + 0.00000], recall=[0.32745, 0.58043], hitrate=[0.99163, 0.99983], precision=[0.26806, 0.20207], ndcg=[0.35269, 0.44836]
Epoch 380 [1355.9s + 757.0s]: test==[0.12597=0.11878 + 0.00718 + 0.00000], recall=[0.17592, 0.27293], hitrate=[0.58212, 0.71763], precision=[0.05412, 0.03397], ndcg=[0.15013, 0.18019]
Epoch 381 [25.2s]: train==[0.01524=0.00804 + 0.00720]
Epoch 382 [25.1s]: train==[0.01547=0.00827 + 0.00720]
Epoch 383 [25.4s]: train==[0.01565=0.00845 + 0.00720]
Epoch 384 [25.3s]: train==[0.01535=0.00814 + 0.00721]
Epoch 385 [25.3s]: train==[0.01545=0.00824 + 0.00721]
Epoch 386 [25.3s]: train==[0.01527=0.00806 + 0.00721]
Epoch 387 [25.3s]: train==[0.01536=0.00815 + 0.00722]
Epoch 388 [25.6s]: train==[0.01546=0.00825 + 0.00722]
Epoch 389 [25.4s]: train==[0.01547=0.00824 + 0.00722]
Epoch 390 [26.0s]: train==[0.01541=0.00819 + 0.00722]
Epoch 391 [25.6s]: train==[0.01527=0.00804 + 0.00723]
Epoch 392 [25.7s]: train==[0.01529=0.00806 + 0.00724]
Epoch 393 [25.6s]: train==[0.01517=0.00794 + 0.00723]
Epoch 394 [25.6s]: train==[0.01538=0.00815 + 0.00723]
Epoch 395 [25.4s]: train==[0.01543=0.00819 + 0.00724]
Epoch 396 [25.5s]: train==[0.01550=0.00826 + 0.00724]
Epoch 397 [25.6s]: train==[0.01529=0.00805 + 0.00724]
Epoch 398 [25.4s]: train==[0.01515=0.00791 + 0.00724]
Epoch 399 [25.7s]: train==[0.01500=0.00775 + 0.00724]
Epoch 400: train==[0.01543=0.00818 + 0.00725 + 0.00000], recall=[0.33382, 0.58861], hitrate=[0.99223, 0.99987], precision=[0.27229, 0.20484], ndcg=[0.35778, 0.45442]
Epoch 400 [1354.2s + 761.9s]: test==[0.12616=0.11892 + 0.00723 + 0.00000], recall=[0.17614, 0.27339], hitrate=[0.58269, 0.71760], precision=[0.05413, 0.03407], ndcg=[0.15023, 0.18044]
Epoch 401 [25.1s]: train==[0.01545=0.00820 + 0.00726]
Epoch 402 [25.2s]: train==[0.01532=0.00806 + 0.00725]
Epoch 403 [25.0s]: train==[0.01520=0.00795 + 0.00726]
Epoch 404 [25.0s]: train==[0.01524=0.00798 + 0.00727]
Epoch 405 [24.9s]: train==[0.01545=0.00818 + 0.00726]
Epoch 406 [25.2s]: train==[0.01540=0.00814 + 0.00726]
Epoch 407 [25.4s]: train==[0.01531=0.00804 + 0.00727]
Epoch 408 [25.4s]: train==[0.01533=0.00805 + 0.00727]
Epoch 409 [25.4s]: train==[0.01500=0.00773 + 0.00727]
Epoch 410 [25.3s]: train==[0.01504=0.00776 + 0.00728]
Epoch 411 [24.8s]: train==[0.01518=0.00790 + 0.00728]
Epoch 412 [24.9s]: train==[0.01539=0.00811 + 0.00728]
Epoch 413 [25.0s]: train==[0.01520=0.00792 + 0.00728]
Epoch 414 [24.9s]: train==[0.01536=0.00807 + 0.00729]
Epoch 415 [25.5s]: train==[0.01513=0.00784 + 0.00729]
Epoch 416 [25.4s]: train==[0.01515=0.00786 + 0.00729]
Epoch 417 [25.5s]: train==[0.01498=0.00768 + 0.00730]
Epoch 418 [25.2s]: train==[0.01514=0.00784 + 0.00730]
Epoch 419 [25.2s]: train==[0.01502=0.00772 + 0.00730]
Epoch 420: train==[0.01495=0.00765 + 0.00731 + 0.00000], recall=[0.33940, 0.59519], hitrate=[0.99317, 0.99990], precision=[0.27608, 0.20705], ndcg=[0.36257, 0.45968]
Epoch 420 [1356.8s + 766.5s]: test==[0.12648=0.11919 + 0.00729 + 0.00000], recall=[0.17625, 0.27328], hitrate=[0.58232, 0.71790], precision=[0.05415, 0.03405], ndcg=[0.15036, 0.18051]
Epoch 421 [24.8s]: train==[0.01491=0.00760 + 0.00731]
Epoch 422 [24.8s]: train==[0.01516=0.00785 + 0.00731]
Epoch 423 [25.0s]: train==[0.01515=0.00784 + 0.00731]
Epoch 424 [25.3s]: train==[0.01503=0.00772 + 0.00731]
Epoch 425 [25.2s]: train==[0.01506=0.00775 + 0.00732]
Epoch 426 [25.3s]: train==[0.01495=0.00764 + 0.00732]
Epoch 427 [25.2s]: train==[0.01509=0.00777 + 0.00732]
Epoch 428 [25.3s]: train==[0.01525=0.00793 + 0.00732]
Epoch 429 [25.6s]: train==[0.01482=0.00750 + 0.00732]
Epoch 430 [25.4s]: train==[0.01499=0.00767 + 0.00732]
Epoch 431 [25.3s]: train==[0.01511=0.00779 + 0.00733]
Epoch 432 [25.2s]: train==[0.01496=0.00763 + 0.00732]
Epoch 433 [25.2s]: train==[0.01509=0.00776 + 0.00733]
Epoch 434 [25.4s]: train==[0.01511=0.00778 + 0.00733]
Epoch 435 [25.5s]: train==[0.01504=0.00771 + 0.00733]
Epoch 436 [25.4s]: train==[0.01506=0.00773 + 0.00733]
Epoch 437 [25.3s]: train==[0.01491=0.00757 + 0.00734]
Epoch 438 [25.4s]: train==[0.01505=0.00770 + 0.00734]
Epoch 439 [25.1s]: train==[0.01509=0.00775 + 0.00734]
Epoch 440: train==[0.01506=0.00772 + 0.00734 + 0.00000], recall=[0.34621, 0.60373], hitrate=[0.99427, 0.99993], precision=[0.28089, 0.21020], ndcg=[0.36868, 0.46680]
Epoch 440 [1354.5s + 767.6s]: test==[0.12730=0.11998 + 0.00733 + 0.00000], recall=[0.17702, 0.27455], hitrate=[0.58363, 0.72068], precision=[0.05446, 0.03420], ndcg=[0.15109, 0.18133]
Epoch 441 [24.9s]: train==[0.01509=0.00774 + 0.00735]
Epoch 442 [24.9s]: train==[0.01486=0.00751 + 0.00735]
Epoch 443 [25.1s]: train==[0.01507=0.00772 + 0.00735]
Epoch 444 [24.8s]: train==[0.01492=0.00757 + 0.00735]
Epoch 445 [25.2s]: train==[0.01495=0.00759 + 0.00736]
Epoch 446 [25.2s]: train==[0.01498=0.00762 + 0.00736]
Epoch 447 [25.2s]: train==[0.01497=0.00760 + 0.00736]
Epoch 448 [25.2s]: train==[0.01494=0.00758 + 0.00736]
Epoch 449 [25.1s]: train==[0.01504=0.00768 + 0.00736]
Epoch 450 [25.7s]: train==[0.01488=0.00752 + 0.00736]
Epoch 451 [25.2s]: train==[0.01478=0.00741 + 0.00737]
Epoch 452 [25.1s]: train==[0.01501=0.00765 + 0.00736]
Epoch 453 [25.5s]: train==[0.01487=0.00750 + 0.00737]
Epoch 454 [25.5s]: train==[0.01503=0.00766 + 0.00737]
Epoch 455 [25.5s]: train==[0.01498=0.00760 + 0.00737]
Epoch 456 [25.3s]: train==[0.01490=0.00753 + 0.00737]
Epoch 457 [25.3s]: train==[0.01471=0.00733 + 0.00738]
Epoch 458 [25.4s]: train==[0.01495=0.00757 + 0.00738]
Epoch 459 [25.2s]: train==[0.01499=0.00761 + 0.00738]
Epoch 460: train==[0.01481=0.00743 + 0.00738 + 0.00000], recall=[0.35097, 0.60998], hitrate=[0.99471, 0.99993], precision=[0.28415, 0.21237], ndcg=[0.37238, 0.47132]
Epoch 460 [1351.2s + 763.5s]: test==[0.12666=0.11929 + 0.00736 + 0.00000], recall=[0.17745, 0.27555], hitrate=[0.58383, 0.72061], precision=[0.05453, 0.03433], ndcg=[0.15142, 0.18185]
Epoch 461 [24.9s]: train==[0.01475=0.00737 + 0.00738]
Epoch 462 [24.9s]: train==[0.01471=0.00732 + 0.00739]
Epoch 463 [24.9s]: train==[0.01493=0.00754 + 0.00739]
Epoch 464 [25.5s]: train==[0.01485=0.00747 + 0.00739]
Epoch 465 [25.5s]: train==[0.01490=0.00750 + 0.00739]
Epoch 466 [25.2s]: train==[0.01474=0.00735 + 0.00740]
Epoch 467 [25.0s]: train==[0.01468=0.00729 + 0.00739]
Epoch 468 [25.0s]: train==[0.01465=0.00725 + 0.00740]
Epoch 469 [25.4s]: train==[0.01489=0.00750 + 0.00740]
Epoch 470 [25.4s]: train==[0.01504=0.00764 + 0.00741]
Epoch 471 [25.2s]: train==[0.01489=0.00749 + 0.00740]
Epoch 472 [25.3s]: train==[0.01497=0.00756 + 0.00741]
Epoch 473 [25.3s]: train==[0.01480=0.00740 + 0.00740]
Epoch 474 [25.5s]: train==[0.01487=0.00746 + 0.00741]
Epoch 475 [25.3s]: train==[0.01485=0.00744 + 0.00741]
Epoch 476 [25.2s]: train==[0.01475=0.00733 + 0.00741]
Epoch 477 [25.3s]: train==[0.01491=0.00750 + 0.00741]
Epoch 478 [25.6s]: train==[0.01496=0.00755 + 0.00741]
Epoch 479 [25.6s]: train==[0.01484=0.00743 + 0.00741]
Epoch 480: train==[0.01497=0.00756 + 0.00742 + 0.00000], recall=[0.35690, 0.61626], hitrate=[0.99501, 1.00000], precision=[0.28833, 0.21470], ndcg=[0.37748, 0.47666]
Epoch 480 [1355.2s + 766.3s]: test==[0.12704=0.11964 + 0.00740 + 0.00000], recall=[0.17805, 0.27630], hitrate=[0.58437, 0.72275], precision=[0.05466, 0.03443], ndcg=[0.15161, 0.18209]
Epoch 481 [24.8s]: train==[0.01470=0.00728 + 0.00742]
Epoch 482 [25.2s]: train==[0.01456=0.00714 + 0.00742]
Epoch 483 [25.3s]: train==[0.01471=0.00728 + 0.00742]
Epoch 484 [25.1s]: train==[0.01471=0.00728 + 0.00743]
Epoch 485 [25.1s]: train==[0.01462=0.00719 + 0.00743]
Epoch 486 [25.2s]: train==[0.01488=0.00745 + 0.00743]
Epoch 487 [25.4s]: train==[0.01462=0.00719 + 0.00743]
Epoch 488 [25.3s]: train==[0.01484=0.00740 + 0.00744]
Epoch 489 [25.4s]: train==[0.01471=0.00728 + 0.00744]
Epoch 490 [25.4s]: train==[0.01453=0.00709 + 0.00744]
Epoch 491 [25.5s]: train==[0.01469=0.00725 + 0.00744]
Epoch 492 [25.2s]: train==[0.01477=0.00733 + 0.00744]
Epoch 493 [25.4s]: train==[0.01486=0.00742 + 0.00744]
Epoch 494 [25.4s]: train==[0.01457=0.00712 + 0.00744]
Epoch 495 [25.2s]: train==[0.01476=0.00732 + 0.00744]
Epoch 496 [25.4s]: train==[0.01467=0.00722 + 0.00745]
Epoch 497 [25.5s]: train==[0.01493=0.00749 + 0.00745]
Epoch 498 [25.4s]: train==[0.01449=0.00704 + 0.00745]
Epoch 499 [25.4s]: train==[0.01474=0.00729 + 0.00745]
Epoch 500: train==[0.01476=0.00731 + 0.00745 + 0.00000], recall=[0.36209, 0.62228], hitrate=[0.99581, 1.00000], precision=[0.29191, 0.21694], ndcg=[0.38195, 0.48165]
Epoch 500 [1359.5s + 760.6s]: test==[0.12671=0.11928 + 0.00743 + 0.00000], recall=[0.17857, 0.27594], hitrate=[0.58567, 0.72235], precision=[0.05491, 0.03441], ndcg=[0.15182, 0.18200]
Epoch 501 [25.2s]: train==[0.01456=0.00711 + 0.00745]
Epoch 502 [25.2s]: train==[0.01470=0.00724 + 0.00746]
Epoch 503 [25.2s]: train==[0.01496=0.00751 + 0.00745]
Epoch 504 [25.1s]: train==[0.01471=0.00725 + 0.00746]
Epoch 505 [25.1s]: train==[0.01473=0.00727 + 0.00746]
Epoch 506 [25.2s]: train==[0.01491=0.00745 + 0.00746]
Epoch 507 [25.4s]: train==[0.01462=0.00716 + 0.00746]
Epoch 508 [25.2s]: train==[0.01480=0.00733 + 0.00747]
Epoch 509 [25.1s]: train==[0.01458=0.00711 + 0.00746]
Epoch 510 [25.2s]: train==[0.01464=0.00717 + 0.00747]
Epoch 511 [25.2s]: train==[0.01457=0.00710 + 0.00747]
Epoch 512 [25.3s]: train==[0.01468=0.00721 + 0.00747]
Epoch 513 [25.3s]: train==[0.01466=0.00718 + 0.00748]
Epoch 514 [25.2s]: train==[0.01464=0.00716 + 0.00747]
Epoch 515 [25.5s]: train==[0.01463=0.00715 + 0.00748]
Epoch 516 [25.4s]: train==[0.01463=0.00716 + 0.00748]
Epoch 517 [25.4s]: train==[0.01447=0.00699 + 0.00748]
Epoch 518 [25.2s]: train==[0.01451=0.00702 + 0.00748]
Epoch 519 [25.4s]: train==[0.01443=0.00695 + 0.00748]
Epoch 520: train==[0.01470=0.00722 + 0.00748 + 0.00000], recall=[0.36613, 0.62615], hitrate=[0.99575, 1.00000], precision=[0.29464, 0.21837], ndcg=[0.38575, 0.48539]
Epoch 520 [1356.1s + 755.7s]: test==[0.12686=0.11940 + 0.00746 + 0.00000], recall=[0.17789, 0.27653], hitrate=[0.58487, 0.72265], precision=[0.05482, 0.03451], ndcg=[0.15168, 0.18226]
Epoch 521 [25.1s]: train==[0.01444=0.00695 + 0.00749]
Epoch 522 [24.9s]: train==[0.01445=0.00695 + 0.00749]
Epoch 523 [25.4s]: train==[0.01460=0.00712 + 0.00749]
Epoch 524 [25.2s]: train==[0.01450=0.00701 + 0.00749]
Epoch 525 [25.2s]: train==[0.01461=0.00712 + 0.00749]
Epoch 526 [25.6s]: train==[0.01476=0.00726 + 0.00749]
Epoch 527 [25.3s]: train==[0.01466=0.00717 + 0.00749]
Epoch 528 [25.5s]: train==[0.01453=0.00704 + 0.00749]
Epoch 529 [25.4s]: train==[0.01463=0.00714 + 0.00750]
Epoch 530 [25.4s]: train==[0.01456=0.00707 + 0.00749]
Epoch 531 [25.3s]: train==[0.01460=0.00710 + 0.00750]
Epoch 532 [25.2s]: train==[0.01467=0.00716 + 0.00750]
Epoch 533 [25.6s]: train==[0.01459=0.00710 + 0.00749]
Epoch 534 [25.4s]: train==[0.01460=0.00710 + 0.00750]
Epoch 535 [25.4s]: train==[0.01470=0.00720 + 0.00750]
Epoch 536 [25.3s]: train==[0.01434=0.00684 + 0.00751]
Epoch 537 [25.5s]: train==[0.01456=0.00706 + 0.00750]
Epoch 538 [25.5s]: train==[0.01461=0.00711 + 0.00751]
Epoch 539 [25.7s]: train==[0.01450=0.00699 + 0.00751]

poch 540: train==[0.01442=0.00691 + 0.00751 + 0.00000], recall=[0.37087, 0.63082], hitrate=[0.99571, 1.00000], precision=[0.29800, 0.22006], ndcg=[0.38985, 0.48943]
Epoch 540 [1353.7s + 763.4s]: test==[0.12699=0.11950 + 0.00749 + 0.00000], recall=[0.17861, 0.27725], hitrate=[0.58567, 0.72252], precision=[0.05503, 0.03459], ndcg=[0.15225, 0.18281]
Epoch 541 [25.1s]: train==[0.01438=0.00687 + 0.00751]
Epoch 542 [25.1s]: train==[0.01457=0.00705 + 0.00752]
Epoch 543 [25.1s]: train==[0.01446=0.00694 + 0.00751]
Epoch 544 [25.1s]: train==[0.01442=0.00691 + 0.00752]
Epoch 545 [25.0s]: train==[0.01462=0.00710 + 0.00752]
Epoch 546 [25.3s]: train==[0.01440=0.00687 + 0.00752]
Epoch 547 [25.4s]: train==[0.01430=0.00678 + 0.00752]
Epoch 548 [25.4s]: train==[0.01447=0.00694 + 0.00753]
Epoch 549 [25.5s]: train==[0.01455=0.00702 + 0.00753]
Epoch 550 [25.6s]: train==[0.01446=0.00693 + 0.00752]
Epoch 551 [25.5s]: train==[0.01447=0.00694 + 0.00753]
Epoch 552 [25.4s]: train==[0.01455=0.00703 + 0.00752]
Epoch 553 [25.7s]: train==[0.01439=0.00686 + 0.00753]
Epoch 554 [25.4s]: train==[0.01434=0.00682 + 0.00753]
Epoch 555 [25.8s]: train==[0.01477=0.00725 + 0.00753]
Epoch 556 [25.6s]: train==[0.01424=0.00671 + 0.00753]
Epoch 557 [25.5s]: train==[0.01441=0.00688 + 0.00753]
Epoch 558 [25.5s]: train==[0.01426=0.00673 + 0.00754]
Epoch 559 [25.4s]: train==[0.01448=0.00694 + 0.00754]
Epoch 560: train==[0.01444=0.00690 + 0.00754 + 0.00000], recall=[0.37254, 0.63377], hitrate=[0.99668, 1.00000], precision=[0.29909, 0.22131], ndcg=[0.39153, 0.49198]
Epoch 560 [1338.3s + 768.8s]: test==[0.12722=0.11971 + 0.00751 + 0.00000], recall=[0.17849, 0.27728], hitrate=[0.58550, 0.72386], precision=[0.05494, 0.03458], ndcg=[0.15224, 0.18286]
Epoch 561 [25.5s]: train==[0.01454=0.00700 + 0.00754]
Epoch 562 [25.2s]: train==[0.01442=0.00688 + 0.00754]
Epoch 563 [25.4s]: train==[0.01444=0.00690 + 0.00754]
Epoch 564 [25.3s]: train==[0.01445=0.00691 + 0.00754]
Epoch 565 [25.4s]: train==[0.01437=0.00682 + 0.00754]
Epoch 566 [25.9s]: train==[0.01443=0.00688 + 0.00754]
Epoch 567 [25.4s]: train==[0.01452=0.00697 + 0.00754]
Epoch 568 [25.4s]: train==[0.01437=0.00683 + 0.00754]
Epoch 569 [25.5s]: train==[0.01434=0.00679 + 0.00755]
Epoch 570 [25.5s]: train==[0.01436=0.00682 + 0.00754]
Epoch 571 [25.5s]: train==[0.01439=0.00684 + 0.00755]
Epoch 572 [25.3s]: train==[0.01409=0.00654 + 0.00755]
Epoch 573 [25.5s]: train==[0.01448=0.00693 + 0.00755]
Epoch 574 [25.5s]: train==[0.01454=0.00699 + 0.00755]
Epoch 575 [25.5s]: train==[0.01427=0.00671 + 0.00756]
Epoch 576 [25.8s]: train==[0.01447=0.00691 + 0.00755]
Epoch 577 [27.3s]: train==[0.01441=0.00686 + 0.00755]
Epoch 578 [28.2s]: train==[0.01442=0.00686 + 0.00756]
Epoch 579 [25.5s]: train==[0.01428=0.00673 + 0.00756]
Epoch 580: train==[0.01442=0.00686 + 0.00756 + 0.00000], recall=[0.37662, 0.63852], hitrate=[0.99632, 1.00000], precision=[0.30198, 0.22304], ndcg=[0.39510, 0.49584]
Epoch 580 [1341.6s + 770.0s]: test==[0.12634=0.11881 + 0.00753 + 0.00000], recall=[0.17902, 0.27794], hitrate=[0.58507, 0.72480], precision=[0.05503, 0.03467], ndcg=[0.15254, 0.18324]
Epoch 581 [25.2s]: train==[0.01426=0.00671 + 0.00756]
Epoch 582 [25.1s]: train==[0.01414=0.00657 + 0.00757]
Epoch 583 [25.4s]: train==[0.01427=0.00671 + 0.00756]
Epoch 584 [25.6s]: train==[0.01415=0.00658 + 0.00757]
Epoch 585 [25.4s]: train==[0.01451=0.00694 + 0.00757]
Epoch 586 [25.5s]: train==[0.01424=0.00667 + 0.00757]
Epoch 587 [25.4s]: train==[0.01434=0.00677 + 0.00757]
Epoch 588 [25.5s]: train==[0.01432=0.00675 + 0.00757]
Epoch 589 [25.6s]: train==[0.01444=0.00687 + 0.00757]
Epoch 590 [25.3s]: train==[0.01438=0.00682 + 0.00757]
Epoch 591 [25.5s]: train==[0.01442=0.00685 + 0.00757]
Epoch 592 [26.6s]: train==[0.01422=0.00664 + 0.00758]
Epoch 593 [28.8s]: train==[0.01423=0.00666 + 0.00757]
Epoch 594 [25.7s]: train==[0.01452=0.00694 + 0.00757]
Epoch 595 [25.4s]: train==[0.01432=0.00674 + 0.00758]
Epoch 596 [25.3s]: train==[0.01452=0.00695 + 0.00758]
Epoch 597 [25.5s]: train==[0.01440=0.00682 + 0.00758]
Epoch 598 [25.5s]: train==[0.01425=0.00667 + 0.00758]
Epoch 599 [25.5s]: train==[0.01430=0.00672 + 0.00758]
Epoch 600: train==[0.01428=0.00670 + 0.00758 + 0.00000], recall=[0.37961, 0.64230], hitrate=[0.99672, 0.99997], precision=[0.30432, 0.22460], ndcg=[0.39800, 0.49920]
Epoch 600 [1334.8s + 768.2s]: test==[0.12679=0.11923 + 0.00755 + 0.00000], recall=[0.17912, 0.27786], hitrate=[0.58664, 0.72440], precision=[0.05511, 0.03467], ndcg=[0.15277, 0.18340]
Epoch 601 [25.5s]: train==[0.01436=0.00677 + 0.00758]
Epoch 602 [25.5s]: train==[0.01420=0.00662 + 0.00758]
Epoch 603 [25.6s]: train==[0.01439=0.00680 + 0.00759]
Epoch 604 [25.6s]: train==[0.01431=0.00673 + 0.00758]
Epoch 605 [25.5s]: train==[0.01429=0.00670 + 0.00759]
Epoch 606 [25.3s]: train==[0.01435=0.00676 + 0.00759]
Epoch 607 [28.1s]: train==[0.01448=0.00690 + 0.00759]
Epoch 608 [30.7s]: train==[0.01423=0.00664 + 0.00758]
Epoch 609 [25.5s]: train==[0.01419=0.00660 + 0.00759]
Epoch 610 [25.4s]: train==[0.01424=0.00665 + 0.00759]
Epoch 611 [25.3s]: train==[0.01425=0.00666 + 0.00759]
Epoch 612 [25.6s]: train==[0.01417=0.00659 + 0.00759]
Epoch 613 [27.0s]: train==[0.01429=0.00670 + 0.00759]
Epoch 614 [25.6s]: train==[0.01414=0.00655 + 0.00759]
Epoch 615 [25.8s]: train==[0.01415=0.00655 + 0.00759]
Epoch 616 [25.9s]: train==[0.01427=0.00667 + 0.00760]
Epoch 617 [25.7s]: train==[0.01418=0.00658 + 0.00760]
Epoch 618 [26.2s]: train==[0.01428=0.00668 + 0.00759]
Epoch 619 [26.1s]: train==[0.01431=0.00671 + 0.00760]
Epoch 620: train==[0.01423=0.00664 + 0.00760 + 0.00000], recall=[0.38169, 0.64442], hitrate=[0.99678, 1.00000], precision=[0.30589, 0.22549], ndcg=[0.39929, 0.50057]
Epoch 620 [1346.7s + 774.3s]: test==[0.12674=0.11917 + 0.00757 + 0.00000], recall=[0.17925, 0.27763], hitrate=[0.58698, 0.72393], precision=[0.05521, 0.03471], ndcg=[0.15285, 0.18339]
Epoch 621 [25.7s]: train==[0.01398=0.00639 + 0.00759]
Epoch 622 [25.7s]: train==[0.01431=0.00671 + 0.00760]
Epoch 623 [25.8s]: train==[0.01433=0.00674 + 0.00760]
Epoch 624 [25.8s]: train==[0.01430=0.00670 + 0.00760]
Epoch 625 [25.9s]: train==[0.01424=0.00664 + 0.00760]
Epoch 626 [25.9s]: train==[0.01433=0.00673 + 0.00760]
Epoch 627 [28.5s]: train==[0.01415=0.00654 + 0.00760]
Epoch 628 [27.7s]: train==[0.01435=0.00675 + 0.00760]
Epoch 629 [25.6s]: train==[0.01428=0.00668 + 0.00760]
Epoch 630 [25.6s]: train==[0.01418=0.00658 + 0.00760]
Epoch 631 [25.4s]: train==[0.01432=0.00671 + 0.00760]
Epoch 632 [25.7s]: train==[0.01418=0.00657 + 0.00761]
Epoch 633 [25.7s]: train==[0.01427=0.00666 + 0.00761]
Epoch 634 [25.6s]: train==[0.01424=0.00663 + 0.00761]
Epoch 635 [25.6s]: train==[0.01446=0.00685 + 0.00761]
Epoch 636 [25.8s]: train==[0.01414=0.00654 + 0.00761]
Epoch 637 [25.8s]: train==[0.01419=0.00659 + 0.00760]
Epoch 638 [25.7s]: train==[0.01426=0.00664 + 0.00762]
Epoch 639 [25.5s]: train==[0.01445=0.00684 + 0.00761]
Epoch 640: train==[0.01423=0.00662 + 0.00761 + 0.00000], recall=[0.38615, 0.64989], hitrate=[0.99745, 1.00000], precision=[0.30908, 0.22742], ndcg=[0.40365, 0.50536]
Epoch 640 [1363.1s + 790.3s]: test==[0.12652=0.11893 + 0.00759 + 0.00000], recall=[0.17939, 0.27823], hitrate=[0.58694, 0.72430], precision=[0.05517, 0.03476], ndcg=[0.15303, 0.18375]
Epoch 641 [25.9s]: train==[0.01400=0.00639 + 0.00762]
Epoch 642 [25.8s]: train==[0.01424=0.00662 + 0.00762]
Epoch 643 [25.9s]: train==[0.01393=0.00632 + 0.00762]
Epoch 644 [26.5s]: train==[0.01420=0.00658 + 0.00762]
Epoch 645 [26.1s]: train==[0.01418=0.00656 + 0.00763]
Epoch 646 [27.0s]: train==[0.01421=0.00659 + 0.00762]
Epoch 647 [29.0s]: train==[0.01415=0.00653 + 0.00762]
Epoch 648 [26.7s]: train==[0.01427=0.00665 + 0.00762]
Epoch 649 [26.0s]: train==[0.01414=0.00652 + 0.00762]
Epoch 650 [26.1s]: train==[0.01420=0.00658 + 0.00762]
Epoch 651 [26.5s]: train==[0.01422=0.00659 + 0.00763]
Epoch 652 [25.9s]: train==[0.01412=0.00650 + 0.00762]
Epoch 653 [25.9s]: train==[0.01395=0.00632 + 0.00763]
Epoch 654 [26.3s]: train==[0.01393=0.00630 + 0.00763]
Epoch 655 [25.9s]: train==[0.01419=0.00656 + 0.00763]
Epoch 656 [26.2s]: train==[0.01424=0.00661 + 0.00763]
Epoch 657 [26.6s]: train==[0.01443=0.00680 + 0.00763]
Epoch 658 [26.2s]: train==[0.01421=0.00658 + 0.00763]
Epoch 659 [25.9s]: train==[0.01397=0.00634 + 0.00763]
Epoch 660: train==[0.01427=0.00664 + 0.00763 + 0.00000], recall=[0.38859, 0.65205], hitrate=[0.99695, 1.00000], precision=[0.31086, 0.22844], ndcg=[0.40580, 0.50750]
Epoch 660 [1472.3s + 764.7s]: test==[0.12655=0.11895 + 0.00760 + 0.00000], recall=[0.17925, 0.27829], hitrate=[0.58691, 0.72493], precision=[0.05519, 0.03479], ndcg=[0.15305, 0.18383]
Epoch 661 [25.7s]: train==[0.01421=0.00657 + 0.00764]
Epoch 662 [25.0s]: train==[0.01420=0.00656 + 0.00764]
Epoch 663 [25.1s]: train==[0.01427=0.00664 + 0.00763]
Epoch 664 [25.7s]: train==[0.01416=0.00652 + 0.00763]
Epoch 665 [25.6s]: train==[0.01419=0.00656 + 0.00763]
Epoch 666 [25.4s]: train==[0.01405=0.00641 + 0.00764]
Epoch 667 [25.6s]: train==[0.01419=0.00655 + 0.00764]
Epoch 668 [25.6s]: train==[0.01391=0.00627 + 0.00764]
Epoch 669 [25.3s]: train==[0.01411=0.00647 + 0.00764]
Epoch 670 [25.5s]: train==[0.01412=0.00648 + 0.00764]
Epoch 671 [25.4s]: train==[0.01423=0.00659 + 0.00764]
Epoch 672 [25.4s]: train==[0.01412=0.00648 + 0.00764]
Epoch 673 [25.9s]: train==[0.01408=0.00644 + 0.00764]
Epoch 674 [25.7s]: train==[0.01412=0.00647 + 0.00764]
Epoch 675 [25.3s]: train==[0.01427=0.00663 + 0.00764]
Epoch 676 [25.3s]: train==[0.01426=0.00661 + 0.00764]
Epoch 677 [25.4s]: train==[0.01414=0.00650 + 0.00764]
Epoch 678 [25.6s]: train==[0.01427=0.00663 + 0.00764]
Epoch 679 [25.3s]: train==[0.01423=0.00659 + 0.00764]
Epoch 680: train==[0.01398=0.00634 + 0.00764 + 0.00000], recall=[0.39089, 0.65497], hitrate=[0.99699, 1.00000], precision=[0.31245, 0.22951], ndcg=[0.40773, 0.50982]
Epoch 680 [1332.2s + 774.1s]: test==[0.12736=0.11975 + 0.00761 + 0.00000], recall=[0.17961, 0.27924], hitrate=[0.58835, 0.72614], precision=[0.05542, 0.03489], ndcg=[0.15346, 0.18435]
Epoch 681 [25.4s]: train==[0.01408=0.00643 + 0.00765]
Epoch 682 [25.4s]: train==[0.01414=0.00649 + 0.00764]
Epoch 683 [25.5s]: train==[0.01409=0.00644 + 0.00765]
Epoch 684 [25.7s]: train==[0.01423=0.00658 + 0.00765]
Epoch 685 [25.5s]: train==[0.01416=0.00651 + 0.00765]
Epoch 686 [25.6s]: train==[0.01407=0.00642 + 0.00765]
Epoch 687 [25.3s]: train==[0.01399=0.00634 + 0.00765]
Epoch 688 [25.3s]: train==[0.01414=0.00649 + 0.00765]
Epoch 689 [25.6s]: train==[0.01399=0.00633 + 0.00766]
Epoch 690 [25.3s]: train==[0.01410=0.00644 + 0.00766]
Epoch 691 [25.3s]: train==[0.01397=0.00632 + 0.00765]
Epoch 692 [25.4s]: train==[0.01404=0.00638 + 0.00766]
Epoch 693 [25.5s]: train==[0.01412=0.00647 + 0.00765]
Epoch 694 [25.6s]: train==[0.01391=0.00625 + 0.00766]
Epoch 695 [25.2s]: train==[0.01418=0.00651 + 0.00766]
Epoch 696 [25.3s]: train==[0.01406=0.00641 + 0.00766]
Epoch 697 [25.4s]: train==[0.01410=0.00644 + 0.00766]
Epoch 698 [25.8s]: train==[0.01415=0.00649 + 0.00766]
Epoch 699 [28.2s]: train==[0.01404=0.00638 + 0.00766]
Epoch 700: train==[0.01416=0.00651 + 0.00766 + 0.00000], recall=[0.39322, 0.65744], hitrate=[0.99745, 1.00000], precision=[0.31431, 0.23059], ndcg=[0.40975, 0.51187]
Epoch 700 [1334.3s + 771.3s]: test==[0.12690=0.11927 + 0.00763 + 0.00000], recall=[0.18024, 0.27924], hitrate=[0.58942, 0.72574], precision=[0.05562, 0.03490], ndcg=[0.15374, 0.18441]
Epoch 701 [25.2s]: train==[0.01398=0.00632 + 0.00766]
Epoch 702 [25.4s]: train==[0.01400=0.00634 + 0.00766]
Epoch 703 [25.6s]: train==[0.01400=0.00634 + 0.00766]
Epoch 704 [25.7s]: train==[0.01401=0.00635 + 0.00766]
Epoch 705 [25.5s]: train==[0.01407=0.00641 + 0.00766]
Epoch 706 [25.5s]: train==[0.01411=0.00645 + 0.00766]
Epoch 707 [25.5s]: train==[0.01399=0.00632 + 0.00767]
Epoch 708 [25.6s]: train==[0.01401=0.00634 + 0.00767]
Epoch 709 [25.5s]: train==[0.01407=0.00640 + 0.00767]
Epoch 710 [25.7s]: train==[0.01405=0.00638 + 0.00766]
Epoch 711 [25.6s]: train==[0.01409=0.00642 + 0.00767]
Epoch 712 [25.4s]: train==[0.01405=0.00639 + 0.00767]
Epoch 713 [25.7s]: train==[0.01398=0.00632 + 0.00767]
Epoch 714 [27.6s]: train==[0.01389=0.00622 + 0.00767]
Epoch 715 [28.4s]: train==[0.01425=0.00658 + 0.00767]
Epoch 716 [25.6s]: train==[0.01408=0.00642 + 0.00767]
Epoch 717 [25.3s]: train==[0.01414=0.00647 + 0.00767]
Epoch 718 [25.4s]: train==[0.01394=0.00627 + 0.00767]
Epoch 719 [25.5s]: train==[0.01396=0.00629 + 0.00767]
Epoch 720: train==[0.01412=0.00645 + 0.00767 + 0.00000], recall=[0.39520, 0.65996], hitrate=[0.99702, 1.00000], precision=[0.31595, 0.23158], ndcg=[0.41131, 0.51367]
Epoch 720 [1333.7s + 773.0s]: test==[0.12691=0.11926 + 0.00764 + 0.00000], recall=[0.18000, 0.27981], hitrate=[0.58972, 0.72600], precision=[0.05548, 0.03494], ndcg=[0.15340, 0.18435]
Epoch 721 [25.5s]: train==[0.01422=0.00655 + 0.00767]
Epoch 722 [25.8s]: train==[0.01400=0.00633 + 0.00768]
Epoch 723 [25.5s]: train==[0.01407=0.00639 + 0.00767]
Epoch 724 [25.4s]: train==[0.01398=0.00631 + 0.00767]
Epoch 725 [25.7s]: train==[0.01402=0.00635 + 0.00767]
Epoch 726 [25.6s]: train==[0.01417=0.00649 + 0.00767]
Epoch 727 [25.6s]: train==[0.01388=0.00620 + 0.00768]
Epoch 728 [25.7s]: train==[0.01389=0.00621 + 0.00768]
Epoch 729 [26.1s]: train==[0.01411=0.00643 + 0.00768]
Epoch 730 [29.1s]: train==[0.01402=0.00635 + 0.00768]
Epoch 731 [27.1s]: train==[0.01414=0.00647 + 0.00768]
Epoch 732 [25.2s]: train==[0.01405=0.00637 + 0.00768]
Epoch 733 [25.4s]: train==[0.01396=0.00629 + 0.00768]
Epoch 734 [25.4s]: train==[0.01395=0.00628 + 0.00768]
Epoch 735 [25.5s]: train==[0.01403=0.00635 + 0.00768]
Epoch 736 [25.9s]: train==[0.01391=0.00622 + 0.00768]
Epoch 737 [25.7s]: train==[0.01408=0.00639 + 0.00768]
Epoch 738 [25.4s]: train==[0.01397=0.00628 + 0.00769]
Epoch 739 [25.1s]: train==[0.01397=0.00628 + 0.00769]
Epoch 740: train==[0.01388=0.00620 + 0.00769 + 0.00000], recall=[0.39671, 0.66195], hitrate=[0.99709, 1.00000], precision=[0.31738, 0.23248], ndcg=[0.41380, 0.51631]
Epoch 740 [1326.9s + 765.7s]: test==[0.12647=0.11881 + 0.00766 + 0.00000], recall=[0.18007, 0.27991], hitrate=[0.58835, 0.72677], precision=[0.05555, 0.03499], ndcg=[0.15355, 0.18453]
Epoch 741 [25.5s]: train==[0.01388=0.00619 + 0.00768]
Epoch 742 [25.2s]: train==[0.01408=0.00639 + 0.00769]
Epoch 743 [25.4s]: train==[0.01406=0.00637 + 0.00769]
Epoch 744 [25.4s]: train==[0.01413=0.00644 + 0.00768]
Epoch 745 [25.4s]: train==[0.01399=0.00631 + 0.00769]
Epoch 746 [25.6s]: train==[0.01392=0.00623 + 0.00769]
Epoch 747 [25.4s]: train==[0.01405=0.00636 + 0.00769]
Epoch 748 [25.4s]: train==[0.01398=0.00628 + 0.00769]
Epoch 749 [25.2s]: train==[0.01407=0.00638 + 0.00769]
Epoch 750 [25.2s]: train==[0.01397=0.00627 + 0.00770]
Epoch 751 [25.6s]: train==[0.01402=0.00634 + 0.00769]
Epoch 752 [25.3s]: train==[0.01395=0.00626 + 0.00769]
Epoch 753 [25.2s]: train==[0.01401=0.00631 + 0.00770]
Epoch 754 [25.6s]: train==[0.01401=0.00632 + 0.00769]
Epoch 755 [25.5s]: train==[0.01401=0.00631 + 0.00770]
Epoch 756 [25.5s]: train==[0.01400=0.00630 + 0.00770]
Epoch 757 [25.4s]: train==[0.01400=0.00630 + 0.00770]
Epoch 758 [25.4s]: train==[0.01401=0.00631 + 0.00770]
Epoch 759 [25.0s]: train==[0.01413=0.00643 + 0.00770]
Epoch 760: train==[0.01391=0.00621 + 0.00770 + 0.00000], recall=[0.39925, 0.66457], hitrate=[0.99732, 1.00000], precision=[0.31891, 0.23349], ndcg=[0.41563, 0.51833]
Epoch 760 [1337.0s + 771.7s]: test==[0.12732=0.11966 + 0.00767 + 0.00000], recall=[0.18039, 0.28052], hitrate=[0.58969, 0.72818], precision=[0.05567, 0.03504], ndcg=[0.15372, 0.18476]
Epoch 761 [25.1s]: train==[0.01396=0.00626 + 0.00770]
Epoch 762 [25.0s]: train==[0.01390=0.00621 + 0.00769]
Epoch 763 [25.2s]: train==[0.01395=0.00624 + 0.00770]
Epoch 764 [25.6s]: train==[0.01386=0.00616 + 0.00770]
Epoch 765 [25.3s]: train==[0.01421=0.00651 + 0.00770]
Epoch 766 [25.3s]: train==[0.01410=0.00640 + 0.00770]
Epoch 767 [25.4s]: train==[0.01399=0.00629 + 0.00769]
Epoch 768 [25.4s]: train==[0.01387=0.00617 + 0.00770]
Epoch 769 [25.7s]: train==[0.01394=0.00623 + 0.00770]
Epoch 770 [25.4s]: train==[0.01399=0.00629 + 0.00770]
Epoch 771 [25.4s]: train==[0.01406=0.00636 + 0.00771]
Epoch 772 [25.5s]: train==[0.01397=0.00626 + 0.00771]
Epoch 773 [25.4s]: train==[0.01396=0.00626 + 0.00771]
Epoch 774 [25.4s]: train==[0.01390=0.00620 + 0.00770]
Epoch 775 [25.6s]: train==[0.01398=0.00627 + 0.00771]
Epoch 776 [25.5s]: train==[0.01394=0.00623 + 0.00771]
Epoch 777 [25.7s]: train==[0.01417=0.00646 + 0.00770]
Epoch 778 [25.6s]: train==[0.01391=0.00621 + 0.00771]
Epoch 779 [25.4s]: train==[0.01388=0.00617 + 0.00771]
Epoch 780: train==[0.01390=0.00619 + 0.00771 + 0.00000], recall=[0.40190, 0.66661], hitrate=[0.99729, 1.00000], precision=[0.32080, 0.23434], ndcg=[0.41797, 0.52041]
Epoch 780 [1338.1s + 769.0s]: test==[0.12697=0.11929 + 0.00768 + 0.00000], recall=[0.18070, 0.28043], hitrate=[0.59046, 0.72848], precision=[0.05569, 0.03506], ndcg=[0.15416, 0.18514]
Epoch 781 [25.2s]: train==[0.01387=0.00616 + 0.00771]
Epoch 782 [25.5s]: train==[0.01419=0.00648 + 0.00771]
Epoch 783 [25.1s]: train==[0.01407=0.00636 + 0.00771]
Epoch 784 [25.2s]: train==[0.01386=0.00615 + 0.00771]
Epoch 785 [25.2s]: train==[0.01384=0.00613 + 0.00771]
Epoch 786 [25.0s]: train==[0.01385=0.00614 + 0.00771]
Epoch 787 [25.1s]: train==[0.01388=0.00617 + 0.00771]
Epoch 788 [25.3s]: train==[0.01391=0.00620 + 0.00771]
Epoch 789 [25.5s]: train==[0.01405=0.00634 + 0.00771]
Epoch 790 [25.2s]: train==[0.01389=0.00618 + 0.00771]
Epoch 791 [25.3s]: train==[0.01376=0.00604 + 0.00772]
Epoch 792 [25.2s]: train==[0.01408=0.00636 + 0.00772]
Epoch 793 [25.0s]: train==[0.01402=0.00631 + 0.00772]
Epoch 794 [25.2s]: train==[0.01396=0.00624 + 0.00772]
Epoch 795 [25.3s]: train==[0.01388=0.00615 + 0.00772]
Epoch 796 [25.3s]: train==[0.01380=0.00608 + 0.00772]
Epoch 797 [25.4s]: train==[0.01397=0.00625 + 0.00772]
Epoch 798 [25.6s]: train==[0.01389=0.00617 + 0.00772]
Epoch 799 [25.3s]: train==[0.01378=0.00605 + 0.00772]
Epoch 800: train==[0.01399=0.00627 + 0.00773 + 0.00000], recall=[0.40258, 0.66779], hitrate=[0.99786, 1.00000], precision=[0.32161, 0.23500], ndcg=[0.41924, 0.52186]
Epoch 800 [1336.0s + 761.5s]: test==[0.12719=0.11950 + 0.00769 + 0.00000], recall=[0.18115, 0.28060], hitrate=[0.59023, 0.72872], precision=[0.05582, 0.03509], ndcg=[0.15430, 0.18516]
Epoch 801 [25.3s]: train==[0.01382=0.00610 + 0.00772]
Epoch 802 [25.4s]: train==[0.01385=0.00613 + 0.00773]
Epoch 803 [25.3s]: train==[0.01381=0.00609 + 0.00772]
Epoch 804 [25.5s]: train==[0.01396=0.00623 + 0.00773]
Epoch 805 [25.5s]: train==[0.01383=0.00611 + 0.00772]
Epoch 806 [25.2s]: train==[0.01375=0.00603 + 0.00772]
Epoch 807 [25.4s]: train==[0.01374=0.00602 + 0.00773]
Epoch 808 [25.4s]: train==[0.01385=0.00612 + 0.00773]
Epoch 809 [25.1s]: train==[0.01403=0.00630 + 0.00772]
Epoch 810 [25.1s]: train==[0.01364=0.00591 + 0.00773]
Epoch 811 [25.2s]: train==[0.01380=0.00607 + 0.00773]
Epoch 812 [25.3s]: train==[0.01381=0.00608 + 0.00772]
Epoch 813 [25.1s]: train==[0.01378=0.00606 + 0.00773]
Epoch 814 [25.4s]: train==[0.01382=0.00609 + 0.00773]
Epoch 815 [25.6s]: train==[0.01398=0.00626 + 0.00773]
Epoch 816 [25.3s]: train==[0.01391=0.00618 + 0.00773]
Epoch 817 [25.4s]: train==[0.01391=0.00618 + 0.00773]
Epoch 818 [25.3s]: train==[0.01395=0.00622 + 0.00773]
Epoch 819 [25.2s]: train==[0.01392=0.00620 + 0.00773]
Epoch 820: train==[0.01387=0.00614 + 0.00773 + 0.00000], recall=[0.40309, 0.66855], hitrate=[0.99752, 1.00000], precision=[0.32182, 0.23530], ndcg=[0.41898, 0.52186]
Epoch 820 [1330.3s + 769.4s]: test==[0.12561=0.11791 + 0.00769 + 0.00000], recall=[0.18086, 0.28088], hitrate=[0.59100, 0.72774], precision=[0.05580, 0.03512], ndcg=[0.15420, 0.18525]
Epoch 821 [25.2s]: train==[0.01398=0.00625 + 0.00773]
Epoch 822 [25.6s]: train==[0.01410=0.00637 + 0.00773]
Epoch 823 [25.1s]: train==[0.01383=0.00610 + 0.00773]
Epoch 824 [25.4s]: train==[0.01380=0.00607 + 0.00773]
Epoch 825 [25.3s]: train==[0.01394=0.00621 + 0.00773]
Epoch 826 [25.4s]: train==[0.01398=0.00626 + 0.00773]
Epoch 827 [25.6s]: train==[0.01386=0.00613 + 0.00773]
Epoch 828 [25.5s]: train==[0.01380=0.00607 + 0.00773]
Epoch 829 [25.2s]: train==[0.01386=0.00613 + 0.00773]
Epoch 830 [25.3s]: train==[0.01380=0.00607 + 0.00773]
Epoch 831 [25.4s]: train==[0.01400=0.00627 + 0.00773]
Epoch 832 [25.6s]: train==[0.01381=0.00608 + 0.00773]
Epoch 833 [25.4s]: train==[0.01413=0.00639 + 0.00774]
Epoch 834 [25.6s]: train==[0.01379=0.00606 + 0.00773]
Epoch 835 [25.7s]: train==[0.01381=0.00608 + 0.00773]
Epoch 836 [25.7s]: train==[0.01395=0.00622 + 0.00773]
Epoch 837 [25.3s]: train==[0.01381=0.00608 + 0.00773]
Epoch 838 [25.2s]: train==[0.01390=0.00616 + 0.00773]
Epoch 839 [25.4s]: train==[0.01389=0.00616 + 0.00773]
Epoch 840: train==[0.01384=0.00610 + 0.00774 + 0.00000], recall=[0.40655, 0.67177], hitrate=[0.99782, 1.00000], precision=[0.32428, 0.23650], ndcg=[0.42210, 0.52483]
Epoch 840 [1340.7s + 772.3s]: test==[0.12686=0.11916 + 0.00770 + 0.00000], recall=[0.18175, 0.28109], hitrate=[0.59220, 0.72818], precision=[0.05592, 0.03518], ndcg=[0.15457, 0.18546]
Epoch 841 [25.2s]: train==[0.01383=0.00609 + 0.00774]
Epoch 842 [25.2s]: train==[0.01377=0.00603 + 0.00774]
Epoch 843 [25.1s]: train==[0.01388=0.00614 + 0.00774]
Epoch 844 [25.5s]: train==[0.01383=0.00609 + 0.00774]
Epoch 845 [25.3s]: train==[0.01384=0.00611 + 0.00774]
Epoch 846 [25.3s]: train==[0.01378=0.00604 + 0.00773]
Epoch 847 [25.4s]: train==[0.01416=0.00642 + 0.00774]
Epoch 848 [25.5s]: train==[0.01382=0.00609 + 0.00773]
Epoch 849 [25.1s]: train==[0.01394=0.00620 + 0.00773]
Epoch 850 [25.1s]: train==[0.01397=0.00622 + 0.00774]
Epoch 851 [25.1s]: train==[0.01373=0.00599 + 0.00774]
Epoch 852 [25.1s]: train==[0.01388=0.00614 + 0.00774]
Epoch 853 [25.4s]: train==[0.01395=0.00621 + 0.00774]
Epoch 854 [25.4s]: train==[0.01388=0.00613 + 0.00774]
Epoch 855 [25.3s]: train==[0.01392=0.00618 + 0.00774]
Epoch 856 [25.2s]: train==[0.01395=0.00622 + 0.00774]
Epoch 857 [25.2s]: train==[0.01376=0.00601 + 0.00775]
Epoch 858 [25.4s]: train==[0.01386=0.00611 + 0.00774]
Epoch 859 [25.2s]: train==[0.01385=0.00610 + 0.00775]
Epoch 860: train==[0.01378=0.00602 + 0.00775 + 0.00000], recall=[0.40757, 0.67284], hitrate=[0.99806, 1.00000], precision=[0.32528, 0.23708], ndcg=[0.42325, 0.52598]
Epoch 860 [1330.3s + 767.3s]: test==[0.12611=0.11839 + 0.00772 + 0.00000], recall=[0.18138, 0.28104], hitrate=[0.59190, 0.72851], precision=[0.05590, 0.03517], ndcg=[0.15424, 0.18520]
Epoch 861 [25.5s]: train==[0.01386=0.00611 + 0.00775]
Epoch 862 [25.3s]: train==[0.01384=0.00609 + 0.00774]
Epoch 863 [25.2s]: train==[0.01389=0.00614 + 0.00775]
Epoch 864 [25.0s]: train==[0.01362=0.00587 + 0.00775]
Epoch 865 [25.3s]: train==[0.01367=0.00592 + 0.00775]
Epoch 866 [25.1s]: train==[0.01375=0.00600 + 0.00775]
Epoch 867 [25.3s]: train==[0.01385=0.00610 + 0.00776]
Epoch 868 [25.4s]: train==[0.01379=0.00604 + 0.00775]
Epoch 869 [25.1s]: train==[0.01381=0.00606 + 0.00775]
Epoch 870 [25.1s]: train==[0.01372=0.00597 + 0.00775]
Epoch 871 [25.4s]: train==[0.01393=0.00617 + 0.00776]
Epoch 872 [25.4s]: train==[0.01390=0.00614 + 0.00776]
Epoch 873 [25.7s]: train==[0.01373=0.00597 + 0.00776]
Epoch 874 [25.4s]: train==[0.01388=0.00612 + 0.00775]
Epoch 875 [25.0s]: train==[0.01386=0.00611 + 0.00775]
Epoch 876 [25.1s]: train==[0.01361=0.00586 + 0.00775]
Epoch 877 [24.7s]: train==[0.01404=0.00629 + 0.00775]
Epoch 878 [25.2s]: train==[0.01387=0.00611 + 0.00775]
Epoch 879 [25.2s]: train==[0.01375=0.00600 + 0.00775]
Epoch 880: train==[0.01385=0.00609 + 0.00775 + 0.00000], recall=[0.40855, 0.67383], hitrate=[0.99792, 1.00000], precision=[0.32623, 0.23766], ndcg=[0.42493, 0.52760]
Epoch 880 [1332.8s + 771.2s]: test==[0.12580=0.11808 + 0.00772 + 0.00000], recall=[0.18125, 0.28148], hitrate=[0.59063, 0.72818], precision=[0.05596, 0.03520], ndcg=[0.15448, 0.18556]
Epoch 881 [25.4s]: train==[0.01390=0.00614 + 0.00776]
Epoch 882 [25.2s]: train==[0.01386=0.00611 + 0.00775]
Epoch 883 [25.2s]: train==[0.01377=0.00601 + 0.00776]
Epoch 884 [25.7s]: train==[0.01368=0.00592 + 0.00776]
Epoch 885 [25.3s]: train==[0.01379=0.00603 + 0.00775]
Epoch 886 [25.3s]: train==[0.01386=0.00610 + 0.00776]
Epoch 887 [25.2s]: train==[0.01384=0.00609 + 0.00775]
Epoch 888 [25.2s]: train==[0.01373=0.00598 + 0.00776]
Epoch 889 [25.3s]: train==[0.01376=0.00601 + 0.00776]
Epoch 890 [25.1s]: train==[0.01377=0.00601 + 0.00776]
Epoch 891 [25.5s]: train==[0.01386=0.00610 + 0.00776]
Epoch 892 [25.4s]: train==[0.01377=0.00601 + 0.00776]
Epoch 893 [25.2s]: train==[0.01377=0.00601 + 0.00776]
Epoch 894 [25.5s]: train==[0.01372=0.00596 + 0.00776]
Epoch 895 [25.5s]: train==[0.01397=0.00621 + 0.00776]
Epoch 896 [25.3s]: train==[0.01374=0.00598 + 0.00776]
Epoch 897 [25.4s]: train==[0.01401=0.00625 + 0.00776]
Epoch 898 [25.4s]: train==[0.01363=0.00587 + 0.00776]
Epoch 899 [25.3s]: train==[0.01382=0.00605 + 0.00776]
Epoch 900: train==[0.01368=0.00592 + 0.00776 + 0.00000], recall=[0.40860, 0.67480], hitrate=[0.99792, 1.00000], precision=[0.32631, 0.23797], ndcg=[0.42478, 0.52796]
Epoch 900 [1338.6s + 772.3s]: test==[0.12672=0.11899 + 0.00773 + 0.00000], recall=[0.18144, 0.28141], hitrate=[0.59080, 0.72935], precision=[0.05592, 0.03522], ndcg=[0.15451, 0.18559]
Epoch 901 [25.8s]: train==[0.01382=0.00606 + 0.00776]
Epoch 902 [25.6s]: train==[0.01385=0.00609 + 0.00776]
Epoch 903 [25.7s]: train==[0.01399=0.00623 + 0.00776]
Epoch 904 [25.8s]: train==[0.01377=0.00601 + 0.00776]
Epoch 905 [25.6s]: train==[0.01345=0.00568 + 0.00777]
Epoch 906 [25.6s]: train==[0.01395=0.00618 + 0.00776]
Epoch 907 [25.6s]: train==[0.01386=0.00610 + 0.00776]
Epoch 908 [25.4s]: train==[0.01371=0.00595 + 0.00776]
Epoch 909 [25.2s]: train==[0.01383=0.00606 + 0.00777]
Epoch 910 [25.5s]: train==[0.01383=0.00607 + 0.00776]
Epoch 911 [25.5s]: train==[0.01388=0.00612 + 0.00776]
Epoch 912 [25.3s]: train==[0.01368=0.00591 + 0.00776]
Epoch 913 [25.2s]: train==[0.01366=0.00589 + 0.00777]
Epoch 914 [25.4s]: train==[0.01383=0.00606 + 0.00777]
Epoch 915 [25.5s]: train==[0.01381=0.00604 + 0.00777]
Epoch 916 [25.5s]: train==[0.01380=0.00603 + 0.00777]
Epoch 917 [25.4s]: train==[0.01371=0.00594 + 0.00777]
Epoch 918 [25.4s]: train==[0.01376=0.00599 + 0.00777]
Epoch 919 [25.3s]: train==[0.01369=0.00593 + 0.00777]
Epoch 920: train==[0.01386=0.00609 + 0.00778 + 0.00000], recall=[0.41080, 0.67647], hitrate=[0.99779, 1.00000], precision=[0.32777, 0.23872], ndcg=[0.42639, 0.52937]
Epoch 920 [1339.2s + 771.3s]: test==[0.12573=0.11799 + 0.00774 + 0.00000], recall=[0.18154, 0.28254], hitrate=[0.59163, 0.72942], precision=[0.05591, 0.03532], ndcg=[0.15432, 0.18572]
Epoch 921 [25.8s]: train==[0.01379=0.00602 + 0.00777]
Epoch 922 [25.4s]: train==[0.01382=0.00605 + 0.00777]
Epoch 923 [25.2s]: train==[0.01390=0.00613 + 0.00777]
Epoch 924 [25.5s]: train==[0.01386=0.00609 + 0.00777]
Epoch 925 [25.8s]: train==[0.01391=0.00614 + 0.00777]
Epoch 926 [25.8s]: train==[0.01358=0.00581 + 0.00777]
Epoch 927 [25.9s]: train==[0.01361=0.00584 + 0.00777]
Epoch 928 [25.5s]: train==[0.01384=0.00607 + 0.00777]
Epoch 929 [25.2s]: train==[0.01367=0.00589 + 0.00777]
Epoch 930 [25.8s]: train==[0.01381=0.00604 + 0.00778]
Epoch 931 [25.0s]: train==[0.01386=0.00609 + 0.00777]
Epoch 932 [25.0s]: train==[0.01375=0.00598 + 0.00778]
Epoch 933 [25.1s]: train==[0.01375=0.00597 + 0.00778]
Epoch 934 [25.2s]: train==[0.01387=0.00609 + 0.00778]
Epoch 935 [25.3s]: train==[0.01375=0.00597 + 0.00778]
Epoch 936 [25.2s]: train==[0.01373=0.00595 + 0.00778]
Epoch 937 [25.0s]: train==[0.01378=0.00600 + 0.00778]
Epoch 938 [25.3s]: train==[0.01357=0.00578 + 0.00778]
Epoch 939 [25.3s]: train==[0.01374=0.00595 + 0.00779]
Epoch 940: train==[0.01382=0.00604 + 0.00778 + 0.00000], recall=[0.41391, 0.67847], hitrate=[0.99799, 1.00000], precision=[0.32981, 0.23953], ndcg=[0.42897, 0.53146]
Epoch 940 [1331.3s + 772.8s]: test==[0.12586=0.11811 + 0.00775 + 0.00000], recall=[0.18192, 0.28249], hitrate=[0.59163, 0.73016], precision=[0.05613, 0.03532], ndcg=[0.15467, 0.18588]
Epoch 941 [25.6s]: train==[0.01362=0.00584 + 0.00778]
Epoch 942 [25.4s]: train==[0.01364=0.00585 + 0.00778]
Epoch 943 [25.3s]: train==[0.01373=0.00595 + 0.00778]
Epoch 944 [24.9s]: train==[0.01375=0.00597 + 0.00778]
Epoch 945 [25.0s]: train==[0.01374=0.00596 + 0.00778]
Epoch 946 [25.2s]: train==[0.01359=0.00580 + 0.00779]
Epoch 947 [25.1s]: train==[0.01381=0.00603 + 0.00778]
Epoch 948 [25.6s]: train==[0.01373=0.00595 + 0.00778]
Epoch 949 [25.4s]: train==[0.01377=0.00599 + 0.00778]
Epoch 950 [25.2s]: train==[0.01382=0.00603 + 0.00779]
Epoch 951 [25.4s]: train==[0.01376=0.00597 + 0.00779]
Epoch 952 [25.2s]: train==[0.01373=0.00594 + 0.00779]
Epoch 953 [25.7s]: train==[0.01372=0.00594 + 0.00778]
Epoch 954 [25.8s]: train==[0.01369=0.00591 + 0.00778]
Epoch 955 [25.3s]: train==[0.01368=0.00590 + 0.00778]
Epoch 956 [25.4s]: train==[0.01376=0.00597 + 0.00779]
Epoch 957 [25.3s]: train==[0.01359=0.00581 + 0.00778]
Epoch 958 [25.5s]: train==[0.01381=0.00602 + 0.00779]
Epoch 959 [25.2s]: train==[0.01366=0.00588 + 0.00778]
Epoch 960: train==[0.01365=0.00587 + 0.00778 + 0.00000], recall=[0.41400, 0.67853], hitrate=[0.99822, 1.00000], precision=[0.33024, 0.23966], ndcg=[0.42971, 0.53202]
Epoch 960 [1337.1s + 769.8s]: test==[0.12614=0.11839 + 0.00775 + 0.00000], recall=[0.18202, 0.28217], hitrate=[0.59237, 0.72945], precision=[0.05609, 0.03531], ndcg=[0.15474, 0.18585]
Epoch 961 [25.3s]: train==[0.01388=0.00609 + 0.00778]
Epoch 962 [25.3s]: train==[0.01370=0.00591 + 0.00778]
Epoch 963 [24.9s]: train==[0.01372=0.00594 + 0.00779]
Epoch 964 [25.2s]: train==[0.01370=0.00592 + 0.00778]
Epoch 965 [25.0s]: train==[0.01383=0.00605 + 0.00778]
Epoch 966 [24.9s]: train==[0.01384=0.00606 + 0.00778]
Epoch 967 [25.0s]: train==[0.01357=0.00578 + 0.00779]
Epoch 968 [25.1s]: train==[0.01379=0.00601 + 0.00778]
Epoch 969 [25.2s]: train==[0.01369=0.00590 + 0.00779]
Epoch 970 [25.4s]: train==[0.01364=0.00585 + 0.00778]
Epoch 971 [25.3s]: train==[0.01365=0.00586 + 0.00779]
Epoch 972 [25.2s]: train==[0.01366=0.00588 + 0.00778]
Epoch 973 [25.0s]: train==[0.01368=0.00590 + 0.00779]
Epoch 974 [25.4s]: train==[0.01374=0.00596 + 0.00778]
Epoch 975 [25.2s]: train==[0.01385=0.00607 + 0.00778]
Epoch 976 [25.4s]: train==[0.01376=0.00597 + 0.00779]
Epoch 977 [25.6s]: train==[0.01374=0.00596 + 0.00779]
Epoch 978 [25.2s]: train==[0.01358=0.00580 + 0.00779]
Epoch 979 [25.0s]: train==[0.01373=0.00595 + 0.00779]
Epoch 980: train==[0.01375=0.00596 + 0.00779 + 0.00000], recall=[0.41387, 0.67985], hitrate=[0.99799, 1.00000], precision=[0.33016, 0.24020], ndcg=[0.42934, 0.53253]
Epoch 980 [1334.4s + 771.3s]: test==[0.12640=0.11864 + 0.00776 + 0.00000], recall=[0.18132, 0.28185], hitrate=[0.59194, 0.72922], precision=[0.05593, 0.03524], ndcg=[0.15427, 0.18549]
Epoch 981 [25.2s]: train==[0.01354=0.00575 + 0.00779]
Epoch 982 [25.1s]: train==[0.01365=0.00587 + 0.00778]
Epoch 983 [25.4s]: train==[0.01362=0.00583 + 0.00779]
Epoch 984 [25.6s]: train==[0.01350=0.00572 + 0.00779]
Epoch 985 [25.2s]: train==[0.01365=0.00586 + 0.00779]
Epoch 986 [25.3s]: train==[0.01350=0.00571 + 0.00779]
Epoch 987 [25.0s]: train==[0.01378=0.00599 + 0.00779]
Epoch 988 [25.2s]: train==[0.01365=0.00586 + 0.00779]
Epoch 989 [25.1s]: train==[0.01367=0.00588 + 0.00779]
Epoch 990 [25.4s]: train==[0.01377=0.00598 + 0.00779]
Epoch 991 [25.1s]: train==[0.01377=0.00597 + 0.00779]
Epoch 992 [25.5s]: train==[0.01365=0.00586 + 0.00779]
Epoch 993 [25.3s]: train==[0.01368=0.00589 + 0.00779]
Epoch 994 [25.2s]: train==[0.01350=0.00570 + 0.00779]
Epoch 995 [25.8s]: train==[0.01374=0.00594 + 0.00779]
Epoch 996 [25.4s]: train==[0.01367=0.00588 + 0.00779]
Epoch 997 [25.1s]: train==[0.01373=0.00594 + 0.00779]
Epoch 998 [25.4s]: train==[0.01372=0.00593 + 0.00778]
Epoch 999 [25.5s]: train==[0.01372=0.00593 + 0.00779]
Epoch 1000: train==[0.01365=0.00586 + 0.00779 + 0.00000], recall=[0.41550, 0.68044], hitrate=[0.99822, 1.00000], precision=[0.33148, 0.24045], ndcg=[0.43072, 0.53335]
Epoch 1000 [1328.3s + 767.1s]: test==[0.12550=0.11775 + 0.00775 + 0.00000], recall=[0.18176, 0.28230], hitrate=[0.59163, 0.72885], precision=[0.05611, 0.03532], ndcg=[0.15463, 0.18584]
Best Iter=[47]@[132063.9]      recall=[0.18202 0.28217], hitrate=[0.59237 0.72945], precision=[0.05609 0.03531], ndcg=[0.15474 0.18585]
```

