@genai-fi/nanogpt 0.18.1 → 0.19.1

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 (253) hide show
  1. package/dist/Generator.js +30 -30
  2. package/dist/{RealDiv-ioj6Z-ox.js → RealDiv-CGwv0liw.js} +9 -9
  3. package/dist/{Reshape-BZC-ebeR.js → Reshape-BW__R4mZ.js} +7 -7
  4. package/dist/{Reshape-pwprEaej.js → Reshape-CPBkTIH2.js} +1 -1
  5. package/dist/TeachableLLM.js +17 -17
  6. package/dist/Trainer.js +97 -95
  7. package/dist/{axis_util-QWWgLjut.js → axis_util-GTVlo58H.js} +1 -1
  8. package/dist/backend.js +2 -2
  9. package/dist/{backend_util-qwSFfxYx.js → backend_util-GaFarB78.js} +21 -21
  10. package/dist/{backend_webgpu-DI2wXEC2.js → backend_webgpu-BqASlsbV.js} +8 -8
  11. package/dist/{broadcast_to-C_EJTVTZ.js → broadcast_to-eS93CCN_.js} +2 -2
  12. package/dist/checks/appendCache.js +2 -2
  13. package/dist/checks/attentionMask.js +5 -5
  14. package/dist/checks/gelu.js +2 -2
  15. package/dist/checks/matMulGelu.js +2 -2
  16. package/dist/checks/normRMS.js +6 -6
  17. package/dist/checks/normRMSGrad.js +3 -3
  18. package/dist/checks/packUnpack.js +6 -6
  19. package/dist/checks/qkv.js +2 -2
  20. package/dist/checks/rope.js +2 -2
  21. package/dist/{clip_by_value-CLAD4h_I.js → clip_by_value-DDA7rrcT.js} +1 -1
  22. package/dist/complex-DI35Q-gW.js +11 -0
  23. package/dist/{concat-Dqk7Xk7h.js → concat-CAQpCret.js} +5 -5
  24. package/dist/{concat_util-C1Mxe27t.js → concat_util-D18dJ4fD.js} +1 -1
  25. package/dist/data/textLoader.d.ts +1 -1
  26. package/dist/data/textLoader.js +68 -58
  27. package/dist/{dataset-DlqAN81i.js → dataset-CGGp1z9P.js} +3 -3
  28. package/dist/{dropout_util-N0z8Os-K.js → dropout_util--NxWuYg2.js} +1 -1
  29. package/dist/{expand_dims-D0rBtgT1.js → expand_dims-Bkd1YD5x.js} +4 -4
  30. package/dist/{exports_initializers-DIOZQt_L.js → exports_initializers-CYzKLjN7.js} +1 -1
  31. package/dist/{floor-CymuCmTO.js → floor-BQtb-Azg.js} +1 -1
  32. package/dist/{gather-DEyjXNb1.js → gather-qIqEqaGn.js} +1 -1
  33. package/dist/{gelu-DpTCC3eB.js → gelu-B220X1Go.js} +1 -1
  34. package/dist/{gpgpu_math-3bCb5ooU.js → gpgpu_math-BwvV12df.js} +25 -25
  35. package/dist/{index-DSGwv2Yx.js → index-CUXkjxiT.js} +33 -33
  36. package/dist/{index-BQvB7LCC.js → index-CjOWnMXP.js} +15 -15
  37. package/dist/{kernel_funcs_utils-DGqzNlHT.js → kernel_funcs_utils-pq0CK9co.js} +6 -6
  38. package/dist/layers/BaseLayer.js +4 -4
  39. package/dist/layers/CausalSelfAttention.d.ts +1 -0
  40. package/dist/layers/CausalSelfAttention.js +14 -14
  41. package/dist/layers/LoRA.js +4 -4
  42. package/dist/layers/MLP.js +4 -4
  43. package/dist/layers/PositionEmbedding.js +5 -5
  44. package/dist/layers/RMSNorm.js +3 -3
  45. package/dist/layers/RoPECache.js +4 -4
  46. package/dist/layers/TiedEmbedding.js +6 -6
  47. package/dist/layers/TransformerBlock.d.ts +1 -0
  48. package/dist/layers/TransformerBlock.js +1 -1
  49. package/dist/layers/WeightStore.js +2 -2
  50. package/dist/loader/loadTransformers.js +1 -1
  51. package/dist/loader/oldZipLoad.js +9 -9
  52. package/dist/loader/save.js +38 -31
  53. package/dist/main.js +9 -9
  54. package/dist/{matMul16-BIT70Vya.js → matMul16-BcVC_E62.js} +3 -3
  55. package/dist/{matMulGelu-CsZnh18H.js → matMulGelu-JNLZqKQp.js} +18 -18
  56. package/dist/mat_mul-DhG0Newp.js +11 -0
  57. package/dist/mod-CSdCpRjf.js +11 -0
  58. package/dist/models/NanoGPTV1.js +2 -2
  59. package/dist/models/NanoGPTV2.js +2 -2
  60. package/dist/models/model.d.ts +1 -0
  61. package/dist/models/model.js +9 -9
  62. package/dist/{not_equal-CkQKkKZy.js → not_equal-hurPF26l.js} +15 -15
  63. package/dist/{ones-DbVB5N58.js → ones-BytntneX.js} +3 -3
  64. package/dist/ops/adamAdjust.js +3 -3
  65. package/dist/ops/adamMoments.js +3 -3
  66. package/dist/ops/add16.js +1 -1
  67. package/dist/ops/appendCache.js +6 -6
  68. package/dist/ops/attentionMask.js +3 -3
  69. package/dist/ops/concat16.js +3 -3
  70. package/dist/ops/cpu/adamAdjust.js +9 -9
  71. package/dist/ops/cpu/adamMoments.js +5 -5
  72. package/dist/ops/cpu/appendCache.js +2 -2
  73. package/dist/ops/cpu/attentionMask.js +6 -6
  74. package/dist/ops/cpu/fusedSoftmax.js +4 -4
  75. package/dist/ops/cpu/gatherSub.js +5 -5
  76. package/dist/ops/cpu/gelu.js +4 -4
  77. package/dist/ops/cpu/matMul16.js +2 -2
  78. package/dist/ops/cpu/matMulGelu.js +7 -7
  79. package/dist/ops/cpu/matMulMul.js +2 -2
  80. package/dist/ops/cpu/mulDropout.js +5 -5
  81. package/dist/ops/cpu/normRMS.js +1 -1
  82. package/dist/ops/cpu/qkv.js +3 -3
  83. package/dist/ops/cpu/rope.js +5 -5
  84. package/dist/ops/cpu/scatterSub.js +5 -5
  85. package/dist/ops/dot16.js +2 -2
  86. package/dist/ops/dropout.js +6 -6
  87. package/dist/ops/dropout16.js +1 -1
  88. package/dist/ops/gatherSub.js +1 -1
  89. package/dist/ops/gelu.js +2 -2
  90. package/dist/ops/globalNorm.js +7 -7
  91. package/dist/ops/grads/add16.js +1 -1
  92. package/dist/ops/grads/attentionMask.js +2 -2
  93. package/dist/ops/grads/dropout16.js +1 -1
  94. package/dist/ops/grads/gelu.js +2 -2
  95. package/dist/ops/grads/matMul16.js +3 -3
  96. package/dist/ops/grads/matMulGelu.js +1 -1
  97. package/dist/ops/grads/mul16.js +1 -1
  98. package/dist/ops/grads/normRMS.js +7 -7
  99. package/dist/ops/grads/pack16.js +3 -3
  100. package/dist/ops/grads/qkv.js +11 -11
  101. package/dist/ops/grads/rope.js +2 -2
  102. package/dist/ops/grads/softmax16.js +1 -1
  103. package/dist/ops/grads/unpack16.js +2 -2
  104. package/dist/ops/matMul16.js +3 -3
  105. package/dist/ops/matMulGelu.js +6 -6
  106. package/dist/ops/matMulMul.js +3 -3
  107. package/dist/ops/mul16.js +1 -1
  108. package/dist/ops/mulDrop.js +3 -3
  109. package/dist/ops/normRMS.js +4 -4
  110. package/dist/ops/pack16.js +2 -2
  111. package/dist/ops/qkv.js +3 -3
  112. package/dist/ops/reshape16.js +6 -6
  113. package/dist/ops/rope.js +2 -2
  114. package/dist/ops/scatterSub.js +1 -1
  115. package/dist/ops/slice16.js +2 -2
  116. package/dist/ops/softmax16.js +1 -1
  117. package/dist/ops/sub16.js +1 -1
  118. package/dist/ops/sum16.js +6 -6
  119. package/dist/ops/transpose16.js +3 -3
  120. package/dist/ops/unpack16.js +2 -2
  121. package/dist/ops/webgl/adamAdjust.js +2 -2
  122. package/dist/ops/webgl/adamMoments.js +1 -1
  123. package/dist/ops/webgl/appendCache.js +1 -1
  124. package/dist/ops/webgl/attentionMask.js +1 -1
  125. package/dist/ops/webgl/dropout16.js +1 -1
  126. package/dist/ops/webgl/fusedSoftmax.js +7 -7
  127. package/dist/ops/webgl/gatherSub.js +3 -3
  128. package/dist/ops/webgl/gelu.js +2 -2
  129. package/dist/ops/webgl/log.js +3 -3
  130. package/dist/ops/webgl/matMul16.js +13 -13
  131. package/dist/ops/webgl/matMulGelu.js +4 -4
  132. package/dist/ops/webgl/matMulMul.js +2 -2
  133. package/dist/ops/webgl/mulDropout.js +1 -1
  134. package/dist/ops/webgl/normRMS.js +2 -2
  135. package/dist/ops/webgl/qkv.js +1 -1
  136. package/dist/ops/webgl/rope.js +1 -1
  137. package/dist/ops/webgl/scatterSub.js +2 -2
  138. package/dist/ops/webgpu/adamAdjust.js +3 -3
  139. package/dist/ops/webgpu/adamMoments.js +3 -3
  140. package/dist/ops/webgpu/add16.js +6 -6
  141. package/dist/ops/webgpu/appendCache.js +3 -3
  142. package/dist/ops/webgpu/attentionMask.js +2 -2
  143. package/dist/ops/webgpu/attentionMask32_program.js +2 -2
  144. package/dist/ops/webgpu/clipScale.js +7 -7
  145. package/dist/ops/webgpu/concat16.js +5 -5
  146. package/dist/ops/webgpu/dropout16.js +6 -6
  147. package/dist/ops/webgpu/gatherSub.js +3 -3
  148. package/dist/ops/webgpu/gelu.js +8 -8
  149. package/dist/ops/webgpu/matMul16.js +16 -16
  150. package/dist/ops/webgpu/matMul16_program.js +2 -2
  151. package/dist/ops/webgpu/mul16.js +5 -5
  152. package/dist/ops/webgpu/norm2.js +1 -1
  153. package/dist/ops/webgpu/normRMS.js +2 -2
  154. package/dist/ops/webgpu/normRMSGrad.js +4 -4
  155. package/dist/ops/webgpu/pack16.js +4 -4
  156. package/dist/ops/webgpu/pack16_program.js +2 -2
  157. package/dist/ops/webgpu/qkv.js +2 -2
  158. package/dist/ops/webgpu/rope.js +3 -3
  159. package/dist/ops/webgpu/scatterSub.js +3 -3
  160. package/dist/ops/webgpu/slice16.js +4 -4
  161. package/dist/ops/webgpu/softmax16.js +4 -4
  162. package/dist/ops/webgpu/softmax16_program.js +2 -2
  163. package/dist/ops/webgpu/softmax16_subgroup_program.js +2 -2
  164. package/dist/ops/webgpu/softmax16grad.js +4 -4
  165. package/dist/ops/webgpu/sub16.js +6 -6
  166. package/dist/ops/webgpu/sum16.js +3 -3
  167. package/dist/ops/webgpu/transpose16.js +8 -8
  168. package/dist/ops/webgpu/transpose16_program.js +2 -2
  169. package/dist/ops/webgpu/transpose16_shared_program.js +3 -3
  170. package/dist/ops/webgpu/unpack16.js +3 -3
  171. package/dist/ops/webgpu/utils/binary_op.js +3 -3
  172. package/dist/ops/webgpu/utils/reductions.js +5 -5
  173. package/dist/{ops-CURIZSVt.js → ops-CsXeTq1P.js} +100 -100
  174. package/dist/{pack16-WlOSOuZA.js → pack16-bqltoUlR.js} +2 -2
  175. package/dist/patches/webgpu_backend.js +6 -6
  176. package/dist/patches/webgpu_base.js +1 -1
  177. package/dist/patches/webgpu_program.js +2 -2
  178. package/dist/{random_normal-CIm8lk2-.js → random_normal-IBRrha8a.js} +1 -1
  179. package/dist/{random_width-B_fVXhGx.js → random_width-DN5ZtQkM.js} +131 -131
  180. package/dist/{range-BDxO73mk.js → range-C-CjF-LI.js} +1 -1
  181. package/dist/relu-J_X6MUzx.js +9 -0
  182. package/dist/{reshape-BIN71H3p.js → reshape-BDOuCSNW.js} +1 -1
  183. package/dist/{resize_nearest_neighbor-C6_0dAnK.js → resize_nearest_neighbor-BojqlfRe.js} +41 -41
  184. package/dist/{rope-CC5RjmKU.js → rope-DcrZM_e6.js} +5 -5
  185. package/dist/{scatter_nd_util-C-x73Cj6.js → scatter_nd_util-ByNJaL6I.js} +1 -1
  186. package/dist/{segment_util-4zuHV5IG.js → segment_util-Dasb2Zaf.js} +2 -2
  187. package/dist/{selu_util-BXdhy_W6.js → selu_util-BLhIqRkw.js} +5 -5
  188. package/dist/{shared-zTaJ5siv.js → shared-3agzAqQ_.js} +1 -1
  189. package/dist/{shared-DRWDyk9w.js → shared-CagdqkLh.js} +6 -6
  190. package/dist/slice-BzS11Qh0.js +12 -0
  191. package/dist/{slice_util-DPY56GzQ.js → slice_util-CC35pLmT.js} +5 -5
  192. package/dist/{softmax-BLGJqdwx.js → softmax-D4q1LJN7.js} +1 -1
  193. package/dist/split-C2Sj255c.js +9 -0
  194. package/dist/{squeeze-O_YWJpw_.js → squeeze-ho4wLUek.js} +2 -2
  195. package/dist/{stack-z6QE7kmP.js → stack-DudVrtmG.js} +1 -1
  196. package/dist/{step-DQY6_ABw.js → step-BTxPtq1r.js} +4 -4
  197. package/dist/{sum-D39FeU5h.js → sum-BpiwSWvg.js} +3 -3
  198. package/dist/{tensor-D8e0Gd7c.js → tensor-BWFldCso.js} +1 -1
  199. package/dist/{tensor1d-BMl0eZYV.js → tensor1d-LMGMIUlr.js} +1 -1
  200. package/dist/{tensor2d-DTtQ1QcT.js → tensor2d-BnXMKScO.js} +1 -1
  201. package/dist/{tensor4d-Dj4rDssL.js → tensor4d-C6UCG_u8.js} +1 -1
  202. package/dist/{tfjs_backend-Bk3PmK91.js → tfjs_backend-BGnG-ppu.js} +65 -65
  203. package/dist/{tile-CsWlVKKz.js → tile-CFy-xTO6.js} +1 -1
  204. package/dist/tokeniser/BaseTokeniser.d.ts +4 -0
  205. package/dist/tokeniser/BaseTokeniser.js +61 -56
  206. package/dist/tokeniser/type.d.ts +8 -0
  207. package/dist/training/AdamW.js +2 -2
  208. package/dist/training/BasicTrainer.d.ts +1 -0
  209. package/dist/training/BasicTrainer.js +95 -79
  210. package/dist/training/DatasetBuilder.d.ts +6 -2
  211. package/dist/training/DatasetBuilder.js +60 -41
  212. package/dist/training/Evaluator.d.ts +1 -2
  213. package/dist/training/Evaluator.js +21 -31
  214. package/dist/training/SFTTrainer.d.ts +3 -2
  215. package/dist/training/SFTTrainer.js +4 -3
  216. package/dist/training/orthoGrad.js +1 -1
  217. package/dist/training/sparseCrossEntropy.js +38 -38
  218. package/dist/training/tasks/ConversationTask.d.ts +4 -0
  219. package/dist/training/tasks/ConversationTask.js +7 -7
  220. package/dist/training/tasks/PretrainingTask.d.ts +4 -0
  221. package/dist/training/tasks/PretrainingTask.js +11 -7
  222. package/dist/training/tasks/StartSentenceTask.d.ts +4 -0
  223. package/dist/training/tasks/StartSentenceTask.js +5 -5
  224. package/dist/training/tasks/Task.d.ts +12 -0
  225. package/dist/training/tasks/Task.js +55 -31
  226. package/dist/training/types.d.ts +1 -0
  227. package/dist/training/validation.d.ts +1 -1
  228. package/dist/training/validation.js +33 -32
  229. package/dist/{transpose-Qxz-4os3.js → transpose-9kRxIXWR.js} +7 -7
  230. package/dist/{unsorted_segment_sum-BfFVV9Zm.js → unsorted_segment_sum-DJvk5xnh.js} +20 -20
  231. package/dist/utilities/dummy.js +6 -6
  232. package/dist/utilities/multinomialCPU.js +2 -2
  233. package/dist/utilities/packed.js +1 -1
  234. package/dist/utilities/performance.js +1 -1
  235. package/dist/utilities/profile.js +1 -1
  236. package/dist/utilities/safetensors.js +2 -2
  237. package/dist/utilities/sentences.js +5 -5
  238. package/dist/utilities/weights.js +2 -2
  239. package/dist/{variable-SSATClyt.js → variable-Ck482e3n.js} +1 -1
  240. package/dist/{webgpu_program-CbjdYLYk.js → webgpu_program-B4HmApL1.js} +1 -1
  241. package/dist/{webgpu_util-DuofJBMo.js → webgpu_util-DYlGSwOJ.js} +7 -7
  242. package/dist/{zeros-Bw0puq_w.js → zeros-DvZpK8s6.js} +2 -2
  243. package/dist/{zeros_like-rOHr54NY.js → zeros_like-CWjDdwr-.js} +69 -69
  244. package/package.json +1 -1
  245. package/dist/complex-3DpPEG9B.js +0 -11
  246. package/dist/mat_mul-DP86qZtZ.js +0 -11
  247. package/dist/mod-BXjLYwvM.js +0 -11
  248. package/dist/readers-17HLdxVM.js +0 -12
  249. package/dist/relu-DTvZKBsZ.js +0 -9
  250. package/dist/slice-BvItlgXu.js +0 -12
  251. package/dist/split-BN9LkEgS.js +0 -9
  252. package/dist/training/SFTDatasetBuilder.d.ts +0 -23
  253. package/dist/training/SFTDatasetBuilder.js +0 -85
package/dist/Generator.js CHANGED
@@ -1,41 +1,41 @@
1
1
  import { E as Ui } from "./index-DvYrXKkX.js";
2
- import { o as Hi, n as Xi, E as Ki, dl as Ss, a5 as pe, ab as _, as as oo, at as ao, e as Oe, aY as Dt, ay as ro, az as io, au as ji, av as Ft, aD as Ge, ae as co, aG as ws, aH as qi, N as G, af as _e, aI as Yi, A as Ns, aJ as Rs, R as Qi, aj as Ji, v as te, B as lo, _ as Ne, a9 as ee, bb as uo, c7 as Ts, c8 as Es, cO as po, bm as ho, ah as ue, L as Ye, bn as fo, bo as mo, c9 as go, ca as Ds, cb as Fs, cc as Ps, cd as Os, ce as As, bp as xo, ac as nt, cy as Co, cP as bo, cQ as Io, bs as yo, br as ko, bd as $o, de as vo, C as _s, cS as So, ao as wo, x as No, bt as Ro, c2 as $e, cD as To, bu as Eo, cz as Do, cT as Fo, cA as Po, bv as Ls, bw as Vs, bf as Oo, bx as Ao, am as Qe, Q as Zi, by as _o, cB as Lo, cf as Vo, bz as Wo, cF as Mo, cG as Bo, df as Go, cg as zo, bX as ns, bR as St, bU as Ws, cU as yn, dt as ut, du as Uo, cV as kn, dg as ec, K as tc, be as Ho, cW as Xo, bB as Ms, y as Ko, aX as jo, aV as mt, cp as qo, dc as Yo, dd as Qo, bg as Jo, cE as Zo, di as ea, al as ta, G as sa, cq as na, ch as Bs, ci as Gs, cj as zs, dj as oa, b3 as Us, b4 as Hs, bD as Xs, cl as Ks, ck as aa, cY as ra, aM as sc, bE as ia, cC as ca, cZ as la, c_ as ua, dk as da, aP as pa, aZ as ha, cm as fa, bQ as ma, M as js, D as ga, bi as xa, bk as Ca, bj as ba, bF as Ia, d3 as ya, bG as ka, P as $a, a6 as va, bH as Sa, c$ as qs, dv as wa, dw as Na, dx as Ra, X as Ta, cn as Ys, b9 as Ea, d0 as Da, ba as Fa, d1 as Pa, bJ as Oa, bh as Aa, b6 as Qs, ak as _a, dm as La, aL as Va, bL as Js, co as Zs, bM as en, bN as tn, bC as sn, bI as Wa, dy as Ma, dz as Ba, dn as Ga, dp as za, dq as Ua, H as Ha, d2 as Xa, aK as nn, cr as Ka, dr as ja, dA as qa, dB as Ya, cs as on, bq as an, ds as Qa, T as Ja, ct as Za, bl as er, dC as rn, cu as tr, b8 as sr, bO as nr, a as or, dD as ar, dE as $n, aw as vn, ax as nc, t as rr, b as oc, dF as ac, dG as rc, c0 as ic, ar as cc, bP as lc, bV as uc, S as dc, bW as pc, aQ as hc, aq as fc, bS as mc, bT as gc, bY as xc, aS as ir, bA as Cc, aN as bc, bZ as Ic, F as yc, b_ as kc, dh as $c, a$ as vc, b0 as Sc, b1 as wc, b2 as Nc, aO as Rc, b$ as Tc, b5 as Ec, c5 as Dc, ap as Fc, c1 as Pc, aW as cr, bK as Oc, aF as Ac, c3 as _c, b7 as Lc, c4 as Vc, k as Wc } from "./index-DSGwv2Yx.js";
3
- import { n as Mc } from "./random_width-B_fVXhGx.js";
4
- import { t as Bc } from "./zeros_like-rOHr54NY.js";
2
+ import { o as Hi, q as Xi, E as Ki, dl as Ss, a5 as pe, ab as _, as as oo, at as ao, h as Oe, aY as Dt, ay as ro, az as io, au as ji, av as Ft, aD as Ge, ae as co, aG as ws, aH as qi, U as G, af as _e, aI as Yi, H as Ns, aJ as Rs, R as Qi, aj as Ji, x as te, D as lo, _ as Ne, a9 as ee, bb as uo, c7 as Ts, c8 as Es, cO as po, bm as ho, ah as ue, Q as Ye, bn as fo, bo as mo, c9 as go, ca as Ds, cb as Fs, cc as Ps, cd as Os, ce as As, bp as xo, ac as nt, cy as Co, cP as bo, cQ as Io, bs as yo, br as ko, bd as $o, de as vo, C as _s, cS as So, ao as wo, z as No, bt as Ro, c2 as $e, cD as To, bu as Eo, cz as Do, cT as Fo, cA as Po, bv as Ls, bw as Vs, bf as Oo, bx as Ao, am as Qe, V as Zi, by as _o, cB as Lo, cf as Vo, bz as Wo, cF as Mo, cG as Bo, df as Go, cg as zo, bX as ns, bR as St, bU as Ws, cU as yn, dt as ut, du as Uo, cV as kn, dg as ec, N as tc, be as Ho, cW as Xo, bB as Ms, A as Ko, aX as jo, aV as mt, cp as qo, dc as Yo, dd as Qo, bg as Jo, cE as Zo, di as ea, al as ta, G as sa, cq as na, ch as Bs, ci as Gs, cj as zs, dj as oa, b3 as Us, b4 as Hs, bD as Xs, cl as Ks, ck as aa, cY as ra, aM as sc, bE as ia, cC as ca, cZ as la, c_ as ua, dk as da, aP as pa, aZ as ha, cm as fa, bQ as ma, M as js, I as ga, bi as xa, bk as Ca, bj as ba, bF as Ia, d3 as ya, bG as ka, P as $a, a6 as va, bH as Sa, c$ as qs, dv as wa, dw as Na, dx as Ra, Z as Ta, cn as Ys, b9 as Ea, d0 as Da, ba as Fa, d1 as Pa, bJ as Oa, bh as Aa, b6 as Qs, ak as _a, dm as La, aL as Va, bL as Js, co as Zs, bM as en, bN as tn, bC as sn, bI as Wa, dy as Ma, dz as Ba, dn as Ga, dp as za, dq as Ua, J as Ha, d2 as Xa, aK as nn, cr as Ka, dr as ja, dA as qa, dB as Ya, cs as on, bq as an, ds as Qa, T as Ja, ct as Za, bl as er, dC as rn, cu as tr, b8 as sr, bO as nr, c as or, dD as ar, dE as $n, aw as vn, ax as nc, t as rr, a as oc, dF as ac, dG as rc, c0 as ic, ar as cc, bP as lc, bV as uc, S as dc, bW as pc, aQ as hc, aq as fc, bS as mc, bT as gc, bY as xc, aS as ir, bA as Cc, aN as bc, bZ as Ic, F as yc, b_ as kc, dh as $c, a$ as vc, b0 as Sc, b1 as wc, b2 as Nc, aO as Rc, b$ as Tc, b5 as Ec, c5 as Dc, ap as Fc, c1 as Pc, aW as cr, bK as Oc, aF as Ac, c3 as _c, b7 as Lc, c4 as Vc, k as Wc } from "./index-CUXkjxiT.js";
3
+ import { n as Mc } from "./random_width-DN5ZtQkM.js";
4
+ import { t as Bc } from "./zeros_like-CWjDdwr-.js";
5
5
  import "./index-Cp39cXWe.js";
6
- import "./dataset-DlqAN81i.js";
7
- import { a as j, u as ae, c as ot, i as at, b as Gc, d as wt, t as Re, e as gt, f as dt, g as lr, r as Nt, h as Ae, j as zc, k as Uc, l as cn, z as Hc, m as ln, n as ur, o as Xc, p as Kc, q as jc, v as qc, w as Yc, x as Qc, y as Jc, A as Zc, B as el, C as tl, D as lt, E as sl, F as nl, G as dr, H as ol, I as al, J as rl, K as il, L as cl, M as ll, N as ul, O as dl, P as pl, Q as hl, R as fl, S as ml, T as gl, U as xl, V as Cl, W as bl, X as Il, Y as yl, Z as kl, _ as $l, $ as vl, a0 as Sl, a1 as wl, a2 as Nl, a3 as Rl, a4 as Tl, a5 as El, a6 as Dl, a7 as Fl, a8 as Pl, a9 as Ol, aa as Al, ab as _l, ac as Ll, ad as Vl, ae as Wl, af as Ml, ag as Bl, ah as Gl, ai as zl } from "./shared-DRWDyk9w.js";
6
+ import "./dataset-CGGp1z9P.js";
7
+ import { a as j, u as ae, c as ot, i as at, b as Gc, d as wt, t as Re, e as gt, f as dt, g as lr, r as Nt, h as Ae, j as zc, k as Uc, l as cn, z as Hc, m as ln, n as ur, o as Xc, p as Kc, q as jc, v as qc, w as Yc, x as Qc, y as Jc, A as Zc, B as el, C as tl, D as lt, E as sl, F as nl, G as dr, H as ol, I as al, J as rl, K as il, L as cl, M as ll, N as ul, O as dl, P as pl, Q as hl, R as fl, S as ml, T as gl, U as xl, V as Cl, W as bl, X as Il, Y as yl, Z as kl, _ as $l, $ as vl, a0 as Sl, a1 as wl, a2 as Nl, a3 as Rl, a4 as Tl, a5 as El, a6 as Dl, a7 as Fl, a8 as Pl, a9 as Ol, aa as Al, ab as _l, ac as Ll, ad as Vl, ae as Wl, af as Ml, ag as Bl, ah as Gl, ai as zl } from "./shared-CagdqkLh.js";
8
8
  import { m as pt, g as pr, s as Ul, c as Hl, b as Xl, d as Kl, a as jl, e as ql } from "./complex_util-Yc1A_gV1.js";
9
- import { a as ge, b as xe, d as ke, c as ve, e as Te, g as os } from "./axis_util-QWWgLjut.js";
10
- import { k as Je, h as Le, i as Ze, j as rt, b as Se, d as xt, g as as } from "./step-DQY6_ABw.js";
11
- import { z as rs, A as is, B as cs, C as hr, D as fr, F as mr, G as gr, H as xr, I as Cr, J as br, y as Ir, x as yr, w as kr, u as $r, t as vr, E as Sr, K as wr, L as Nr, M as Rr, c as Tr, f as Yl } from "./backend_util-qwSFfxYx.js";
12
- import { a as Er, c as Ue } from "./concat_util-C1Mxe27t.js";
13
- import { c as Dr, a as Ql, s as Jl } from "./segment_util-4zuHV5IG.js";
9
+ import { a as ge, b as xe, d as ke, c as ve, e as Te, g as os } from "./axis_util-GTVlo58H.js";
10
+ import { k as Je, h as Le, i as Ze, j as rt, b as Se, d as xt, g as as } from "./step-BTxPtq1r.js";
11
+ import { z as rs, A as is, B as cs, C as hr, D as fr, F as mr, G as gr, H as xr, I as Cr, J as br, y as Ir, x as yr, w as kr, u as $r, t as vr, E as Sr, K as wr, L as Nr, M as Rr, c as Tr, f as Yl } from "./backend_util-GaFarB78.js";
12
+ import { a as Er, c as Ue } from "./concat_util-D18dJ4fD.js";
13
+ import { c as Dr, a as Ql, s as Jl } from "./segment_util-Dasb2Zaf.js";
14
14
  import { s as Zl } from "./index-CieiGp4Y.js";
15
15
  import { n as Fr, b as Pr, a as Or } from "./non_max_suppression_impl-B2W7YjZB.js";
16
- import { c as Ct } from "./scatter_nd_util-C-x73Cj6.js";
17
- import { S as Ar, a as _r } from "./selu_util-BXdhy_W6.js";
18
- import { s as Lr, b as Vr, p as eu, a as tu, i as su, c as nu } from "./slice_util-DPY56GzQ.js";
19
- import { h as Sn, j as ou, k as au, l as ru, m as iu, n as cu, o as lu, P as un, p as Ve, u as Pe, q as Wr, c as Mr, T as De, E as Br, g as Gr, a as zr, r as uu, s as du, t as Y, v as pu, w as wn, x as hu, y as fu, z as Pt, A as Ot, B as mu, C as gu, D as bs, F as Gt, G as zt, H as xu, I as Cu, J as Nn, K as bu, L as Iu, M as fs, N as yu, O as ku, Q as $u, R as Ut, S as ms, U as vu, f as he, V as be, W as Ht, X as Xt, Y as Su, d as Rn, e as Tn, i as Ur, Z as wu, _ as Nu, $ as Ru, a0 as Tu, a1 as Eu, a2 as Du, a3 as At } from "./gpgpu_math-3bCb5ooU.js";
20
- import { s as Hr, a as Fu, t as Xr, b as Pu, c as Ou, d as Kr, e as Au, n as _u, f as Lu, g as Vu, h as Wu, i as Mu, j as Bu, k as Gu, l as zu, o as Uu, p as Hu, q as Xu, r as Ku, u as ju, v as qu, w as Yu, x as Qu, y as Ju, z as Zu, A as ed, B as td, C as sd, D as nd, E as od, F as ad, G as rd, H as id, I as cd, J as ld, K as ud, L as dd, M as jr, N as pd, O as hd, P as fd, Q as md, R as gd, S as xd, T as Cd, U as bd, V as Id, W as yd } from "./shared-zTaJ5siv.js";
21
- import { a as ye, c as kd, U as st, d as qe, e as ze, A as En, f as bt, B as dn, h as pn, m as Rt, u as se, C as We, b as Ce, i as Fe, j as hn, k as it, l as It, n as $d, o as vd, p as Sd, q as wd } from "./kernel_funcs_utils-DGqzNlHT.js";
22
- import { R as Nd, r as U, a as Rd } from "./Reshape-BZC-ebeR.js";
23
- import { M as qr } from "./matMulGelu-CsZnh18H.js";
24
- import { t as Yr, s as fn, a as _t, m as Td, r as Ed, b as Dd, c as Fd, d as Pd } from "./RealDiv-ioj6Z-ox.js";
25
- import { z as Od } from "./zeros-Bw0puq_w.js";
16
+ import { c as Ct } from "./scatter_nd_util-ByNJaL6I.js";
17
+ import { S as Ar, a as _r } from "./selu_util-BLhIqRkw.js";
18
+ import { s as Lr, b as Vr, p as eu, a as tu, i as su, c as nu } from "./slice_util-CC35pLmT.js";
19
+ import { h as Sn, j as ou, k as au, l as ru, m as iu, n as cu, o as lu, P as un, p as Ve, u as Pe, q as Wr, c as Mr, T as De, E as Br, g as Gr, a as zr, r as uu, s as du, t as Y, v as pu, w as wn, x as hu, y as fu, z as Pt, A as Ot, B as mu, C as gu, D as bs, F as Gt, G as zt, H as xu, I as Cu, J as Nn, K as bu, L as Iu, M as fs, N as yu, O as ku, Q as $u, R as Ut, S as ms, U as vu, f as he, V as be, W as Ht, X as Xt, Y as Su, d as Rn, e as Tn, i as Ur, Z as wu, _ as Nu, $ as Ru, a0 as Tu, a1 as Eu, a2 as Du, a3 as At } from "./gpgpu_math-BwvV12df.js";
20
+ import { s as Hr, a as Fu, t as Xr, b as Pu, c as Ou, d as Kr, e as Au, n as _u, f as Lu, g as Vu, h as Wu, i as Mu, j as Bu, k as Gu, l as zu, o as Uu, p as Hu, q as Xu, r as Ku, u as ju, v as qu, w as Yu, x as Qu, y as Ju, z as Zu, A as ed, B as td, C as sd, D as nd, E as od, F as ad, G as rd, H as id, I as cd, J as ld, K as ud, L as dd, M as jr, N as pd, O as hd, P as fd, Q as md, R as gd, S as xd, T as Cd, U as bd, V as Id, W as yd } from "./shared-3agzAqQ_.js";
21
+ import { a as ye, c as kd, U as st, d as qe, e as ze, A as En, f as bt, B as dn, h as pn, m as Rt, u as se, C as We, b as Ce, i as Fe, j as hn, k as it, l as It, n as $d, o as vd, p as Sd, q as wd } from "./kernel_funcs_utils-pq0CK9co.js";
22
+ import { R as Nd, r as U, a as Rd } from "./Reshape-BW__R4mZ.js";
23
+ import { M as qr } from "./matMulGelu-JNLZqKQp.js";
24
+ import { t as Yr, s as fn, a as _t, m as Td, r as Ed, b as Dd, c as Fd, d as Pd } from "./RealDiv-CGwv0liw.js";
25
+ import { z as Od } from "./zeros-DvZpK8s6.js";
26
26
  import "./ops/cpu/attentionMask.js";
27
27
  import "./ops/webgl/attentionMask.js";
28
28
  import "./ops/grads/attentionMask.js";
29
29
  import "./ops/cpu/rope.js";
30
30
  import "./ops/webgl/rope.js";
31
- import "./rope-CC5RjmKU.js";
31
+ import "./rope-DcrZM_e6.js";
32
32
  import "./ops/cpu/appendCache.js";
33
33
  import "./ops/webgl/appendCache.js";
34
34
  import "./ops/grads/softmax16.js";
35
- import "./matMul16-BIT70Vya.js";
35
+ import "./matMul16-BcVC_E62.js";
36
36
  import "./ops/webgl/matMul16.js";
37
37
  import "./ops/cpu/matMul16.js";
38
- import "./pack16-WlOSOuZA.js";
38
+ import "./pack16-bqltoUlR.js";
39
39
  import "./ops/transpose16.js";
40
40
  import "./ops/reshape16.js";
41
41
  import "./ops/cpu/qkv.js";
@@ -65,17 +65,17 @@ import "./ops/cpu/matMulGelu.js";
65
65
  import "./ops/grads/matMulGelu.js";
66
66
  import "./ops/cpu/gelu.js";
67
67
  import "./ops/webgl/gelu.js";
68
- import "./gelu-DpTCC3eB.js";
68
+ import "./gelu-B220X1Go.js";
69
69
  import "./ops/webgl/log.js";
70
70
  import "./checks/normRMS.js";
71
71
  import "./checks/normRMSGrad.js";
72
72
  import Wd from "./utilities/multinomialCPU.js";
73
- import { r as Dn } from "./reshape-BIN71H3p.js";
74
- import { t as Kt } from "./tensor2d-DTtQ1QcT.js";
75
- import { z as Md } from "./unsorted_segment_sum-BfFVV9Zm.js";
76
- import { s as gs } from "./softmax-BLGJqdwx.js";
77
- import { g as Bd } from "./gather-DEyjXNb1.js";
78
- import { c as Gd } from "./concat-Dqk7Xk7h.js";
73
+ import { r as Dn } from "./reshape-BDOuCSNW.js";
74
+ import { t as Kt } from "./tensor2d-BnXMKScO.js";
75
+ import { z as Md } from "./unsorted_segment_sum-DJvk5xnh.js";
76
+ import { s as gs } from "./softmax-D4q1LJN7.js";
77
+ import { g as Bd } from "./gather-qIqEqaGn.js";
78
+ import { c as Gd } from "./concat-CAQpCret.js";
79
79
  function zd(a, t, e, n = !1) {
80
80
  const s = Xi(a, "logits", "multinomial"), o = s.size, r = s.rank;
81
81
  if (o < 2)
@@ -1,10 +1,10 @@
1
- import { aE as E, ab as T, ah as O, N as V, aW as B, K as F, aM as K, aX as W } from "./index-DSGwv2Yx.js";
2
- import { r as $ } from "./Reshape-BZC-ebeR.js";
3
- import { a as A, b as k, d as C, c as N, e as R } from "./axis_util-QWWgLjut.js";
4
- import { t as U, m as _ } from "./shared-zTaJ5siv.js";
5
- import { c as j } from "./backend_util-qwSFfxYx.js";
6
- import { f as y } from "./gpgpu_math-3bCb5ooU.js";
7
- import { g as G, b as L } from "./kernel_funcs_utils-DGqzNlHT.js";
1
+ import { aE as E, ab as T, ah as O, U as V, aW as B, N as F, aM as U, aX as W } from "./index-CUXkjxiT.js";
2
+ import { r as $ } from "./Reshape-BW__R4mZ.js";
3
+ import { a as A, b as k, d as C, c as N, e as R } from "./axis_util-GTVlo58H.js";
4
+ import { t as K, m as _ } from "./shared-3agzAqQ_.js";
5
+ import { c as j } from "./backend_util-GaFarB78.js";
6
+ import { f as y } from "./gpgpu_math-BwvV12df.js";
7
+ import { g as G, b as L } from "./kernel_funcs_utils-pq0CK9co.js";
8
8
  class w {
9
9
  constructor(s, e) {
10
10
  this.variableNames = ["x"];
@@ -299,7 +299,7 @@ function te(a) {
299
299
  const I = e.texData.get(d.dataId).values, m = new Array(i);
300
300
  for (let v = 0; v < m.length; v++)
301
301
  m[v] = n.shape[u[v]];
302
- const z = U(I, n.shape, n.dtype, u, m);
302
+ const z = K(I, n.shape, n.dtype, u, m);
303
303
  d = e.makeTensorInfo(m, n.dtype);
304
304
  const D = e.texData.get(d.dataId);
305
305
  D.values = z;
@@ -322,7 +322,7 @@ function te(a) {
322
322
  return p && e.disposeIntermediateTensorInfo(d), x;
323
323
  }
324
324
  const he = {
325
- kernelName: K,
325
+ kernelName: U,
326
326
  backendName: "webgl",
327
327
  kernelFunc: te
328
328
  };
@@ -1,6 +1,6 @@
1
- import { R as C, N as c, aj as R, v as f } from "./index-DSGwv2Yx.js";
2
- import { u as g, g as I, a as x, b as F, c as $, d as u, e as m, i as l } from "./gpgpu_math-3bCb5ooU.js";
3
- class v {
1
+ import { R as C, U as c, aj as R, x as f } from "./index-CUXkjxiT.js";
2
+ import { u as g, g as I, a as x, b as F, c as $, d as u, e as m, i as l } from "./gpgpu_math-BwvV12df.js";
3
+ class S {
4
4
  constructor(t, i) {
5
5
  this.variableNames = ["A"], this.packedInputs = !0, this.packedOutput = !0, this.customUniforms = [{ name: "inputShape", type: "ivec3" }], this.outputShape = t, this.enableShapeUniforms = g(this.outputShape.length);
6
6
  let a = "";
@@ -20,7 +20,7 @@ class v {
20
20
  `;
21
21
  }
22
22
  this.userCode = `
23
- ${S(i, this.enableShapeUniforms)}
23
+ ${v(i, this.enableShapeUniforms)}
24
24
  ${this.enableShapeUniforms ? I() : x(t)}
25
25
 
26
26
  void main() {
@@ -39,7 +39,7 @@ class v {
39
39
  `;
40
40
  }
41
41
  }
42
- function S(s, t) {
42
+ function v(s, t) {
43
43
  return `
44
44
  ivec3 inputCoordsFromReshapedOutCoords(int index) {
45
45
  ${t ? F(["r", "c", "d"], "inputShape") : $(["r", "c", "d"], s)}
@@ -58,7 +58,7 @@ function b(s, t, i) {
58
58
  }, o = [
59
59
  u(t),
60
60
  ...m(t)
61
- ], r = new v(o, a), p = !0, n = [a], h = i.runWebGLProgram(r, [e], s.dtype, n, p);
61
+ ], r = new S(o, a), p = !0, n = [a], h = i.runWebGLProgram(r, [e], s.dtype, n, p);
62
62
  return { dataId: h.dataId, shape: t, dtype: h.dtype };
63
63
  }
64
64
  function y(s) {
@@ -73,7 +73,7 @@ const U = {
73
73
  kernelFunc: y
74
74
  };
75
75
  export {
76
- v as R,
76
+ S as R,
77
77
  U as a,
78
78
  y as r
79
79
  };
@@ -1,4 +1,4 @@
1
- import { N as h, aj as d, v as c, R as m } from "./index-DSGwv2Yx.js";
1
+ import { U as h, aj as d, x as c, R as m } from "./index-CUXkjxiT.js";
2
2
  function i(n) {
3
3
  const { inputs: p, attrs: o } = n, { x: e } = p, { shape: r } = o, a = h(e.shape), s = d(r, a), t = h(s);
4
4
  return c(a === t, () => `The new shape (${s}) has ${t} elements and the old shape (${e.shape}) has ${a} elements. The new shape and old shape must have the same number of elements.`), n.backend.incRef(e.dataId), { dataId: e.dataId, shape: s, dtype: e.dtype };
@@ -1,28 +1,28 @@
1
- import { validateConfig as l } from "./models/config.js";
1
+ import { validateConfig as _ } from "./models/config.js";
2
2
  import { saveModel as p } from "./loader/save.js";
3
3
  import { loadModel as u } from "./loader/load.js";
4
4
  import f from "./Generator.js";
5
5
  import h from "./Trainer.js";
6
6
  import { E as c } from "./index-DvYrXKkX.js";
7
7
  import { dummyPassTrainAsync as d } from "./utilities/dummy.js";
8
- import "./index-DSGwv2Yx.js";
9
- import "./random_width-B_fVXhGx.js";
10
- import "./zeros_like-rOHr54NY.js";
8
+ import "./index-CUXkjxiT.js";
9
+ import "./random_width-DN5ZtQkM.js";
10
+ import "./zeros_like-CWjDdwr-.js";
11
11
  import "./index-Cp39cXWe.js";
12
- import "./dataset-DlqAN81i.js";
12
+ import "./dataset-CGGp1z9P.js";
13
13
  import "./ops/cpu/attentionMask.js";
14
14
  import "./ops/webgl/attentionMask.js";
15
15
  import "./ops/grads/attentionMask.js";
16
16
  import "./ops/cpu/rope.js";
17
17
  import "./ops/webgl/rope.js";
18
- import "./rope-CC5RjmKU.js";
18
+ import "./rope-DcrZM_e6.js";
19
19
  import "./ops/cpu/appendCache.js";
20
20
  import "./ops/webgl/appendCache.js";
21
21
  import "./ops/grads/softmax16.js";
22
- import "./matMul16-BIT70Vya.js";
22
+ import "./matMul16-BcVC_E62.js";
23
23
  import "./ops/webgl/matMul16.js";
24
24
  import "./ops/cpu/matMul16.js";
25
- import "./pack16-WlOSOuZA.js";
25
+ import "./pack16-bqltoUlR.js";
26
26
  import "./ops/transpose16.js";
27
27
  import "./ops/reshape16.js";
28
28
  import "./ops/cpu/qkv.js";
@@ -43,11 +43,11 @@ import "./ops/webgl/gatherSub.js";
43
43
  import "./ops/cpu/scatterSub.js";
44
44
  import "./ops/webgl/scatterSub.js";
45
45
  import "./ops/cpu/matMulGelu.js";
46
- import "./matMulGelu-CsZnh18H.js";
46
+ import "./matMulGelu-JNLZqKQp.js";
47
47
  import "./ops/grads/matMulGelu.js";
48
48
  import "./ops/cpu/gelu.js";
49
49
  import "./ops/webgl/gelu.js";
50
- import "./gelu-DpTCC3eB.js";
50
+ import "./gelu-B220X1Go.js";
51
51
  import "./ops/webgl/log.js";
52
52
  import "./ops/cpu/adamMoments.js";
53
53
  import "./ops/webgl/adamMoments.js";
@@ -57,7 +57,7 @@ import "./checks/normRMS.js";
57
57
  import "./checks/normRMSGrad.js";
58
58
  import k from "./utilities/profile.js";
59
59
  import y from "./models/factory.js";
60
- class _ {
60
+ class l {
61
61
  ee = new c();
62
62
  _config;
63
63
  _model;
@@ -133,7 +133,7 @@ class _ {
133
133
  attachLoRA(t) {
134
134
  if (!this._model)
135
135
  throw new Error("model_not_initialized.");
136
- this._model.attachLoRA(t), this.ee.emit("changeLoRA");
136
+ this.model.lora?.name !== t && (this._trainer && (this._trainer.dispose(), this._trainer = null), this._model.attachLoRA(t), this.ee.emit("changeLoRA"));
137
137
  }
138
138
  detachLoRA() {
139
139
  if (!this._model)
@@ -171,9 +171,9 @@ class _ {
171
171
  );
172
172
  }
173
173
  static loadModel(t, i) {
174
- const e = new _();
174
+ const e = new l();
175
175
  return u(t, i).then(({ model: o, tokeniser: s, metaData: r, optimizer: n, log: a }) => {
176
- l(o.config), e._model = o, e._tokeniser = s, e._config = o.config, r && (e.meta = r), e.setStatus("warmup"), d(o).then((m) => {
176
+ _(o.config), e._model = o, e._tokeniser = s, e._config = o.config, r && (e.meta = r), e.setStatus("warmup"), d(o).then((m) => {
177
177
  e._memoryRequirements = m, n && (e._trainer = new h(
178
178
  o,
179
179
  s,
@@ -189,8 +189,8 @@ class _ {
189
189
  }), e;
190
190
  }
191
191
  static create(t, i) {
192
- l(i);
193
- const e = i, o = t === "char" ? new g(e.vocabSize) : new w(e.vocabSize), s = y(e), r = new _(o, s);
192
+ _(i);
193
+ const e = i, o = t === "char" ? new g(e.vocabSize) : new w(e.vocabSize), s = y(e), r = new l(o, s);
194
194
  return r.setStatus("warmup"), d(s).then((n) => {
195
195
  r._memoryRequirements = n, r.tokeniser.trained ? (r.setStatus("ready"), r.ee.emit("loaded"), r.ee.emit("phase", r.phase)) : (r.setStatus("awaitingTokens"), r.ee.emit("loaded"), r.ee.emit("phase", r.phase), r.tokeniser.once("trainStatus", (a) => {
196
196
  a === "trained" && r.setStatus("ready");
@@ -269,5 +269,5 @@ class _ {
269
269
  }
270
270
  }
271
271
  export {
272
- _ as default
272
+ l as default
273
273
  };
package/dist/Trainer.js CHANGED
@@ -1,29 +1,28 @@
1
- import { E as m } from "./index-DvYrXKkX.js";
2
- import g from "./training/PreTrainer.js";
3
- import { createTrainValidationSplit as u } from "./training/validation.js";
4
- import c from "./training/SFTTrainer.js";
5
- import p from "./training/tasks/splitter.js";
6
- const r = [];
1
+ import { E as w } from "./index-DvYrXKkX.js";
2
+ import c from "./training/PreTrainer.js";
3
+ import { createTrainValidationSplit as f } from "./training/validation.js";
4
+ import g from "./training/SFTTrainer.js";
5
+ const s = [];
7
6
  for (let n = 0; n < 256; ++n)
8
- r.push((n + 256).toString(16).slice(1));
9
- function w(n, t = 0) {
10
- return (r[n[t + 0]] + r[n[t + 1]] + r[n[t + 2]] + r[n[t + 3]] + "-" + r[n[t + 4]] + r[n[t + 5]] + "-" + r[n[t + 6]] + r[n[t + 7]] + "-" + r[n[t + 8]] + r[n[t + 9]] + "-" + r[n[t + 10]] + r[n[t + 11]] + r[n[t + 12]] + r[n[t + 13]] + r[n[t + 14]] + r[n[t + 15]]).toLowerCase();
7
+ s.push((n + 256).toString(16).slice(1));
8
+ function T(n, t = 0) {
9
+ return (s[n[t + 0]] + s[n[t + 1]] + s[n[t + 2]] + s[n[t + 3]] + "-" + s[n[t + 4]] + s[n[t + 5]] + "-" + s[n[t + 6]] + s[n[t + 7]] + "-" + s[n[t + 8]] + s[n[t + 9]] + "-" + s[n[t + 10]] + s[n[t + 11]] + s[n[t + 12]] + s[n[t + 13]] + s[n[t + 14]] + s[n[t + 15]]).toLowerCase();
11
10
  }
12
- const T = new Uint8Array(16);
13
- function D() {
14
- return crypto.getRandomValues(T);
11
+ const p = new Uint8Array(16);
12
+ function k() {
13
+ return crypto.getRandomValues(p);
15
14
  }
16
- function d(n, t, a) {
17
- return crypto.randomUUID ? crypto.randomUUID() : k(n);
15
+ function m(n, t, e) {
16
+ return crypto.randomUUID ? crypto.randomUUID() : L(n);
18
17
  }
19
- function k(n, t, a) {
18
+ function L(n, t, e) {
20
19
  n = n || {};
21
- const i = n.random ?? n.rng?.() ?? D();
20
+ const i = n.random ?? n.rng?.() ?? k();
22
21
  if (i.length < 16)
23
22
  throw new Error("Random bytes length must be >= 16");
24
- return i[6] = i[6] & 15 | 64, i[8] = i[8] & 63 | 128, w(i);
23
+ return i[6] = i[6] & 15 | 64, i[8] = i[8] & 63 | 128, T(i);
25
24
  }
26
- class f extends m {
25
+ class u extends w {
27
26
  trainer;
28
27
  trainingType = "pretraining";
29
28
  hasTrained = !1;
@@ -39,21 +38,34 @@ class f extends m {
39
38
  logInterval: 10
40
39
  };
41
40
  tokenizer;
42
- constructor(t, a, i = "pretraining", e, s) {
43
- if (super(), t instanceof f) {
44
- const o = a || t.options, h = t.options;
41
+ constructor(t, e, i, a, o) {
42
+ if (super(), t instanceof u) {
43
+ const r = e || t.options, h = t.options;
45
44
  let l = !1;
46
- t.trainingType === "sft" && o.sftMode !== h.sftMode && (l = !0), i !== t.trainingType && (l = !0), l ? (t.trainingType === "sft" ? this.trainer = new c(t.model, t.tokenizer, o) : this.trainer = new g(t.model, t.tokenizer, o), this.trainingType = i, this.options = o, this.tokenizer = t.tokenizer) : (this.trainer = t.trainer, this.trainingType = i, this.options = o, this.trainer.updateOptimizer(this.options), this.log = t.log, this.progress = t.progress, this.totalTokens = t.totalTokens, this.tokenizer = t.tokenizer, o.batchSize === h.batchSize && (this.trainDataset = t.trainDataset, this.validationDataset = t.validationDataset));
45
+ if (t.trainingType === "sft" && r.sftMode !== h.sftMode && (l = !0), t.trainer instanceof g && t.trainer.loraName && r.loraName !== t.trainer.loraName && (l = !0), i !== void 0 && i !== t.trainingType && (l = !0), l) {
46
+ if (t.trainingType === "sft") {
47
+ const d = new g(t.model, t.tokenizer, r);
48
+ this.trainer = d, d.loraName = r.loraName;
49
+ } else
50
+ this.trainer = new c(t.model, t.tokenizer, r);
51
+ this.trainingType = i || t.trainingType, this.options = r, this.tokenizer = t.tokenizer;
52
+ } else
53
+ this.trainer = t.trainer, this.trainingType = i || t.trainingType, this.options = r, this.trainer.updateOptimizer(this.options), this.log = t.log, this.progress = t.progress, this.totalTokens = t.totalTokens, this.tokenizer = t.tokenizer, r.batchSize === h.batchSize && (this.trainDataset = t.trainDataset, this.validationDataset = t.validationDataset);
47
54
  return;
48
55
  }
49
- if (!a)
56
+ if (!e)
50
57
  throw new Error("Tokeniser must be provided when initializing Trainer with a model");
51
58
  if (!t)
52
59
  throw new Error("Model must be provided when initializing Trainer");
53
- this.options = e || {
60
+ if (this.options = a || {
54
61
  batchSize: 32,
55
62
  sftMode: "full"
56
- }, i === "sft" ? this.trainer = new c(t, a, e, s) : this.trainer = new g(t, a, e, s), this.trainingType = i, this.tokenizer = a;
63
+ }, i === "sft") {
64
+ const r = new g(t, e, a, o);
65
+ this.trainer = r, r.loraName = a?.loraName;
66
+ } else
67
+ this.trainer = new c(t, e, a, o);
68
+ this.trainingType = i || "pretraining", this.tokenizer = e;
57
69
  }
58
70
  get model() {
59
71
  return this.trainer.model;
@@ -74,85 +86,75 @@ class f extends m {
74
86
  return this.totalTokens;
75
87
  }
76
88
  setOptions(t) {
77
- const a = new Set(
89
+ const e = new Set(
78
90
  Object.keys(t).filter(
79
91
  (i) => t[i] !== this.options[i]
80
92
  )
81
93
  );
82
94
  if (this.trainer.isRunning) {
83
- if (a.has("batchSize"))
95
+ if (e.has("batchSize"))
84
96
  throw new Error("Cannot change batch size during training");
85
- if (a.has("sftMode"))
97
+ if (e.has("sftMode"))
86
98
  throw new Error("Cannot change SFT mode during training");
87
- if (a.has("loraConfig"))
99
+ if (e.has("loraConfig"))
88
100
  throw new Error("Cannot change LoRA configuration during training");
89
- if (a.has("validationSplit"))
101
+ if (e.has("validationSplit"))
90
102
  throw new Error("Cannot change validation split during training");
91
- if (a.has("trainableWeights"))
103
+ if (e.has("trainableWeights"))
92
104
  throw new Error("Cannot change trainable weights during training");
93
- if (a.has("mixedPrecision"))
105
+ if (e.has("mixedPrecision"))
94
106
  throw new Error("Cannot change mixed precision setting during training");
95
- if (a.has("gradientCheckpointing"))
107
+ if (e.has("gradientCheckpointing"))
96
108
  throw new Error("Cannot change gradient checkpointing setting during training");
97
109
  }
98
110
  this.options = {
99
111
  ...this.options,
100
112
  ...t
101
- }, this.trainer.updateOptimizer(this.options), a.has("metrics") && this.trainer.setMetrics(t.metrics || []);
113
+ }, this.trainer.updateOptimizer(this.options), e.has("metrics") && this.trainer.setMetrics(t.metrics || []);
102
114
  }
103
- async prepare(t = [], a) {
115
+ async prepare(t = [], e) {
104
116
  const i = this.options;
105
- if (a && (this.model.metaData.pretrainingData = a.map((e) => ({
106
- id: e.id,
107
- name: e.name
108
- }))), this.trainingType === "pretraining" && this.trainer instanceof g) {
109
- const { trainDataset: e, validationDataset: s, size: o } = await u(
117
+ if (e && (this.model.metaData.pretrainingData = e.map((a) => ({
118
+ id: a.id,
119
+ name: a.name
120
+ }))), this.trainingType === "pretraining" && this.trainer instanceof c) {
121
+ const { trainDataset: a, validationDataset: o, size: r } = await f(
110
122
  t,
111
123
  this.trainer.tokenizer,
112
124
  this.trainer.datasetBuilder,
113
125
  i?.batchSize || 32,
114
- i?.validationSplit || 0.1
115
- ), h = o * (1 - (i?.validationSplit || 0));
116
- this.trainDataset = e, this.validationDataset = s, this.totalTokens = h, this.options.epochSteps = Math.ceil(
126
+ i?.validationSplit || 0.1,
127
+ i?.maskedLoss ?? !1
128
+ ), h = r * (1 - (i?.validationSplit || 0));
129
+ this.trainDataset = a, this.validationDataset = o, this.totalTokens = h, this.options.epochSteps = Math.ceil(
117
130
  this.totalTokens / ((i?.batchSize || 32) * this.model.config.blockSize)
118
131
  ), this.trainer.updateOptimizer(this.options);
119
- } else if (this.trainingType === "sft" && this.trainer instanceof c) {
132
+ } else if (this.trainingType === "sft" && this.trainer instanceof g) {
120
133
  if (t instanceof Uint16Array)
121
134
  throw new Error("SFT training requires Task[] input");
122
- if (i?.validationSplit && i.validationSplit > 0) {
123
- const e = p(t, i?.validationSplit), s = await this.trainer.datasetBuilder.createSFTDataset(
124
- [e.training],
125
- i?.batchSize || 32,
126
- -100
127
- ), o = await this.trainer.datasetBuilder.createSFTDataset(
128
- [e.validation],
129
- i?.batchSize || 32,
130
- -100
131
- );
132
- this.validationDataset = o, this.trainDataset = s;
133
- } else {
134
- const e = await this.trainer.datasetBuilder.createSFTDataset(
135
- t,
136
- i?.batchSize || 32,
137
- -100
138
- );
139
- this.trainDataset = e;
140
- }
141
- this.totalTokens = t.reduce((e, s) => e + s.length, 0), this.options.epochSteps = Math.ceil(
135
+ const { trainDataset: a, validationDataset: o, size: r } = await f(
136
+ t,
137
+ this.trainer.tokenizer,
138
+ this.trainer.datasetBuilder,
139
+ i?.batchSize || 32,
140
+ i?.validationSplit || 0.1,
141
+ i?.maskedLoss ?? !0
142
+ ), h = r * (1 - (i?.validationSplit || 0));
143
+ this.trainDataset = a, this.validationDataset = o, this.totalTokens = h, this.options.epochSteps = Math.ceil(
142
144
  this.totalTokens / ((i?.batchSize || 32) * this.model.config.blockSize)
143
145
  ), this.trainer.updateOptimizer(this.options);
144
146
  }
145
147
  }
146
148
  configureModel(t) {
147
- const a = t?.sftMode || "full";
149
+ const e = t?.sftMode || "full";
148
150
  if (this.trainingType === "pretraining" && (this.trainer.model.hasLoRA() && this.trainer.model.detachLoRA(), this.trainer.model.weightStore.setTrainable(["*"])), this.trainingType === "sft") {
149
- if (a === "lora") {
151
+ if (e === "lora") {
150
152
  const i = this.trainer.model;
151
- if (t?.loraName)
153
+ if (console.log("Configuring model for LoRA fine-tuning with options:", t), t?.loraName)
152
154
  if (i.hasLoRA(t.loraName)) {
153
155
  if (i.attachLoRA(t.loraName), t.loraConfig) {
154
- const e = i.lora;
155
- (e.alpha !== t.loraConfig.alpha || e.rank !== t.loraConfig.rank) && (i.detachLoRA(), i.deleteLoRA(t.loraName), i.createLoRA(t.loraName, t.loraConfig), i.attachLoRA(t.loraName), console.warn("Resetting LoRA with new configuration."));
156
+ const a = i.lora;
157
+ (a.alpha !== t.loraConfig.alpha || a.rank !== t.loraConfig.rank) && (i.detachLoRA(), i.deleteLoRA(t.loraName), i.createLoRA(t.loraName, t.loraConfig), i.attachLoRA(t.loraName), console.warn("Resetting LoRA with new configuration."));
156
158
  }
157
159
  } else if (t.loraConfig)
158
160
  i.createLoRA(t.loraName, t.loraConfig), i.attachLoRA(t.loraName);
@@ -162,23 +164,23 @@ class f extends m {
162
164
  );
163
165
  else if (t?.loraConfig)
164
166
  if (i.hasLoRA()) {
165
- const e = i.lora;
166
- if (e.alpha !== t.loraConfig.alpha || e.rank !== t.loraConfig.rank) {
167
+ const a = i.lora;
168
+ if (a.alpha !== t.loraConfig.alpha || a.rank !== t.loraConfig.rank) {
167
169
  i.detachLoRA();
168
- const s = t.loraName || d();
169
- i.createLoRA(s, t.loraConfig), i.attachLoRA(s);
170
+ const o = t.loraName || m();
171
+ i.createLoRA(o, t.loraConfig), i.attachLoRA(o);
170
172
  }
171
173
  } else {
172
- const e = t.loraName || d();
173
- i.createLoRA(e, t.loraConfig), i.attachLoRA(e);
174
+ const a = t.loraName || m();
175
+ i.createLoRA(a, t.loraConfig), i.attachLoRA(a);
174
176
  }
175
177
  else if (!i.hasLoRA()) throw new Error("LoRA configuration must be provided for lora SFT mode");
176
178
  } else
177
179
  this.trainer.model.hasLoRA() && this.trainer.model.detachLoRA();
178
- a === "last-layer" ? this.trainer.model.weightStore.setTrainable([
180
+ e === "last-layer" ? this.trainer.model.weightStore.setTrainable([
179
181
  `block_${this.trainer.model.config.nLayer - 1}_*`,
180
182
  "token_embedding"
181
- ]) : a === "full" && this.trainer.model.weightStore.setTrainable(["*"]);
183
+ ]) : e === "full" && this.trainer.model.weightStore.setTrainable(["*"]);
182
184
  }
183
185
  t?.trainableWeights && this.trainer.model.weightStore.setTrainable(t.trainableWeights);
184
186
  }
@@ -187,20 +189,20 @@ class f extends m {
187
189
  if (!this.trainDataset)
188
190
  throw new Error("Dataset not prepared");
189
191
  this.hasTrained || this.trainer.setLearningRate(t?.learningRate || 1e-3), this.hasTrained = !0, this.emit("start"), this.model.metaData.pretrainingSettings = t;
190
- const a = Date.now();
192
+ const e = Date.now();
191
193
  this.log.length > 0 && this.trainer.resumeFromLog(this.log[this.log.length - 1]), this.trainer.setGradientCheckpointing(t?.gradientCheckpointing || !1), this.trainer.setMixedPrecision(t?.mixedPrecision || !1), this.trainer.setLabelSmoothing(t?.labelSmoothing || 0), this.trainer.setDropout(t?.dropout || 0), this.trainer.setLayerDrop(t?.layerDrop || 0), this.configureModel(t), await this.trainer.trainOnDataset(
192
194
  this.trainDataset,
193
195
  {
194
196
  ...t,
195
- onStep: async (e) => {
196
- this.log.push(e), this.progress = {
197
- lastLog: e,
198
- progress: e.totalTokens / this.totalTokens,
199
- remaining: Math.max(0, (this.totalTokens - e.totalTokens) / e.totalTokens * e.duration)
200
- }, this.tokensProcessed = e.totalTokens;
201
- const s = this.listeners("log");
202
- for (const o of s)
203
- await o(e, this.progress);
197
+ onStep: async (a) => {
198
+ this.log.push(a), this.progress = {
199
+ lastLog: a,
200
+ progress: a.totalTokens / this.totalTokens,
201
+ remaining: Math.max(0, (this.totalTokens - a.totalTokens) / a.totalTokens * a.duration)
202
+ }, this.tokensProcessed = a.totalTokens;
203
+ const o = this.listeners("log");
204
+ for (const r of o)
205
+ await r(a, this.progress);
204
206
  }
205
207
  },
206
208
  this.validationDataset
@@ -209,7 +211,7 @@ class f extends m {
209
211
  this.model.metaData.actionLog.push({
210
212
  action: "pretrain",
211
213
  timestamp: i,
212
- duration: i - a,
214
+ duration: i - e,
213
215
  tokensProcessed: this.tokensProcessed,
214
216
  options: t
215
217
  }), this.emit("stop");
@@ -218,12 +220,12 @@ class f extends m {
218
220
  if (!this.trainDataset)
219
221
  throw new Error("Dataset not prepared");
220
222
  this.hasTrained || this.trainer.setLearningRate(t?.learningRate || 1e-3), this.hasTrained = !0, this.emit("start");
221
- const { log: a } = await this.trainer.stepDataset(this.trainDataset, t || {}, this.validationDataset), i = this.listeners("log");
222
- for (const e of i)
223
- await e(a, {
224
- lastLog: a,
225
- progress: a.totalTokens / this.totalTokens,
226
- remaining: Math.max(0, (this.totalTokens - a.totalTokens) / a.totalTokens * a.duration)
223
+ const { log: e } = await this.trainer.stepDataset(this.trainDataset, t || {}, this.validationDataset), i = this.listeners("log");
224
+ for (const a of i)
225
+ await a(e, {
226
+ lastLog: e,
227
+ progress: e.totalTokens / this.totalTokens,
228
+ remaining: Math.max(0, (this.totalTokens - e.totalTokens) / e.totalTokens * e.duration)
227
229
  });
228
230
  this.emit("stop");
229
231
  }
@@ -238,5 +240,5 @@ class f extends m {
238
240
  }
239
241
  }
240
242
  export {
241
- f as default
243
+ u as default
242
244
  };
@@ -1,4 +1,4 @@
1
- import { v as c } from "./index-DSGwv2Yx.js";
1
+ import { x as c } from "./index-CUXkjxiT.js";
2
2
  function i(e, n) {
3
3
  for (let t = 0; t < e.length; ++t)
4
4
  if (e[e.length - t - 1] !== n - 1 - t)
package/dist/backend.js CHANGED
@@ -1,9 +1,9 @@
1
- import { g as o, s as e, r as s } from "./index-DSGwv2Yx.js";
1
+ import { g as o, s as e, r as s } from "./index-CUXkjxiT.js";
2
2
  async function c(t, a) {
3
3
  if (o() !== t) {
4
4
  if (t === "webgpu") {
5
5
  const { registerWebGPUBackend: i } = await import("./patches/webgpu_base.js");
6
- i(a), await import("./index-BQvB7LCC.js"), await import("./ops/webgpu/index.js");
6
+ i(a), await import("./index-CjOWnMXP.js"), await import("./ops/webgpu/index.js");
7
7
  }
8
8
  await e(t), await s(), console.log(`Backend set to ${t}`);
9
9
  }