nextrec 0.1.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. nextrec/__init__.py +41 -0
  2. nextrec/__version__.py +1 -0
  3. nextrec/basic/__init__.py +0 -0
  4. nextrec/basic/activation.py +92 -0
  5. nextrec/basic/callback.py +35 -0
  6. nextrec/basic/dataloader.py +447 -0
  7. nextrec/basic/features.py +87 -0
  8. nextrec/basic/layers.py +985 -0
  9. nextrec/basic/loggers.py +124 -0
  10. nextrec/basic/metrics.py +557 -0
  11. nextrec/basic/model.py +1438 -0
  12. nextrec/data/__init__.py +27 -0
  13. nextrec/data/data_utils.py +132 -0
  14. nextrec/data/preprocessor.py +662 -0
  15. nextrec/loss/__init__.py +35 -0
  16. nextrec/loss/loss_utils.py +136 -0
  17. nextrec/loss/match_losses.py +294 -0
  18. nextrec/models/generative/hstu.py +0 -0
  19. nextrec/models/generative/tiger.py +0 -0
  20. nextrec/models/match/__init__.py +13 -0
  21. nextrec/models/match/dssm.py +200 -0
  22. nextrec/models/match/dssm_v2.py +162 -0
  23. nextrec/models/match/mind.py +210 -0
  24. nextrec/models/match/sdm.py +253 -0
  25. nextrec/models/match/youtube_dnn.py +172 -0
  26. nextrec/models/multi_task/esmm.py +129 -0
  27. nextrec/models/multi_task/mmoe.py +161 -0
  28. nextrec/models/multi_task/ple.py +260 -0
  29. nextrec/models/multi_task/share_bottom.py +126 -0
  30. nextrec/models/ranking/__init__.py +17 -0
  31. nextrec/models/ranking/afm.py +118 -0
  32. nextrec/models/ranking/autoint.py +140 -0
  33. nextrec/models/ranking/dcn.py +120 -0
  34. nextrec/models/ranking/deepfm.py +95 -0
  35. nextrec/models/ranking/dien.py +214 -0
  36. nextrec/models/ranking/din.py +181 -0
  37. nextrec/models/ranking/fibinet.py +130 -0
  38. nextrec/models/ranking/fm.py +87 -0
  39. nextrec/models/ranking/masknet.py +125 -0
  40. nextrec/models/ranking/pnn.py +128 -0
  41. nextrec/models/ranking/widedeep.py +105 -0
  42. nextrec/models/ranking/xdeepfm.py +117 -0
  43. nextrec/utils/__init__.py +18 -0
  44. nextrec/utils/common.py +14 -0
  45. nextrec/utils/embedding.py +19 -0
  46. nextrec/utils/initializer.py +47 -0
  47. nextrec/utils/optimizer.py +75 -0
  48. nextrec-0.1.1.dist-info/METADATA +302 -0
  49. nextrec-0.1.1.dist-info/RECORD +51 -0
  50. nextrec-0.1.1.dist-info/WHEEL +4 -0
  51. nextrec-0.1.1.dist-info/licenses/LICENSE +21 -0
@@ -0,0 +1,87 @@
1
+ """
2
+ Feature definitions
3
+
4
+ Date: create on 27/10/2025
5
+ Author:
6
+ Yang Zhou,zyaztec@gmail.com
7
+ """
8
+
9
+ from typing import Optional
10
+ from nextrec.utils import get_auto_embedding_dim
11
+
12
+ class BaseFeature(object):
13
+ def __repr__(self):
14
+ params = {
15
+ k: v
16
+ for k, v in self.__dict__.items()
17
+ if not k.startswith("_")
18
+ }
19
+ param_str = ", ".join(f"{k}={v!r}" for k, v in params.items())
20
+ return f"{self.__class__.__name__}({param_str})"
21
+
22
+ class SequenceFeature(BaseFeature):
23
+ def __init__(
24
+ self,
25
+ name: str,
26
+ vocab_size: int,
27
+ max_len: int = 20,
28
+ embedding_name: str = '',
29
+ embedding_dim: Optional[int] = 4,
30
+ combiner: str = "mean",
31
+ padding_idx: Optional[int] = None,
32
+ init_type: str='normal',
33
+ init_params: dict|None = None,
34
+ l1_reg: float = 0.0,
35
+ l2_reg: float = 1e-5,
36
+ trainable: bool = True,
37
+ ):
38
+
39
+ self.name = name
40
+ self.vocab_size = vocab_size
41
+ self.max_len = max_len
42
+ self.embedding_name = embedding_name or name
43
+ self.embedding_dim = embedding_dim or get_auto_embedding_dim(vocab_size)
44
+
45
+ self.init_type = init_type
46
+ self.init_params = init_params or {}
47
+ self.combiner = combiner
48
+ self.padding_idx = padding_idx
49
+ self.l1_reg = l1_reg
50
+ self.l2_reg = l2_reg
51
+ self.trainable = trainable
52
+
53
+ class SparseFeature(BaseFeature):
54
+ def __init__(self,
55
+ name: str,
56
+ vocab_size: int,
57
+ embedding_name: str = '',
58
+ embedding_dim: int = 4,
59
+ padding_idx: int | None = None,
60
+ init_type: str='normal',
61
+ init_params: dict|None = None,
62
+ l1_reg: float = 0.0,
63
+ l2_reg: float = 1e-5,
64
+ trainable: bool = True):
65
+
66
+ self.name = name
67
+ self.vocab_size = vocab_size
68
+ self.embedding_name = embedding_name or name
69
+ self.embedding_dim = embedding_dim or get_auto_embedding_dim(vocab_size)
70
+
71
+ self.init_type = init_type
72
+ self.init_params = init_params or {}
73
+ self.padding_idx = padding_idx
74
+ self.l1_reg = l1_reg
75
+ self.l2_reg = l2_reg
76
+ self.trainable = trainable
77
+
78
+ class DenseFeature(BaseFeature):
79
+ def __init__(self,
80
+ name: str,
81
+ embedding_dim: int = 1):
82
+
83
+ self.name = name
84
+ self.embedding_dim = embedding_dim
85
+
86
+
87
+