@genai-fi/nanogpt 0.19.1 → 0.20.0

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 (482) hide show
  1. package/package.json +9 -10
  2. package/dist/Generator.d.ts +0 -82
  3. package/dist/Generator.js +0 -11941
  4. package/dist/RealDiv-CGwv0liw.js +0 -365
  5. package/dist/Reshape-BW__R4mZ.js +0 -79
  6. package/dist/Reshape-CPBkTIH2.js +0 -14
  7. package/dist/TeachableLLM.d.ts +0 -70
  8. package/dist/TeachableLLM.js +0 -273
  9. package/dist/Trainer.d.ts +0 -43
  10. package/dist/Trainer.js +0 -244
  11. package/dist/_commonjsHelpers-ByX85dGu.js +0 -33
  12. package/dist/axis_util-GTVlo58H.js +0 -55
  13. package/dist/backend.d.ts +0 -2
  14. package/dist/backend.js +0 -13
  15. package/dist/backend_util-GaFarB78.js +0 -425
  16. package/dist/backend_webgpu-BqASlsbV.js +0 -545
  17. package/dist/binary_op_util-pKXltfxI.js +0 -192
  18. package/dist/broadcast_to-eS93CCN_.js +0 -28
  19. package/dist/checks/appendCache.d.ts +0 -1
  20. package/dist/checks/appendCache.js +0 -22
  21. package/dist/checks/attentionMask.d.ts +0 -1
  22. package/dist/checks/attentionMask.js +0 -37
  23. package/dist/checks/check.d.ts +0 -9
  24. package/dist/checks/check.js +0 -20
  25. package/dist/checks/gelu.d.ts +0 -1
  26. package/dist/checks/gelu.js +0 -18
  27. package/dist/checks/index.d.ts +0 -26
  28. package/dist/checks/index.js +0 -28
  29. package/dist/checks/matMulGelu.d.ts +0 -1
  30. package/dist/checks/matMulGelu.js +0 -28
  31. package/dist/checks/normRMS.d.ts +0 -1
  32. package/dist/checks/normRMS.js +0 -16
  33. package/dist/checks/normRMSGrad.d.ts +0 -1
  34. package/dist/checks/normRMSGrad.js +0 -12
  35. package/dist/checks/packUnpack.d.ts +0 -1
  36. package/dist/checks/packUnpack.js +0 -18
  37. package/dist/checks/qkv.d.ts +0 -1
  38. package/dist/checks/qkv.js +0 -34
  39. package/dist/checks/rope.d.ts +0 -1
  40. package/dist/checks/rope.js +0 -36
  41. package/dist/checks/weights.d.ts +0 -14
  42. package/dist/checks/weights.js +0 -31
  43. package/dist/clip_by_value-DDA7rrcT.js +0 -12
  44. package/dist/complex-DI35Q-gW.js +0 -11
  45. package/dist/complex_util-Yc1A_gV1.js +0 -55
  46. package/dist/concat-CAQpCret.js +0 -17
  47. package/dist/concat_util-D18dJ4fD.js +0 -22
  48. package/dist/data/docx.d.ts +0 -2
  49. package/dist/data/docx.js +0 -15
  50. package/dist/data/parquet.d.ts +0 -2
  51. package/dist/data/parquet.js +0 -17
  52. package/dist/data/pdf.d.ts +0 -2
  53. package/dist/data/pdf.js +0 -14
  54. package/dist/data/textLoader.d.ts +0 -7
  55. package/dist/data/textLoader.js +0 -118
  56. package/dist/dataset-CGGp1z9P.js +0 -1124
  57. package/dist/dropout_util--NxWuYg2.js +0 -27
  58. package/dist/expand_dims-Bkd1YD5x.js +0 -11
  59. package/dist/exports_initializers-CYzKLjN7.js +0 -7
  60. package/dist/floor-BQtb-Azg.js +0 -9
  61. package/dist/gather-qIqEqaGn.js +0 -9
  62. package/dist/gelu-B220X1Go.js +0 -26
  63. package/dist/gpgpu_math-BwvV12df.js +0 -2022
  64. package/dist/index-CUXkjxiT.js +0 -3516
  65. package/dist/index-CieiGp4Y.js +0 -349
  66. package/dist/index-CjOWnMXP.js +0 -7308
  67. package/dist/index-Cp39cXWe.js +0 -1016
  68. package/dist/index-D5v913EJ.js +0 -4
  69. package/dist/index-DmeWGGmS.js +0 -1074
  70. package/dist/index-DvYrXKkX.js +0 -113
  71. package/dist/index-Ksja3su6.js +0 -151
  72. package/dist/index-xuotMAFm.js +0 -118
  73. package/dist/inference/types.d.ts +0 -16
  74. package/dist/inference/types.js +0 -1
  75. package/dist/jszip.min-BZhlzntC.js +0 -2313
  76. package/dist/kernel_funcs_utils-pq0CK9co.js +0 -306
  77. package/dist/layers/BaseLayer.d.ts +0 -44
  78. package/dist/layers/BaseLayer.js +0 -74
  79. package/dist/layers/CausalSelfAttention.d.ts +0 -39
  80. package/dist/layers/CausalSelfAttention.js +0 -86
  81. package/dist/layers/LoRA.d.ts +0 -14
  82. package/dist/layers/LoRA.js +0 -58
  83. package/dist/layers/MLP.d.ts +0 -17
  84. package/dist/layers/MLP.js +0 -44
  85. package/dist/layers/PositionEmbedding.d.ts +0 -8
  86. package/dist/layers/PositionEmbedding.js +0 -31
  87. package/dist/layers/RMSNorm.d.ts +0 -12
  88. package/dist/layers/RMSNorm.js +0 -22
  89. package/dist/layers/RoPECache.d.ts +0 -18
  90. package/dist/layers/RoPECache.js +0 -50
  91. package/dist/layers/TiedEmbedding.d.ts +0 -13
  92. package/dist/layers/TiedEmbedding.js +0 -36
  93. package/dist/layers/TransformerBlock.d.ts +0 -27
  94. package/dist/layers/TransformerBlock.js +0 -40
  95. package/dist/layers/WeightStore.d.ts +0 -20
  96. package/dist/layers/WeightStore.js +0 -76
  97. package/dist/loader/load.d.ts +0 -6
  98. package/dist/loader/load.js +0 -68
  99. package/dist/loader/loadHF.d.ts +0 -8
  100. package/dist/loader/loadHF.js +0 -22
  101. package/dist/loader/loadTransformers.d.ts +0 -4
  102. package/dist/loader/loadTransformers.js +0 -44
  103. package/dist/loader/loadZipMeta.d.ts +0 -3
  104. package/dist/loader/loadZipMeta.js +0 -16
  105. package/dist/loader/newZipLoad.d.ts +0 -3
  106. package/dist/loader/newZipLoad.js +0 -31
  107. package/dist/loader/oldZipLoad.d.ts +0 -9
  108. package/dist/loader/oldZipLoad.js +0 -80
  109. package/dist/loader/save.d.ts +0 -16
  110. package/dist/loader/save.js +0 -90
  111. package/dist/loader/types.d.ts +0 -67
  112. package/dist/loader/types.js +0 -1
  113. package/dist/main.d.ts +0 -50
  114. package/dist/main.js +0 -109
  115. package/dist/matMul16-BcVC_E62.js +0 -80
  116. package/dist/matMulGelu-JNLZqKQp.js +0 -163
  117. package/dist/mat_mul-DhG0Newp.js +0 -11
  118. package/dist/mod-CSdCpRjf.js +0 -11
  119. package/dist/models/NanoGPTV1.d.ts +0 -16
  120. package/dist/models/NanoGPTV1.js +0 -99
  121. package/dist/models/NanoGPTV2.d.ts +0 -16
  122. package/dist/models/NanoGPTV2.js +0 -90
  123. package/dist/models/config.d.ts +0 -27
  124. package/dist/models/config.js +0 -50
  125. package/dist/models/factory.d.ts +0 -3
  126. package/dist/models/factory.js +0 -16
  127. package/dist/models/model.d.ts +0 -44
  128. package/dist/models/model.js +0 -134
  129. package/dist/non_max_suppression_impl-B2W7YjZB.js +0 -102
  130. package/dist/not_equal-hurPF26l.js +0 -64
  131. package/dist/ones-BytntneX.js +0 -14
  132. package/dist/ops/adamAdjust.d.ts +0 -2
  133. package/dist/ops/adamAdjust.js +0 -9
  134. package/dist/ops/adamMoments.d.ts +0 -2
  135. package/dist/ops/adamMoments.js +0 -9
  136. package/dist/ops/add16.d.ts +0 -2
  137. package/dist/ops/add16.js +0 -9
  138. package/dist/ops/appendCache.d.ts +0 -2
  139. package/dist/ops/appendCache.js +0 -22
  140. package/dist/ops/attentionMask.d.ts +0 -2
  141. package/dist/ops/attentionMask.js +0 -10
  142. package/dist/ops/concat16.d.ts +0 -2
  143. package/dist/ops/concat16.js +0 -9
  144. package/dist/ops/cpu/adamAdjust.d.ts +0 -1
  145. package/dist/ops/cpu/adamAdjust.js +0 -18
  146. package/dist/ops/cpu/adamMoments.d.ts +0 -1
  147. package/dist/ops/cpu/adamMoments.js +0 -16
  148. package/dist/ops/cpu/appendCache.d.ts +0 -1
  149. package/dist/ops/cpu/appendCache.js +0 -23
  150. package/dist/ops/cpu/attentionMask.d.ts +0 -1
  151. package/dist/ops/cpu/attentionMask.js +0 -22
  152. package/dist/ops/cpu/fusedSoftmax.d.ts +0 -9
  153. package/dist/ops/cpu/fusedSoftmax.js +0 -29
  154. package/dist/ops/cpu/gatherSub.d.ts +0 -1
  155. package/dist/ops/cpu/gatherSub.js +0 -18
  156. package/dist/ops/cpu/gelu.d.ts +0 -1
  157. package/dist/ops/cpu/gelu.js +0 -40
  158. package/dist/ops/cpu/matMul16.d.ts +0 -1
  159. package/dist/ops/cpu/matMul16.js +0 -15
  160. package/dist/ops/cpu/matMulGelu.d.ts +0 -1
  161. package/dist/ops/cpu/matMulGelu.js +0 -53
  162. package/dist/ops/cpu/matMulMul.d.ts +0 -1
  163. package/dist/ops/cpu/matMulMul.js +0 -23
  164. package/dist/ops/cpu/mulDropout.d.ts +0 -1
  165. package/dist/ops/cpu/mulDropout.js +0 -23
  166. package/dist/ops/cpu/normRMS.d.ts +0 -1
  167. package/dist/ops/cpu/normRMS.js +0 -39
  168. package/dist/ops/cpu/qkv.d.ts +0 -5
  169. package/dist/ops/cpu/qkv.js +0 -41
  170. package/dist/ops/cpu/rope.d.ts +0 -6
  171. package/dist/ops/cpu/rope.js +0 -38
  172. package/dist/ops/cpu/scatterSub.d.ts +0 -1
  173. package/dist/ops/cpu/scatterSub.js +0 -23
  174. package/dist/ops/dot16.d.ts +0 -2
  175. package/dist/ops/dot16.js +0 -42
  176. package/dist/ops/dropout.d.ts +0 -2
  177. package/dist/ops/dropout.js +0 -14
  178. package/dist/ops/dropout16.d.ts +0 -2
  179. package/dist/ops/dropout16.js +0 -25
  180. package/dist/ops/gatherSub.d.ts +0 -2
  181. package/dist/ops/gatherSub.js +0 -9
  182. package/dist/ops/gelu.d.ts +0 -3
  183. package/dist/ops/gelu.js +0 -8
  184. package/dist/ops/globalNorm.d.ts +0 -2
  185. package/dist/ops/globalNorm.js +0 -13
  186. package/dist/ops/grads/add16.d.ts +0 -1
  187. package/dist/ops/grads/add16.js +0 -26
  188. package/dist/ops/grads/attentionMask.d.ts +0 -1
  189. package/dist/ops/grads/attentionMask.js +0 -21
  190. package/dist/ops/grads/dropout16.d.ts +0 -1
  191. package/dist/ops/grads/dropout16.js +0 -2
  192. package/dist/ops/grads/gelu.d.ts +0 -2
  193. package/dist/ops/grads/gelu.js +0 -5
  194. package/dist/ops/grads/matMul16.d.ts +0 -2
  195. package/dist/ops/grads/matMul16.js +0 -9
  196. package/dist/ops/grads/matMulGelu.d.ts +0 -1
  197. package/dist/ops/grads/matMulGelu.js +0 -17
  198. package/dist/ops/grads/mul16.d.ts +0 -1
  199. package/dist/ops/grads/mul16.js +0 -4
  200. package/dist/ops/grads/normRMS.d.ts +0 -3
  201. package/dist/ops/grads/normRMS.js +0 -33
  202. package/dist/ops/grads/pack16.d.ts +0 -2
  203. package/dist/ops/grads/pack16.js +0 -6
  204. package/dist/ops/grads/qkv.d.ts +0 -3
  205. package/dist/ops/grads/qkv.js +0 -34
  206. package/dist/ops/grads/rope.d.ts +0 -2
  207. package/dist/ops/grads/rope.js +0 -5
  208. package/dist/ops/grads/softmax16.d.ts +0 -2
  209. package/dist/ops/grads/softmax16.js +0 -25
  210. package/dist/ops/grads/unpack16.d.ts +0 -2
  211. package/dist/ops/grads/unpack16.js +0 -5
  212. package/dist/ops/grads/utils.d.ts +0 -4
  213. package/dist/ops/grads/utils.js +0 -14
  214. package/dist/ops/log.d.ts +0 -0
  215. package/dist/ops/log.js +0 -1
  216. package/dist/ops/matMul16.d.ts +0 -15
  217. package/dist/ops/matMul16.js +0 -13
  218. package/dist/ops/matMulGelu.d.ts +0 -3
  219. package/dist/ops/matMulGelu.js +0 -14
  220. package/dist/ops/matMulMul.d.ts +0 -2
  221. package/dist/ops/matMulMul.js +0 -9
  222. package/dist/ops/mul16.d.ts +0 -2
  223. package/dist/ops/mul16.js +0 -39
  224. package/dist/ops/mulDrop.d.ts +0 -2
  225. package/dist/ops/mulDrop.js +0 -9
  226. package/dist/ops/normRMS.d.ts +0 -2
  227. package/dist/ops/normRMS.js +0 -19
  228. package/dist/ops/pack16.d.ts +0 -2
  229. package/dist/ops/pack16.js +0 -5
  230. package/dist/ops/qkv.d.ts +0 -2
  231. package/dist/ops/qkv.js +0 -10
  232. package/dist/ops/reshape16.d.ts +0 -2
  233. package/dist/ops/reshape16.js +0 -41
  234. package/dist/ops/rope.d.ts +0 -3
  235. package/dist/ops/rope.js +0 -7
  236. package/dist/ops/scatterSub.d.ts +0 -2
  237. package/dist/ops/scatterSub.js +0 -9
  238. package/dist/ops/slice16.d.ts +0 -2
  239. package/dist/ops/slice16.js +0 -9
  240. package/dist/ops/softmax16.d.ts +0 -2
  241. package/dist/ops/softmax16.js +0 -9
  242. package/dist/ops/sub16.d.ts +0 -2
  243. package/dist/ops/sub16.js +0 -8
  244. package/dist/ops/sum16.d.ts +0 -2
  245. package/dist/ops/sum16.js +0 -13
  246. package/dist/ops/transpose16.d.ts +0 -3
  247. package/dist/ops/transpose16.js +0 -40
  248. package/dist/ops/unpack16.d.ts +0 -2
  249. package/dist/ops/unpack16.js +0 -6
  250. package/dist/ops/webgl/adamAdjust.d.ts +0 -1
  251. package/dist/ops/webgl/adamAdjust.js +0 -49
  252. package/dist/ops/webgl/adamMoments.d.ts +0 -1
  253. package/dist/ops/webgl/adamMoments.js +0 -40
  254. package/dist/ops/webgl/appendCache.d.ts +0 -1
  255. package/dist/ops/webgl/appendCache.js +0 -44
  256. package/dist/ops/webgl/attentionMask.d.ts +0 -1
  257. package/dist/ops/webgl/attentionMask.js +0 -45
  258. package/dist/ops/webgl/dropout16.d.ts +0 -1
  259. package/dist/ops/webgl/dropout16.js +0 -11
  260. package/dist/ops/webgl/fusedSoftmax.d.ts +0 -11
  261. package/dist/ops/webgl/fusedSoftmax.js +0 -80
  262. package/dist/ops/webgl/gatherSub.d.ts +0 -1
  263. package/dist/ops/webgl/gatherSub.js +0 -27
  264. package/dist/ops/webgl/gelu.d.ts +0 -2
  265. package/dist/ops/webgl/gelu.js +0 -50
  266. package/dist/ops/webgl/log.d.ts +0 -17
  267. package/dist/ops/webgl/log.js +0 -23
  268. package/dist/ops/webgl/matMul16.d.ts +0 -1
  269. package/dist/ops/webgl/matMul16.js +0 -45
  270. package/dist/ops/webgl/matMulGelu.d.ts +0 -21
  271. package/dist/ops/webgl/matMulGelu.js +0 -9
  272. package/dist/ops/webgl/matMulMul.d.ts +0 -14
  273. package/dist/ops/webgl/matMulMul.js +0 -28
  274. package/dist/ops/webgl/mulDropout.d.ts +0 -1
  275. package/dist/ops/webgl/mulDropout.js +0 -41
  276. package/dist/ops/webgl/normRMS.d.ts +0 -1
  277. package/dist/ops/webgl/normRMS.js +0 -93
  278. package/dist/ops/webgl/qkv.d.ts +0 -1
  279. package/dist/ops/webgl/qkv.js +0 -46
  280. package/dist/ops/webgl/rope.d.ts +0 -1
  281. package/dist/ops/webgl/rope.js +0 -56
  282. package/dist/ops/webgl/scatterSub.d.ts +0 -1
  283. package/dist/ops/webgl/scatterSub.js +0 -27
  284. package/dist/ops/webgpu/adamAdjust.d.ts +0 -1
  285. package/dist/ops/webgpu/adamAdjust.js +0 -57
  286. package/dist/ops/webgpu/adamMoments.d.ts +0 -1
  287. package/dist/ops/webgpu/adamMoments.js +0 -60
  288. package/dist/ops/webgpu/add16.d.ts +0 -1
  289. package/dist/ops/webgpu/add16.js +0 -13
  290. package/dist/ops/webgpu/appendCache.d.ts +0 -1
  291. package/dist/ops/webgpu/appendCache.js +0 -105
  292. package/dist/ops/webgpu/attentionMask.d.ts +0 -1
  293. package/dist/ops/webgpu/attentionMask.js +0 -26
  294. package/dist/ops/webgpu/attentionMask32_program.d.ts +0 -19
  295. package/dist/ops/webgpu/attentionMask32_program.js +0 -54
  296. package/dist/ops/webgpu/clipScale.d.ts +0 -1
  297. package/dist/ops/webgpu/clipScale.js +0 -58
  298. package/dist/ops/webgpu/concat16.d.ts +0 -19
  299. package/dist/ops/webgpu/concat16.js +0 -126
  300. package/dist/ops/webgpu/dropout16.d.ts +0 -1
  301. package/dist/ops/webgpu/dropout16.js +0 -51
  302. package/dist/ops/webgpu/gatherSub.d.ts +0 -1
  303. package/dist/ops/webgpu/gatherSub.js +0 -39
  304. package/dist/ops/webgpu/gelu.d.ts +0 -14
  305. package/dist/ops/webgpu/gelu.js +0 -141
  306. package/dist/ops/webgpu/index.d.ts +0 -0
  307. package/dist/ops/webgpu/index.js +0 -26
  308. package/dist/ops/webgpu/matMul16.d.ts +0 -1
  309. package/dist/ops/webgpu/matMul16.js +0 -65
  310. package/dist/ops/webgpu/matMul16_program.d.ts +0 -42
  311. package/dist/ops/webgpu/matMul16_program.js +0 -343
  312. package/dist/ops/webgpu/mul16.d.ts +0 -1
  313. package/dist/ops/webgpu/mul16.js +0 -13
  314. package/dist/ops/webgpu/norm2.d.ts +0 -1
  315. package/dist/ops/webgpu/norm2.js +0 -76
  316. package/dist/ops/webgpu/normRMS.d.ts +0 -1
  317. package/dist/ops/webgpu/normRMS.js +0 -34
  318. package/dist/ops/webgpu/normRMS16_program.d.ts +0 -10
  319. package/dist/ops/webgpu/normRMS16_program.js +0 -25
  320. package/dist/ops/webgpu/normRMS32_program.d.ts +0 -10
  321. package/dist/ops/webgpu/normRMS32_program.js +0 -25
  322. package/dist/ops/webgpu/normRMSGrad.d.ts +0 -1
  323. package/dist/ops/webgpu/normRMSGrad.js +0 -284
  324. package/dist/ops/webgpu/pack16.d.ts +0 -1
  325. package/dist/ops/webgpu/pack16.js +0 -18
  326. package/dist/ops/webgpu/pack16_program.d.ts +0 -19
  327. package/dist/ops/webgpu/pack16_program.js +0 -92
  328. package/dist/ops/webgpu/qkv.d.ts +0 -1
  329. package/dist/ops/webgpu/qkv.js +0 -24
  330. package/dist/ops/webgpu/rope.d.ts +0 -1
  331. package/dist/ops/webgpu/rope.js +0 -135
  332. package/dist/ops/webgpu/scatterSub.d.ts +0 -1
  333. package/dist/ops/webgpu/scatterSub.js +0 -40
  334. package/dist/ops/webgpu/slice16.d.ts +0 -7
  335. package/dist/ops/webgpu/slice16.js +0 -69
  336. package/dist/ops/webgpu/softmax16.d.ts +0 -17
  337. package/dist/ops/webgpu/softmax16.js +0 -21
  338. package/dist/ops/webgpu/softmax16_program.d.ts +0 -13
  339. package/dist/ops/webgpu/softmax16_program.js +0 -73
  340. package/dist/ops/webgpu/softmax16_subgroup_program.d.ts +0 -17
  341. package/dist/ops/webgpu/softmax16_subgroup_program.js +0 -75
  342. package/dist/ops/webgpu/softmax16grad.d.ts +0 -1
  343. package/dist/ops/webgpu/softmax16grad.js +0 -37
  344. package/dist/ops/webgpu/sub16.d.ts +0 -1
  345. package/dist/ops/webgpu/sub16.js +0 -13
  346. package/dist/ops/webgpu/sum16.d.ts +0 -1
  347. package/dist/ops/webgpu/sum16.js +0 -38
  348. package/dist/ops/webgpu/transpose16.d.ts +0 -1
  349. package/dist/ops/webgpu/transpose16.js +0 -34
  350. package/dist/ops/webgpu/transpose16_program.d.ts +0 -16
  351. package/dist/ops/webgpu/transpose16_program.js +0 -50
  352. package/dist/ops/webgpu/transpose16_shared_program.d.ts +0 -15
  353. package/dist/ops/webgpu/transpose16_shared_program.js +0 -70
  354. package/dist/ops/webgpu/unpack16.d.ts +0 -1
  355. package/dist/ops/webgpu/unpack16.js +0 -48
  356. package/dist/ops/webgpu/utils/binary_op.d.ts +0 -35
  357. package/dist/ops/webgpu/utils/binary_op.js +0 -139
  358. package/dist/ops/webgpu/utils/deviceInfo.d.ts +0 -7
  359. package/dist/ops/webgpu/utils/deviceInfo.js +0 -11
  360. package/dist/ops/webgpu/utils/reductions.d.ts +0 -43
  361. package/dist/ops/webgpu/utils/reductions.js +0 -275
  362. package/dist/ops-CsXeTq1P.js +0 -476
  363. package/dist/pack16-bqltoUlR.js +0 -39
  364. package/dist/papaparse.min-C0cScC2i.js +0 -418
  365. package/dist/parquet-Bqjmp2vo.js +0 -44231
  366. package/dist/patches/webgpu_backend.d.ts +0 -18
  367. package/dist/patches/webgpu_backend.js +0 -56
  368. package/dist/patches/webgpu_base.d.ts +0 -21
  369. package/dist/patches/webgpu_base.js +0 -34
  370. package/dist/patches/webgpu_program.d.ts +0 -36
  371. package/dist/patches/webgpu_program.js +0 -400
  372. package/dist/pdf-NIhmP3sq.js +0 -19477
  373. package/dist/rand_util-CZ7yLoUm.js +0 -50
  374. package/dist/random_normal-IBRrha8a.js +0 -14
  375. package/dist/random_width-DN5ZtQkM.js +0 -9796
  376. package/dist/range-C-CjF-LI.js +0 -10
  377. package/dist/relu-J_X6MUzx.js +0 -9
  378. package/dist/reshape-BDOuCSNW.js +0 -9
  379. package/dist/resize_nearest_neighbor-BojqlfRe.js +0 -150
  380. package/dist/rope-DcrZM_e6.js +0 -24
  381. package/dist/scatter_nd_util-ByNJaL6I.js +0 -46
  382. package/dist/segment_util-Dasb2Zaf.js +0 -43
  383. package/dist/selu_util-BLhIqRkw.js +0 -44
  384. package/dist/shared-3agzAqQ_.js +0 -53
  385. package/dist/shared-CagdqkLh.js +0 -2143
  386. package/dist/slice-BzS11Qh0.js +0 -12
  387. package/dist/slice_util-CC35pLmT.js +0 -153
  388. package/dist/softmax-D4q1LJN7.js +0 -12
  389. package/dist/split-C2Sj255c.js +0 -9
  390. package/dist/squeeze-ho4wLUek.js +0 -10
  391. package/dist/stack-DudVrtmG.js +0 -11
  392. package/dist/step-BTxPtq1r.js +0 -261
  393. package/dist/sum-BpiwSWvg.js +0 -11
  394. package/dist/tensor-BWFldCso.js +0 -8
  395. package/dist/tensor1d-LMGMIUlr.js +0 -11
  396. package/dist/tensor2d-BnXMKScO.js +0 -14
  397. package/dist/tensor4d-C6UCG_u8.js +0 -14
  398. package/dist/tfjs_backend-BGnG-ppu.js +0 -654
  399. package/dist/tile-CFy-xTO6.js +0 -11
  400. package/dist/tokeniser/BaseTokeniser.d.ts +0 -33
  401. package/dist/tokeniser/BaseTokeniser.js +0 -124
  402. package/dist/tokeniser/CharTokeniser.d.ts +0 -24
  403. package/dist/tokeniser/CharTokeniser.js +0 -107
  404. package/dist/tokeniser/bpe.d.ts +0 -28
  405. package/dist/tokeniser/bpe.js +0 -173
  406. package/dist/tokeniser/messages.d.ts +0 -61
  407. package/dist/tokeniser/messages.js +0 -1
  408. package/dist/tokeniser/type.d.ts +0 -34
  409. package/dist/tokeniser/type.js +0 -1
  410. package/dist/training/AdamW.d.ts +0 -36
  411. package/dist/training/AdamW.js +0 -138
  412. package/dist/training/BasicTrainer.d.ts +0 -63
  413. package/dist/training/BasicTrainer.js +0 -265
  414. package/dist/training/DatasetBuilder.d.ts +0 -26
  415. package/dist/training/DatasetBuilder.js +0 -86
  416. package/dist/training/Evaluator.d.ts +0 -19
  417. package/dist/training/Evaluator.js +0 -39
  418. package/dist/training/LRScheduler.d.ts +0 -12
  419. package/dist/training/LRScheduler.js +0 -34
  420. package/dist/training/PreTrainer.d.ts +0 -11
  421. package/dist/training/PreTrainer.js +0 -20
  422. package/dist/training/SFTTrainer.d.ts +0 -12
  423. package/dist/training/SFTTrainer.js +0 -22
  424. package/dist/training/loss.d.ts +0 -3
  425. package/dist/training/loss.js +0 -24
  426. package/dist/training/orthoGrad.d.ts +0 -2
  427. package/dist/training/orthoGrad.js +0 -10
  428. package/dist/training/sparseCrossEntropy.d.ts +0 -7
  429. package/dist/training/sparseCrossEntropy.js +0 -69
  430. package/dist/training/tasks/ConversationTask.d.ts +0 -18
  431. package/dist/training/tasks/ConversationTask.js +0 -40
  432. package/dist/training/tasks/PretrainingTask.d.ts +0 -17
  433. package/dist/training/tasks/PretrainingTask.js +0 -47
  434. package/dist/training/tasks/StartSentenceTask.d.ts +0 -18
  435. package/dist/training/tasks/StartSentenceTask.js +0 -49
  436. package/dist/training/tasks/Task.d.ts +0 -22
  437. package/dist/training/tasks/Task.js +0 -68
  438. package/dist/training/tasks/splitter.d.ts +0 -5
  439. package/dist/training/tasks/splitter.js +0 -21
  440. package/dist/training/types.d.ts +0 -78
  441. package/dist/training/types.js +0 -1
  442. package/dist/training/validation.d.ts +0 -17
  443. package/dist/training/validation.js +0 -84
  444. package/dist/transpose-9kRxIXWR.js +0 -36
  445. package/dist/unsorted_segment_sum-DJvk5xnh.js +0 -277
  446. package/dist/utilities/arrayClose.d.ts +0 -1
  447. package/dist/utilities/arrayClose.js +0 -20
  448. package/dist/utilities/datasetID.d.ts +0 -2
  449. package/dist/utilities/datasetID.js +0 -21
  450. package/dist/utilities/dummy.d.ts +0 -9
  451. package/dist/utilities/dummy.js +0 -43
  452. package/dist/utilities/multinomialCPU.d.ts +0 -2
  453. package/dist/utilities/multinomialCPU.js +0 -13
  454. package/dist/utilities/naming.d.ts +0 -4
  455. package/dist/utilities/naming.js +0 -1
  456. package/dist/utilities/packed.d.ts +0 -4
  457. package/dist/utilities/packed.js +0 -15
  458. package/dist/utilities/parameters.d.ts +0 -11
  459. package/dist/utilities/parameters.js +0 -57
  460. package/dist/utilities/performance.d.ts +0 -2
  461. package/dist/utilities/performance.js +0 -16
  462. package/dist/utilities/profile.d.ts +0 -17
  463. package/dist/utilities/profile.js +0 -38
  464. package/dist/utilities/safetensors.d.ts +0 -3
  465. package/dist/utilities/safetensors.js +0 -83
  466. package/dist/utilities/sentences.d.ts +0 -5
  467. package/dist/utilities/sentences.js +0 -41
  468. package/dist/utilities/tokenParse.d.ts +0 -1
  469. package/dist/utilities/tokenParse.js +0 -21
  470. package/dist/utilities/topP.d.ts +0 -1
  471. package/dist/utilities/topP.js +0 -13
  472. package/dist/utilities/waitForModel.d.ts +0 -2
  473. package/dist/utilities/waitForModel.js +0 -12
  474. package/dist/utilities/weights.d.ts +0 -12
  475. package/dist/utilities/weights.js +0 -45
  476. package/dist/utilities/yielder.d.ts +0 -1
  477. package/dist/utilities/yielder.js +0 -7
  478. package/dist/variable-Ck482e3n.js +0 -7
  479. package/dist/webgpu_program-B4HmApL1.js +0 -525
  480. package/dist/webgpu_util-DYlGSwOJ.js +0 -64
  481. package/dist/zeros-DvZpK8s6.js +0 -13
  482. package/dist/zeros_like-CWjDdwr-.js +0 -721
@@ -1,11 +0,0 @@
1
- import { default as Model, ModelForwardAttributes } from '../models/model';
2
- import { default as BasicTrainer } from './BasicTrainer';
3
- import { ITokeniser } from '../tokeniser/type';
4
- import { DatasetBuilder } from './DatasetBuilder';
5
- import { AdamWOptimizer } from './AdamW';
6
- import { AdamWOptimizerConfig } from './types';
7
- export default class PreTrainer extends BasicTrainer {
8
- tokenizer: ITokeniser;
9
- datasetBuilder: DatasetBuilder;
10
- constructor(model: Model<ModelForwardAttributes>, tokenizer: ITokeniser, optConfig?: Partial<AdamWOptimizerConfig>, optimizer?: AdamWOptimizer);
11
- }
@@ -1,20 +0,0 @@
1
- import r from "./BasicTrainer.js";
2
- import { DatasetBuilder as n } from "./DatasetBuilder.js";
3
- const s = {
4
- decayEpochs: 100,
5
- epochSteps: 1e4,
6
- warmupSteps: 1e3,
7
- minLearningRate: 3e-5,
8
- weightDecay: 0.1,
9
- learningRate: 3e-4
10
- // clipNorm: 1.0,
11
- };
12
- class m extends r {
13
- constructor(i, e, t, a) {
14
- super(i, e, { ...s, ...t }, a), this.tokenizer = e, this.optimizerConfig.minLearningRate = t?.minLearningRate ?? this.optimizerConfig.learningRate / 20, this.updateOptimizer(), this.datasetBuilder = new n(e, i.config.blockSize);
15
- }
16
- datasetBuilder;
17
- }
18
- export {
19
- m as default
20
- };
@@ -1,12 +0,0 @@
1
- import { default as Model, ModelForwardAttributes } from '../models/model';
2
- import { default as BasicTrainer } from './BasicTrainer';
3
- import { ITokeniser } from '../tokeniser/type';
4
- import { AdamWOptimizer } from './AdamW';
5
- import { AdamWOptimizerConfig } from './types';
6
- import { DatasetBuilder } from './DatasetBuilder';
7
- export default class SFTTrainer extends BasicTrainer {
8
- tokenizer: ITokeniser;
9
- datasetBuilder: DatasetBuilder;
10
- loraName?: string;
11
- constructor(model: Model<ModelForwardAttributes>, tokenizer: ITokeniser, optConfig?: Partial<AdamWOptimizerConfig>, optimizer?: AdamWOptimizer);
12
- }
@@ -1,22 +0,0 @@
1
- import r from "./BasicTrainer.js";
2
- import { DatasetBuilder as s } from "./DatasetBuilder.js";
3
- const n = {
4
- decayEpochs: 100,
5
- epochSteps: 1e4,
6
- warmupSteps: 100,
7
- minLearningRate: 1e-5,
8
- weightDecay: 0.1,
9
- beta2: 0.95,
10
- learningRate: 3e-4
11
- // clipNorm: 1.0,
12
- };
13
- class c extends r {
14
- constructor(t, e, i, a) {
15
- super(t, e, { ...n, ...i }, a), this.tokenizer = e, this.optimizerConfig.minLearningRate = i?.minLearningRate ?? this.optimizerConfig.learningRate / 20, this.updateOptimizer(), this.datasetBuilder = new s(e, t.config.blockSize), this.maskedLoss = !0;
16
- }
17
- datasetBuilder;
18
- loraName;
19
- }
20
- export {
21
- c as default
22
- };
@@ -1,3 +0,0 @@
1
- import { Tensor } from '@tensorflow/tfjs-core';
2
- export declare function calculateLoss(logits: Tensor, targets: Tensor, masked?: boolean, keepBatch?: boolean, labelSmoothing?: number): Tensor;
3
- export declare function calculateAccuracy(logits: Tensor, targets: Tensor): Tensor;
@@ -1,24 +0,0 @@
1
- import { createSoftmaxCrossEntropyWithGrad as n } from "./sparseCrossEntropy.js";
2
- function i(t, s, r, c, o) {
3
- try {
4
- return n(
5
- r,
6
- c,
7
- o && o > 0 ? o : void 0
8
- )(t, s);
9
- } catch (a) {
10
- throw console.error("Error computing loss:", a), new Error(`Loss computation failed: ${a}`);
11
- }
12
- }
13
- function l(t, s) {
14
- try {
15
- const r = t.argMax(-1), c = r.equal(s).cast("float32"), o = c.mean();
16
- return r.dispose(), c.dispose(), o;
17
- } catch (r) {
18
- throw console.error("Error computing accuracy:", r), new Error(`Accuracy computation failed: ${r}`);
19
- }
20
- }
21
- export {
22
- l as calculateAccuracy,
23
- i as calculateLoss
24
- };
@@ -1,2 +0,0 @@
1
- import { Tensor } from '@tensorflow/tfjs-core';
2
- export declare function orthogonalizeGradient(weight: Tensor, gradient: Tensor, epsilon: number): Tensor;
@@ -1,10 +0,0 @@
1
- import { t as d } from "../index-CUXkjxiT.js";
2
- function l(m, t, s) {
3
- return d(() => {
4
- const r = m.reshape([-1]), o = t.reshape([-1]), e = r.mul(r).sum().add(s), c = r.mul(o).sum().div(e), n = o.sub(r.mul(c)), a = o.norm(), u = n.norm().add(s);
5
- return n.mul(a.div(u)).reshape(t.shape);
6
- });
7
- }
8
- export {
9
- l as orthogonalizeGradient
10
- };
@@ -1,7 +0,0 @@
1
- import * as tf from '@tensorflow/tfjs-core';
2
- /**
3
- * Numerically stable sparse cross-entropy with gradient support
4
- * This version handles potential numerical issues better
5
- */
6
- export declare function sparseSoftmaxCrossEntropy(logits: tf.Tensor, labels: tf.Tensor, validMask?: tf.Tensor, keepBatch?: boolean, originalBatchShape?: number[], labelSmoothing?: number): tf.Tensor;
7
- export declare function createSoftmaxCrossEntropyWithGrad(masked?: boolean, keepBatch?: boolean, labelSmoothing?: number): (...args: tf.Tensor[]) => tf.Tensor<tf.Rank>;
@@ -1,69 +0,0 @@
1
- import { gatherSub as $ } from "../ops/gatherSub.js";
2
- import { scatterSub as T } from "../ops/scatterSub.js";
3
- import { t as F, a1 as G, j as A, m as x, i as U, a2 as D, a as j, a3 as q } from "../index-CUXkjxiT.js";
4
- import { m as J, l as K, a as E, n as N, w as O } from "../not_equal-hurPF26l.js";
5
- import { s as m } from "../sum-BpiwSWvg.js";
6
- import { s as Q } from "../softmax-D4q1LJN7.js";
7
- function R(e, l, a, g, v, t = 0) {
8
- return F(() => {
9
- const S = e.shape[e.shape.length - 1], i = v || e.shape.slice(0, -1), f = i.reduce((c, d) => c * d, 1), h = e.shape.length > 2 ? e.reshape([f, S]) : e, y = l.shape.length > 1 ? l.reshape([f]).cast("int32") : l.cast("int32"), u = J(h, -1, !0), o = G(h, u), n = K(o, -1), p = $(n, y, o);
10
- let s;
11
- if (t > 0) {
12
- const c = G(n, E(o, -1));
13
- s = A(x(p, 1 - t), x(c, t));
14
- } else
15
- s = p;
16
- if (a)
17
- if (s = x(s, a), g) {
18
- const c = m(a.reshape(i), -1);
19
- s = U(m(s.reshape(i), -1), c);
20
- } else {
21
- const c = m(a);
22
- s = U(m(s), c);
23
- }
24
- else
25
- g ? s = E(s.reshape(i), -1) : s = E(s);
26
- return s;
27
- });
28
- }
29
- function as(e, l, a = 0) {
30
- return D(
31
- // @ts-expect-error Invalid params
32
- (t, S, i) => {
33
- const f = t.shape[t.shape.length - 1], h = t.shape.slice(0, -1), y = h.reduce((d, r) => d * r, 1), u = t.reshape([y, f]), o = S.reshape([y]).cast("int32");
34
- let n, p = null;
35
- if (e) {
36
- const d = j(65535, "int32"), r = N(o, d);
37
- p = r.cast("float32"), n = O(r, o, q(o)), d.dispose(), r.dispose();
38
- } else
39
- n = o;
40
- const s = R(
41
- u,
42
- n,
43
- p || void 0,
44
- l,
45
- h,
46
- a
47
- );
48
- return i(p ? [u, n, p] : [u, n]), u.dispose(), o.dispose(), { value: s, gradFunc: (d, r) => F(() => {
49
- const C = r[0], z = r[1], b = e ? r[2] : void 0, w = Q(C), H = b ? m(b) : j(C.shape[0], "float32"), I = d.div(H).broadcastTo([C.shape[0]]), M = b && e ? x(I, b) : I;
50
- let L;
51
- if (a > 0) {
52
- const V = a / f, W = G(w, V);
53
- L = T(
54
- W,
55
- z,
56
- x(M, 1 - a)
57
- );
58
- } else
59
- L = T(w, z, M);
60
- const P = q(S);
61
- return [L.reshape(t.shape), P];
62
- }) };
63
- }
64
- );
65
- }
66
- export {
67
- as as createSoftmaxCrossEntropyWithGrad,
68
- R as sparseSoftmaxCrossEntropy
69
- };
@@ -1,18 +0,0 @@
1
- import { Conversation, ITokeniser } from '../../main';
2
- import { Task } from './Task';
3
- export default class ConversationTask extends Task {
4
- private rawConvo;
5
- private shuffledIndices;
6
- private index;
7
- get length(): number;
8
- constructor(conversations: Conversation[][]);
9
- hasMoreConversations(): boolean;
10
- nextConversation(): Conversation[] | null;
11
- nextTokens(tokeniser: ITokeniser): number[] | null;
12
- nextTokens(tokeniser: ITokeniser, masking: boolean): {
13
- tokens: number[];
14
- mask: boolean[];
15
- } | null;
16
- shuffle(): void;
17
- estimateTokens(tokeniser: ITokeniser): Promise<number>;
18
- }
@@ -1,40 +0,0 @@
1
- import { Task as t } from "./Task.js";
2
- import { shuffle as i } from "../DatasetBuilder.js";
3
- class f extends t {
4
- rawConvo;
5
- shuffledIndices = null;
6
- index = 0;
7
- get length() {
8
- return this.rawConvo.length;
9
- }
10
- constructor(n) {
11
- super(), this.rawConvo = n;
12
- }
13
- hasMoreConversations() {
14
- return this.index < this.rawConvo.length;
15
- }
16
- nextConversation() {
17
- if (this.index >= this.rawConvo.length)
18
- return null;
19
- const n = this.rawConvo[this.shuffledIndices ? this.shuffledIndices[this.index] : this.index];
20
- return this.index++, n;
21
- }
22
- nextTokens(n, s) {
23
- const e = this.nextConversation();
24
- return e ? n.encodeConversation(e, !1, s) : null;
25
- }
26
- shuffle() {
27
- if (!this.shuffledIndices) {
28
- this.shuffledIndices = new Uint32Array(this.rawConvo.length);
29
- for (let n = 0; n < this.rawConvo.length; n++)
30
- this.shuffledIndices[n] = n;
31
- }
32
- i(this.shuffledIndices), this.index = 0;
33
- }
34
- async estimateTokens(n) {
35
- return n.encodeConversation(this.rawConvo[0]).length * this.length;
36
- }
37
- }
38
- export {
39
- f as default
40
- };
@@ -1,17 +0,0 @@
1
- import { Conversation, ITokeniser } from '../../main';
2
- import { Task } from './Task';
3
- export default class PretrainingTask extends Task {
4
- private rawText;
5
- private index;
6
- get length(): number;
7
- constructor(texts: string[]);
8
- hasMoreConversations(): boolean;
9
- nextConversation(): Conversation[] | null;
10
- nextTokens(tokeniser: ITokeniser): number[] | null;
11
- nextTokens(tokeniser: ITokeniser, masking: boolean): {
12
- tokens: number[];
13
- mask: boolean[];
14
- } | null;
15
- shuffle(): void;
16
- estimateTokens(tokeniser: ITokeniser): Promise<number>;
17
- }
@@ -1,47 +0,0 @@
1
- import { Task as r } from "./Task.js";
2
- class h extends r {
3
- rawText;
4
- index = 0;
5
- get length() {
6
- return this.rawText.length;
7
- }
8
- constructor(t) {
9
- super(), this.rawText = t;
10
- }
11
- hasMoreConversations() {
12
- return this.index < this.rawText.length;
13
- }
14
- nextConversation() {
15
- if (this.index >= this.rawText.length)
16
- return null;
17
- const t = {
18
- role: "assistant",
19
- content: this.rawText[this.index]
20
- };
21
- return this.index++, [t];
22
- }
23
- nextTokens(t, n) {
24
- if (this.index >= this.rawText.length)
25
- return null;
26
- const e = t.encodeSequence(this.rawText[this.index]);
27
- if (this.index++, n) {
28
- const s = new Array(e.length).fill(!0);
29
- return { tokens: e, mask: s };
30
- }
31
- return e;
32
- }
33
- shuffle() {
34
- this.index = 0;
35
- }
36
- async estimateTokens(t) {
37
- return t.encodeConversation([
38
- {
39
- role: "assistant",
40
- content: this.rawText[0]
41
- }
42
- ]).length * this.length;
43
- }
44
- }
45
- export {
46
- h as default
47
- };
@@ -1,18 +0,0 @@
1
- import { Conversation, ITokeniser } from '../../main';
2
- import { Task } from './Task';
3
- export default class StartSentenceTask extends Task {
4
- private rawText;
5
- private index;
6
- get length(): number;
7
- constructor(texts: string[]);
8
- hasMoreConversations(): boolean;
9
- nextConversation(): Conversation[] | null;
10
- nextTokens(tokeniser: ITokeniser): number[] | null;
11
- nextTokens(tokeniser: ITokeniser, masking: boolean): {
12
- tokens: number[];
13
- mask: boolean[];
14
- } | null;
15
- shuffle(): void;
16
- private conversationFromString;
17
- estimateTokens(tokeniser: ITokeniser): Promise<number>;
18
- }
@@ -1,49 +0,0 @@
1
- import { Task as r } from "./Task.js";
2
- class a extends r {
3
- rawText;
4
- index = 0;
5
- get length() {
6
- return this.rawText.length;
7
- }
8
- constructor(t) {
9
- super(), this.rawText = t;
10
- }
11
- hasMoreConversations() {
12
- return this.index < this.rawText.length;
13
- }
14
- nextConversation() {
15
- if (this.index >= this.rawText.length)
16
- return null;
17
- const t = this.rawText[this.index];
18
- return this.index++, this.conversationFromString(t);
19
- }
20
- nextTokens(t, n) {
21
- const e = this.nextConversation();
22
- return e ? t.encodeConversation(e, !1, n) : null;
23
- }
24
- shuffle() {
25
- this.index = 0;
26
- }
27
- conversationFromString(t) {
28
- const n = t.indexOf(".");
29
- return n === -1 ? [{
30
- role: "assistant",
31
- content: this.rawText[this.index]
32
- }] : [
33
- {
34
- role: "user",
35
- content: t.slice(0, n + 1).trim()
36
- },
37
- {
38
- role: "assistant",
39
- content: t.slice(n + 1).trim()
40
- }
41
- ];
42
- }
43
- async estimateTokens(t) {
44
- return (await t.encodeConversation(this.conversationFromString(this.rawText[0]))).length * this.length;
45
- }
46
- }
47
- export {
48
- a as default
49
- };
@@ -1,22 +0,0 @@
1
- import { Conversation, ITokeniser } from '../../main';
2
- export declare abstract class Task {
3
- abstract get length(): number;
4
- abstract hasMoreConversations(): boolean;
5
- abstract nextConversation(): Conversation[] | null;
6
- abstract nextTokens(tokeniser: ITokeniser): number[] | null;
7
- abstract nextTokens(tokeniser: ITokeniser, masking: boolean): {
8
- tokens: number[];
9
- mask: boolean[];
10
- } | null;
11
- abstract nextTokens(tokeniser: ITokeniser, masking?: boolean): number[] | {
12
- tokens: number[];
13
- mask: boolean[];
14
- } | null;
15
- abstract estimateTokens(tokeniser: ITokeniser): Promise<number>;
16
- abstract shuffle(): void;
17
- }
18
- export declare function tokensFromTasks(tasks: Task[], tokenizer: ITokeniser, cb?: (tokens: number) => void): Promise<Uint16Array>;
19
- export declare function tokensFromTasks(tasks: Task[], tokenizer: ITokeniser, cb?: (tokens: number) => void, masking?: boolean): Promise<{
20
- tokens: Uint16Array;
21
- mask: Uint8Array;
22
- }>;
@@ -1,68 +0,0 @@
1
- import { yieldIfNeeded as k } from "../../utilities/yielder.js";
2
- class w {
3
- }
4
- function m(y, i, u, o, g, n) {
5
- for (const a of y) {
6
- const e = a.nextTokens(u, n ? !0 : void 0);
7
- if (e) {
8
- const f = Array.isArray(e) ? e : e.tokens;
9
- o.total += f.length;
10
- const c = i[i.length - 1], l = n ? n[n.length - 1] : null;
11
- if (o.offset + f.length > c.length) {
12
- const s = c.length - o.offset;
13
- c.set(f.slice(0, s), o.offset);
14
- const t = new Uint16Array(Math.floor(g * 0.1) + 100);
15
- if (t.set(f.slice(s), 0), i.push(t), n && l && !Array.isArray(e)) {
16
- l.set(
17
- e.mask.slice(0, s).map((h) => h ? 1 : 0),
18
- o.offset
19
- );
20
- const r = new Uint8Array(t.length);
21
- r.set(
22
- e.mask.slice(s).map((h) => h ? 1 : 0),
23
- 0
24
- ), n.push(r);
25
- }
26
- o.offset = f.length - s;
27
- } else
28
- c.set(f, o.offset), l && !Array.isArray(e) && l.set(
29
- e.mask.map((s) => s ? 1 : 0),
30
- o.offset
31
- ), o.offset += f.length;
32
- }
33
- }
34
- }
35
- async function p(y, i, u, o) {
36
- const g = Math.min(
37
- (await Promise.all(y.map((t) => t.estimateTokens(i)))).reduce((t, r) => t + r, 0),
38
- i.vocabSize * 1e4
39
- ), n = [new Uint16Array(g)], a = o ? [new Uint8Array(g)] : null, e = {
40
- offset: 0,
41
- total: 0
42
- };
43
- let f = performance.now();
44
- for (; e.offset < g && (m(y, n, i, e, g, a || void 0), !y.every((t) => !t.hasMoreConversations())); )
45
- f = await k(f, u, e.total);
46
- if (n.length === 1)
47
- return a ? { tokens: n[0].subarray(0, e.offset), mask: a[0].subarray(0, e.offset) } : n[0].subarray(0, e.offset);
48
- const c = n.reduce((t, r) => t + r.length, 0) - (n[n.length - 1].length - e.offset), l = new Uint16Array(c);
49
- let s = 0;
50
- for (let t = 0; t < n.length; t++) {
51
- const r = n[t];
52
- t === n.length - 1 ? (l.set(r.subarray(0, e.offset), s), s += e.offset) : (l.set(r, s), s += r.length);
53
- }
54
- if (a) {
55
- const t = new Uint8Array(c);
56
- s = 0;
57
- for (let r = 0; r < a.length; r++) {
58
- const h = a[r];
59
- r === a.length - 1 ? (t.set(h.subarray(0, e.offset), s), s += e.offset) : (t.set(h, s), s += h.length);
60
- }
61
- return { tokens: l, mask: t };
62
- }
63
- return l;
64
- }
65
- export {
66
- w as Task,
67
- p as tokensFromTasks
68
- };
@@ -1,5 +0,0 @@
1
- import { Task } from './Task';
2
- export default function splitValidation(tasks: Task[], validationSplit: number): {
3
- training: Task;
4
- validation: Task;
5
- };
@@ -1,21 +0,0 @@
1
- import s from "./ConversationTask.js";
2
- function f(e, o) {
3
- if (o <= 0 || o >= 1)
4
- throw new Error("validationSplit must be between 0 and 1");
5
- e.forEach((n) => n.shuffle());
6
- const r = [], a = [];
7
- for (const n of e)
8
- for (; n.hasMoreConversations(); ) {
9
- const t = n.nextConversation();
10
- if (!t)
11
- break;
12
- Math.random() < o ? a.push(t) : r.push(t);
13
- }
14
- return {
15
- training: new s(r),
16
- validation: new s(a)
17
- };
18
- }
19
- export {
20
- f as default
21
- };
@@ -1,78 +0,0 @@
1
- import { TensorStatistics } from '../checks/weights';
2
- import { LoRAConfig } from '../models/config';
3
- import { NamedTensorMap, Tensor } from '@tensorflow/tfjs-core';
4
- export interface Metrics {
5
- accuracy?: number;
6
- perplexity?: number;
7
- loss: number;
8
- }
9
- export interface TrainingLogEntry {
10
- trainingMetrics: Metrics;
11
- validationMetrics?: Metrics;
12
- step: number;
13
- time: number;
14
- example?: string;
15
- batchSize: number;
16
- gradientMetrics?: Map<string, TensorStatistics>;
17
- learningRate?: number;
18
- gradientNorm?: number;
19
- weightNorm?: number;
20
- weightStatistics?: Map<string, TensorStatistics>;
21
- memoryUsage?: number;
22
- tokensPerSecond: number;
23
- duration: number;
24
- totalTokens: number;
25
- }
26
- export interface LRSchedulerConfig {
27
- warmupSteps: number;
28
- decayEpochs: number;
29
- minLearningRate: number;
30
- epochSteps: number;
31
- step?: number;
32
- }
33
- export interface AdamWOptimizerConfig extends LRSchedulerConfig {
34
- learningRate: number;
35
- beta1: number;
36
- beta2: number;
37
- accBeta1?: number;
38
- accBeta2?: number;
39
- epsilon?: number;
40
- weightDecay: number;
41
- lossScaling: number;
42
- clipNorm?: number;
43
- orthoGrad?: boolean;
44
- }
45
- export type TrainingMetrics = 'accuracy' | 'perplexity' | 'gradientNorm' | 'gradientStatistics' | 'weightNorm' | 'weightStatistics' | 'memoryUsage' | 'tokensPerSecond' | 'learningRate';
46
- export interface TrainingOptions extends Partial<AdamWOptimizerConfig> {
47
- batchSize: number;
48
- maxEpochs?: number;
49
- logInterval?: number;
50
- prompt?: string;
51
- validationSplit?: number;
52
- gradientCheckpointing?: boolean;
53
- mixedPrecision?: boolean;
54
- trainableWeights?: string[];
55
- loraConfig?: LoRAConfig;
56
- loraName?: string;
57
- sftMode: 'full' | 'lora' | 'last-layer';
58
- maskedLoss?: boolean;
59
- metrics?: TrainingMetrics[];
60
- contextScaling?: number;
61
- labelSmoothing?: number;
62
- dropout?: number;
63
- layerDrop?: number;
64
- debug?: boolean;
65
- onStep?: (log: TrainingLogEntry) => void;
66
- }
67
- export interface TrainingState {
68
- step: number;
69
- lastLoss: number;
70
- totalSteps: number;
71
- losses: number[];
72
- validationLosses: number[];
73
- logStartTime: number;
74
- trainingDuration: number;
75
- gradients?: NamedTensorMap;
76
- gradientNorm?: Tensor;
77
- accuracy?: Tensor;
78
- }
@@ -1 +0,0 @@
1
-
@@ -1,17 +0,0 @@
1
- import { ITokeniser, Task } from '../main';
2
- import { Tensor } from '@tensorflow/tfjs-core';
3
- import { Dataset } from '@tensorflow/tfjs-data';
4
- import { DatasetBuilder, DatasetState } from './DatasetBuilder';
5
- export declare function createTrainValidationSplit(tasks: Task[] | Uint16Array, tokeniser: ITokeniser, datasetBuilder: DatasetBuilder, batchSize: number, validationSplit?: number, masking?: boolean): Promise<{
6
- trainDataset: Dataset<{
7
- xs: Tensor;
8
- ys: Tensor;
9
- }>;
10
- validationDataset: Dataset<{
11
- xs: Tensor;
12
- ys: Tensor;
13
- }>;
14
- size: number;
15
- validationState: DatasetState;
16
- trainState: DatasetState;
17
- }>;