@genai-fi/nanogpt 0.17.5 → 0.18.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.
- package/dist/Generator.d.ts +2 -15
- package/dist/Generator.js +45 -34
- package/dist/{RealDiv-CGwv0liw.js → RealDiv-ioj6Z-ox.js} +9 -9
- package/dist/{Reshape-BW__R4mZ.js → Reshape-BZC-ebeR.js} +7 -7
- package/dist/{Reshape-CPBkTIH2.js → Reshape-pwprEaej.js} +1 -1
- package/dist/TeachableLLM.d.ts +3 -8
- package/dist/TeachableLLM.js +61 -44
- package/dist/Trainer.d.ts +6 -4
- package/dist/Trainer.js +107 -92
- package/dist/{axis_util-GTVlo58H.js → axis_util-QWWgLjut.js} +1 -1
- package/dist/backend.js +2 -2
- package/dist/{backend_util-GaFarB78.js → backend_util-qwSFfxYx.js} +21 -21
- package/dist/{backend_webgpu-BqASlsbV.js → backend_webgpu-DI2wXEC2.js} +8 -8
- package/dist/{broadcast_to-eS93CCN_.js → broadcast_to-C_EJTVTZ.js} +2 -2
- package/dist/checks/appendCache.js +2 -2
- package/dist/checks/attentionMask.js +5 -5
- package/dist/checks/gelu.js +2 -2
- package/dist/checks/matMulGelu.js +2 -2
- package/dist/checks/normRMS.js +6 -6
- package/dist/checks/normRMSGrad.js +3 -3
- package/dist/checks/packUnpack.js +6 -6
- package/dist/checks/qkv.js +2 -2
- package/dist/checks/rope.js +2 -2
- package/dist/{clip_by_value-DDA7rrcT.js → clip_by_value-CLAD4h_I.js} +1 -1
- package/dist/complex-3DpPEG9B.js +11 -0
- package/dist/{concat-CAQpCret.js → concat-Dqk7Xk7h.js} +5 -5
- package/dist/{concat_util-D18dJ4fD.js → concat_util-C1Mxe27t.js} +1 -1
- package/dist/{dataset-CGGp1z9P.js → dataset-DlqAN81i.js} +3 -3
- package/dist/{dropout_util--NxWuYg2.js → dropout_util-N0z8Os-K.js} +1 -1
- package/dist/{expand_dims-Bkd1YD5x.js → expand_dims-D0rBtgT1.js} +4 -4
- package/dist/{exports_initializers-CYzKLjN7.js → exports_initializers-DIOZQt_L.js} +1 -1
- package/dist/{floor-BQtb-Azg.js → floor-CymuCmTO.js} +1 -1
- package/dist/{gather-qIqEqaGn.js → gather-DEyjXNb1.js} +1 -1
- package/dist/{gelu-B220X1Go.js → gelu-DpTCC3eB.js} +1 -1
- package/dist/{gpgpu_math-BwvV12df.js → gpgpu_math-3bCb5ooU.js} +25 -25
- package/dist/{index-CjOWnMXP.js → index-BQvB7LCC.js} +15 -15
- package/dist/{index-CUXkjxiT.js → index-DSGwv2Yx.js} +33 -33
- package/dist/inference/types.d.ts +16 -0
- package/dist/inference/types.js +1 -0
- package/dist/{kernel_funcs_utils-pq0CK9co.js → kernel_funcs_utils-DGqzNlHT.js} +6 -6
- package/dist/layers/BaseLayer.js +4 -4
- package/dist/layers/CausalSelfAttention.js +6 -6
- package/dist/layers/LoRA.js +4 -4
- package/dist/layers/MLP.js +4 -4
- package/dist/layers/PositionEmbedding.js +5 -5
- package/dist/layers/RMSNorm.js +3 -3
- package/dist/layers/RoPECache.js +4 -4
- package/dist/layers/TiedEmbedding.js +6 -6
- package/dist/layers/TransformerBlock.js +1 -1
- package/dist/layers/WeightStore.js +2 -2
- package/dist/loader/load.d.ts +2 -8
- package/dist/loader/loadTransformers.d.ts +2 -8
- package/dist/loader/loadTransformers.js +14 -12
- package/dist/loader/newZipLoad.d.ts +2 -8
- package/dist/loader/newZipLoad.js +25 -10
- package/dist/loader/oldZipLoad.js +13 -13
- package/dist/loader/save.d.ts +9 -2
- package/dist/loader/save.js +65 -55
- package/dist/loader/types.d.ts +30 -1
- package/dist/main.d.ts +2 -0
- package/dist/main.js +45 -43
- package/dist/{matMul16-BcVC_E62.js → matMul16-BIT70Vya.js} +3 -3
- package/dist/{matMulGelu-JNLZqKQp.js → matMulGelu-CsZnh18H.js} +18 -18
- package/dist/mat_mul-DP86qZtZ.js +11 -0
- package/dist/mod-BXjLYwvM.js +11 -0
- package/dist/models/NanoGPTV1.js +2 -2
- package/dist/models/NanoGPTV2.js +2 -2
- package/dist/models/model.d.ts +3 -2
- package/dist/models/model.js +13 -13
- package/dist/{not_equal-hurPF26l.js → not_equal-CkQKkKZy.js} +15 -15
- package/dist/{ones-BytntneX.js → ones-DbVB5N58.js} +3 -3
- package/dist/ops/adamAdjust.js +3 -3
- package/dist/ops/adamMoments.js +3 -3
- package/dist/ops/add16.js +1 -1
- package/dist/ops/appendCache.js +6 -6
- package/dist/ops/attentionMask.js +3 -3
- package/dist/ops/concat16.js +3 -3
- package/dist/ops/cpu/adamAdjust.js +9 -9
- package/dist/ops/cpu/adamMoments.js +5 -5
- package/dist/ops/cpu/appendCache.js +2 -2
- package/dist/ops/cpu/attentionMask.js +6 -6
- package/dist/ops/cpu/fusedSoftmax.js +4 -4
- package/dist/ops/cpu/gatherSub.js +5 -5
- package/dist/ops/cpu/gelu.js +4 -4
- package/dist/ops/cpu/matMul16.js +2 -2
- package/dist/ops/cpu/matMulGelu.js +7 -7
- package/dist/ops/cpu/matMulMul.js +2 -2
- package/dist/ops/cpu/mulDropout.js +5 -5
- package/dist/ops/cpu/normRMS.js +1 -1
- package/dist/ops/cpu/qkv.js +3 -3
- package/dist/ops/cpu/rope.js +5 -5
- package/dist/ops/cpu/scatterSub.js +5 -5
- package/dist/ops/dot16.js +2 -2
- package/dist/ops/dropout.js +6 -6
- package/dist/ops/dropout16.js +1 -1
- package/dist/ops/gatherSub.js +1 -1
- package/dist/ops/gelu.js +2 -2
- package/dist/ops/globalNorm.js +7 -7
- package/dist/ops/grads/add16.js +1 -1
- package/dist/ops/grads/attentionMask.js +2 -2
- package/dist/ops/grads/dropout16.js +1 -1
- package/dist/ops/grads/gelu.js +2 -2
- package/dist/ops/grads/matMul16.js +3 -3
- package/dist/ops/grads/matMulGelu.js +1 -1
- package/dist/ops/grads/mul16.js +1 -1
- package/dist/ops/grads/normRMS.js +7 -7
- package/dist/ops/grads/pack16.js +3 -3
- package/dist/ops/grads/qkv.js +11 -11
- package/dist/ops/grads/rope.js +2 -2
- package/dist/ops/grads/softmax16.js +1 -1
- package/dist/ops/grads/unpack16.js +2 -2
- package/dist/ops/matMul16.js +3 -3
- package/dist/ops/matMulGelu.js +6 -6
- package/dist/ops/matMulMul.js +3 -3
- package/dist/ops/mul16.js +1 -1
- package/dist/ops/mulDrop.js +3 -3
- package/dist/ops/normRMS.js +4 -4
- package/dist/ops/pack16.js +2 -2
- package/dist/ops/qkv.js +3 -3
- package/dist/ops/reshape16.js +6 -6
- package/dist/ops/rope.js +2 -2
- package/dist/ops/scatterSub.js +1 -1
- package/dist/ops/slice16.js +2 -2
- package/dist/ops/softmax16.js +1 -1
- package/dist/ops/sub16.js +1 -1
- package/dist/ops/sum16.js +6 -6
- package/dist/ops/transpose16.js +3 -3
- package/dist/ops/unpack16.js +2 -2
- package/dist/ops/webgl/adamAdjust.js +2 -2
- package/dist/ops/webgl/adamMoments.js +1 -1
- package/dist/ops/webgl/appendCache.js +1 -1
- package/dist/ops/webgl/attentionMask.js +1 -1
- package/dist/ops/webgl/dropout16.js +1 -1
- package/dist/ops/webgl/fusedSoftmax.js +7 -7
- package/dist/ops/webgl/gatherSub.js +3 -3
- package/dist/ops/webgl/gelu.js +2 -2
- package/dist/ops/webgl/log.js +3 -3
- package/dist/ops/webgl/matMul16.js +13 -13
- package/dist/ops/webgl/matMulGelu.js +4 -4
- package/dist/ops/webgl/matMulMul.js +2 -2
- package/dist/ops/webgl/mulDropout.js +1 -1
- package/dist/ops/webgl/normRMS.js +2 -2
- package/dist/ops/webgl/qkv.js +1 -1
- package/dist/ops/webgl/rope.js +1 -1
- package/dist/ops/webgl/scatterSub.js +2 -2
- package/dist/ops/webgpu/adamAdjust.js +3 -3
- package/dist/ops/webgpu/adamMoments.js +3 -3
- package/dist/ops/webgpu/add16.js +6 -6
- package/dist/ops/webgpu/appendCache.js +3 -3
- package/dist/ops/webgpu/attentionMask.js +2 -2
- package/dist/ops/webgpu/attentionMask32_program.js +2 -2
- package/dist/ops/webgpu/clipScale.js +7 -7
- package/dist/ops/webgpu/concat16.js +5 -5
- package/dist/ops/webgpu/dropout16.js +6 -6
- package/dist/ops/webgpu/gatherSub.js +3 -3
- package/dist/ops/webgpu/gelu.js +8 -8
- package/dist/ops/webgpu/matMul16.js +16 -16
- package/dist/ops/webgpu/matMul16_program.js +2 -2
- package/dist/ops/webgpu/mul16.js +5 -5
- package/dist/ops/webgpu/norm2.js +1 -1
- package/dist/ops/webgpu/normRMS.js +2 -2
- package/dist/ops/webgpu/normRMSGrad.js +4 -4
- package/dist/ops/webgpu/pack16.js +4 -4
- package/dist/ops/webgpu/pack16_program.js +2 -2
- package/dist/ops/webgpu/qkv.js +2 -2
- package/dist/ops/webgpu/rope.js +3 -3
- package/dist/ops/webgpu/scatterSub.js +3 -3
- package/dist/ops/webgpu/slice16.js +4 -4
- package/dist/ops/webgpu/softmax16.js +4 -4
- package/dist/ops/webgpu/softmax16_program.js +2 -2
- package/dist/ops/webgpu/softmax16_subgroup_program.js +2 -2
- package/dist/ops/webgpu/softmax16grad.js +4 -4
- package/dist/ops/webgpu/sub16.js +6 -6
- package/dist/ops/webgpu/sum16.js +3 -3
- package/dist/ops/webgpu/transpose16.js +8 -8
- package/dist/ops/webgpu/transpose16_program.js +2 -2
- package/dist/ops/webgpu/transpose16_shared_program.js +3 -3
- package/dist/ops/webgpu/unpack16.js +3 -3
- package/dist/ops/webgpu/utils/binary_op.js +3 -3
- package/dist/ops/webgpu/utils/reductions.js +5 -5
- package/dist/{ops-CsXeTq1P.js → ops-CURIZSVt.js} +100 -100
- package/dist/{pack16-bqltoUlR.js → pack16-WlOSOuZA.js} +2 -2
- package/dist/patches/webgpu_backend.js +6 -6
- package/dist/patches/webgpu_base.js +1 -1
- package/dist/patches/webgpu_program.js +2 -2
- package/dist/{random_normal-IBRrha8a.js → random_normal-CIm8lk2-.js} +1 -1
- package/dist/{random_width-DN5ZtQkM.js → random_width-B_fVXhGx.js} +131 -131
- package/dist/{range-C-CjF-LI.js → range-BDxO73mk.js} +1 -1
- package/dist/{readers-iz5u3HBo.js → readers-17HLdxVM.js} +2 -2
- package/dist/relu-DTvZKBsZ.js +9 -0
- package/dist/{reshape-BDOuCSNW.js → reshape-BIN71H3p.js} +1 -1
- package/dist/{resize_nearest_neighbor-BojqlfRe.js → resize_nearest_neighbor-C6_0dAnK.js} +41 -41
- package/dist/{rope-0j_f1TPm.js → rope-CC5RjmKU.js} +4 -4
- package/dist/{scatter_nd_util-ByNJaL6I.js → scatter_nd_util-C-x73Cj6.js} +1 -1
- package/dist/{segment_util-Dasb2Zaf.js → segment_util-4zuHV5IG.js} +2 -2
- package/dist/{selu_util-BLhIqRkw.js → selu_util-BXdhy_W6.js} +5 -5
- package/dist/{shared-CagdqkLh.js → shared-DRWDyk9w.js} +6 -6
- package/dist/{shared-3agzAqQ_.js → shared-zTaJ5siv.js} +1 -1
- package/dist/slice-BvItlgXu.js +12 -0
- package/dist/{slice_util-CC35pLmT.js → slice_util-DPY56GzQ.js} +5 -5
- package/dist/{softmax-D4q1LJN7.js → softmax-BLGJqdwx.js} +1 -1
- package/dist/split-BN9LkEgS.js +9 -0
- package/dist/{squeeze-ho4wLUek.js → squeeze-O_YWJpw_.js} +2 -2
- package/dist/{stack-DudVrtmG.js → stack-z6QE7kmP.js} +1 -1
- package/dist/{step-BTxPtq1r.js → step-DQY6_ABw.js} +4 -4
- package/dist/{sum-BpiwSWvg.js → sum-D39FeU5h.js} +3 -3
- package/dist/{tensor-BWFldCso.js → tensor-D8e0Gd7c.js} +1 -1
- package/dist/{tensor1d-LMGMIUlr.js → tensor1d-BMl0eZYV.js} +1 -1
- package/dist/{tensor2d-BnXMKScO.js → tensor2d-DTtQ1QcT.js} +1 -1
- package/dist/{tensor4d-C6UCG_u8.js → tensor4d-Dj4rDssL.js} +1 -1
- package/dist/{tfjs_backend-BGnG-ppu.js → tfjs_backend-Bk3PmK91.js} +65 -65
- package/dist/{tile-CFy-xTO6.js → tile-CsWlVKKz.js} +1 -1
- package/dist/tokeniser/BaseTokeniser.d.ts +4 -1
- package/dist/tokeniser/BaseTokeniser.js +35 -15
- package/dist/tokeniser/CharTokeniser.d.ts +1 -1
- package/dist/tokeniser/CharTokeniser.js +29 -28
- package/dist/tokeniser/bpe.d.ts +1 -1
- package/dist/tokeniser/bpe.js +23 -22
- package/dist/tokeniser/type.d.ts +3 -1
- package/dist/training/AdamW.d.ts +3 -0
- package/dist/training/AdamW.js +59 -30
- package/dist/training/BasicTrainer.d.ts +1 -0
- package/dist/training/BasicTrainer.js +112 -92
- package/dist/training/DatasetBuilder.js +3 -3
- package/dist/training/Evaluator.js +2 -2
- package/dist/training/LRScheduler.d.ts +1 -0
- package/dist/training/LRScheduler.js +18 -12
- package/dist/training/PreTrainer.js +3 -3
- package/dist/training/SFTDatasetBuilder.js +3 -3
- package/dist/training/SFTTrainer.js +1 -1
- package/dist/training/orthoGrad.js +1 -1
- package/dist/training/sparseCrossEntropy.js +30 -30
- package/dist/training/types.d.ts +5 -3
- package/dist/training/validation.js +13 -13
- package/dist/{transpose-9kRxIXWR.js → transpose-Qxz-4os3.js} +7 -7
- package/dist/{unsorted_segment_sum-DJvk5xnh.js → unsorted_segment_sum-BfFVV9Zm.js} +20 -20
- package/dist/utilities/datasetID.d.ts +2 -0
- package/dist/utilities/datasetID.js +21 -0
- package/dist/utilities/dummy.js +6 -6
- package/dist/utilities/multinomialCPU.js +2 -2
- package/dist/utilities/packed.js +1 -1
- package/dist/utilities/performance.js +1 -1
- package/dist/utilities/profile.js +1 -1
- package/dist/utilities/safetensors.js +2 -2
- package/dist/utilities/sentences.js +5 -5
- package/dist/utilities/weights.js +2 -2
- package/dist/{variable-Ck482e3n.js → variable-SSATClyt.js} +1 -1
- package/dist/{webgpu_program-B4HmApL1.js → webgpu_program-CbjdYLYk.js} +1 -1
- package/dist/{webgpu_util-DYlGSwOJ.js → webgpu_util-DuofJBMo.js} +7 -7
- package/dist/{zeros-DvZpK8s6.js → zeros-Bw0puq_w.js} +2 -2
- package/dist/{zeros_like-CWjDdwr-.js → zeros_like-rOHr54NY.js} +69 -69
- package/package.json +3 -3
- package/dist/complex-DI35Q-gW.js +0 -11
- package/dist/mat_mul-DhG0Newp.js +0 -11
- package/dist/mod-CSdCpRjf.js +0 -11
- package/dist/relu-J_X6MUzx.js +0 -9
- package/dist/slice-BzS11Qh0.js +0 -12
- package/dist/split-C2Sj255c.js +0 -9
package/dist/Generator.d.ts
CHANGED
|
@@ -1,21 +1,7 @@
|
|
|
1
1
|
import { Conversation, ITokeniser } from './tokeniser/type';
|
|
2
2
|
import { default as EE } from 'eventemitter3';
|
|
3
3
|
import { default as Model, ModelForwardAttributes } from './models/model';
|
|
4
|
-
|
|
5
|
-
_completed?: boolean;
|
|
6
|
-
_timestamp?: number;
|
|
7
|
-
}
|
|
8
|
-
export interface GenerateOptions {
|
|
9
|
-
temperature?: number;
|
|
10
|
-
topK?: number;
|
|
11
|
-
topP?: number;
|
|
12
|
-
usePadding?: boolean;
|
|
13
|
-
attentionScores?: boolean;
|
|
14
|
-
includeProbabilities?: boolean;
|
|
15
|
-
embeddings?: 'embedding' | 'logits' | 'softmax' | 'all';
|
|
16
|
-
targets?: number[];
|
|
17
|
-
loraName?: string;
|
|
18
|
-
}
|
|
4
|
+
import { GenerateOptions } from './inference/types';
|
|
19
5
|
export declare function isConversation(data: unknown): data is Conversation[];
|
|
20
6
|
export interface IGenerateOptions extends GenerateOptions {
|
|
21
7
|
maxLength?: number;
|
|
@@ -64,6 +50,7 @@ export default class Generator extends EE<'start' | 'stop' | 'tokens' | 'reset'>
|
|
|
64
50
|
private lastMultinomialRand;
|
|
65
51
|
private jobQueue;
|
|
66
52
|
private processingJob;
|
|
53
|
+
private startTime;
|
|
67
54
|
constructor(model: Model<ModelForwardAttributes>, tokeniser: ITokeniser);
|
|
68
55
|
private tokenisePrompt;
|
|
69
56
|
private processResponse;
|
package/dist/Generator.js
CHANGED
|
@@ -1,41 +1,41 @@
|
|
|
1
1
|
import { E as Ui } from "./index-DvYrXKkX.js";
|
|
2
|
-
import { o as Hi,
|
|
3
|
-
import { n as Mc } from "./random_width-
|
|
4
|
-
import { t as Bc } from "./zeros_like-
|
|
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";
|
|
5
5
|
import "./index-Cp39cXWe.js";
|
|
6
|
-
import "./dataset-
|
|
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-
|
|
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";
|
|
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-
|
|
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-
|
|
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-
|
|
12
|
-
import { a as Er, c as Ue } from "./concat_util-
|
|
13
|
-
import { c as Dr, a as Ql, s as Jl } from "./segment_util-
|
|
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";
|
|
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-
|
|
17
|
-
import { S as Ar, a as _r } from "./selu_util-
|
|
18
|
-
import { s as Lr, b as Vr, p as eu, a as tu, i as su, c as nu } from "./slice_util-
|
|
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-
|
|
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-
|
|
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-
|
|
22
|
-
import { R as Nd, r as U, a as Rd } from "./Reshape-
|
|
23
|
-
import { M as qr } from "./matMulGelu-
|
|
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-
|
|
25
|
-
import { z as Od } from "./zeros-
|
|
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";
|
|
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-
|
|
31
|
+
import "./rope-CC5RjmKU.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-
|
|
35
|
+
import "./matMul16-BIT70Vya.js";
|
|
36
36
|
import "./ops/webgl/matMul16.js";
|
|
37
37
|
import "./ops/cpu/matMul16.js";
|
|
38
|
-
import "./pack16-
|
|
38
|
+
import "./pack16-WlOSOuZA.js";
|
|
39
39
|
import "./ops/transpose16.js";
|
|
40
40
|
import "./ops/reshape16.js";
|
|
41
41
|
import "./ops/cpu/qkv.js";
|
|
@@ -50,11 +50,11 @@ import "./ops/grads/add16.js";
|
|
|
50
50
|
import "./jszip.min-BZhlzntC.js";
|
|
51
51
|
import Ad from "./tokeniser/CharTokeniser.js";
|
|
52
52
|
import { SPECIALS as _d } from "./tokeniser/BaseTokeniser.js";
|
|
53
|
-
import { sparseSoftmaxCrossEntropy as Ld } from "./training/sparseCrossEntropy.js";
|
|
54
53
|
import "./ops/cpu/adamAdjust.js";
|
|
55
54
|
import "./ops/webgl/adamAdjust.js";
|
|
56
55
|
import "./ops/cpu/adamMoments.js";
|
|
57
56
|
import "./ops/webgl/adamMoments.js";
|
|
57
|
+
import { sparseSoftmaxCrossEntropy as Ld } from "./training/sparseCrossEntropy.js";
|
|
58
58
|
import "./papaparse.min-C0cScC2i.js";
|
|
59
59
|
import Vd from "./utilities/topP.js";
|
|
60
60
|
import "./ops/cpu/scatterSub.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-
|
|
68
|
+
import "./gelu-DpTCC3eB.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-
|
|
74
|
-
import { t as Kt } from "./tensor2d-
|
|
75
|
-
import { z as Md } from "./unsorted_segment_sum-
|
|
76
|
-
import { s as gs } from "./softmax-
|
|
77
|
-
import { g as Bd } from "./gather-
|
|
78
|
-
import { c as Gd } from "./concat-
|
|
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";
|
|
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)
|
|
@@ -11697,6 +11697,7 @@ class AS extends Ui {
|
|
|
11697
11697
|
lastMultinomialRand = null;
|
|
11698
11698
|
jobQueue = [];
|
|
11699
11699
|
processingJob = !1;
|
|
11700
|
+
startTime = null;
|
|
11700
11701
|
async tokenisePrompt(t, e, n) {
|
|
11701
11702
|
if (e) {
|
|
11702
11703
|
const s = e.length > 0 && e[e.length - 1].role === "assistant";
|
|
@@ -11879,7 +11880,7 @@ class AS extends Ui {
|
|
|
11879
11880
|
this.jobQueue.push({ prompt: n, options: e, resolve: s, reject: o });
|
|
11880
11881
|
});
|
|
11881
11882
|
}
|
|
11882
|
-
this.processingJob = !0;
|
|
11883
|
+
this.processingJob = !0, this.startTime = Date.now();
|
|
11883
11884
|
try {
|
|
11884
11885
|
const s = await this.startJob(n, e);
|
|
11885
11886
|
if (this.processingJob = !1, this.jobQueue.length > 0) {
|
|
@@ -11892,9 +11893,19 @@ class AS extends Ui {
|
|
|
11892
11893
|
}
|
|
11893
11894
|
}
|
|
11894
11895
|
async startJob(t, e) {
|
|
11895
|
-
this.initialise(t, e), this.active = !0, e?.maxLength !== 1 && this.emit("start");
|
|
11896
|
+
this.initialise(t, e), this.active = !0, this.model.metaData.generationSettings = e, e?.maxLength !== 1 && this.emit("start");
|
|
11896
11897
|
const s = await this._generate(e);
|
|
11897
|
-
|
|
11898
|
+
if (this.active = !1, this.startTime !== null) {
|
|
11899
|
+
const o = Date.now(), r = o - this.startTime;
|
|
11900
|
+
this.startTime = null, this.model.metaData.actionLog = this.model.metaData.actionLog || [], this.model.metaData.actionLog.push({
|
|
11901
|
+
action: "generate",
|
|
11902
|
+
timestamp: o,
|
|
11903
|
+
duration: r,
|
|
11904
|
+
tokensProcessed: this.tokens.length,
|
|
11905
|
+
options: e || {}
|
|
11906
|
+
});
|
|
11907
|
+
}
|
|
11908
|
+
return this.emit("stop"), s;
|
|
11898
11909
|
}
|
|
11899
11910
|
getQueueLength() {
|
|
11900
11911
|
return this.jobQueue.length;
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { aE as E, ab as T, ah as O,
|
|
2
|
-
import { r as $ } from "./Reshape-
|
|
3
|
-
import { a as A, b as k, d as C, c as N, e as R } from "./axis_util-
|
|
4
|
-
import { t as
|
|
5
|
-
import { c as j } from "./backend_util-
|
|
6
|
-
import { f as y } from "./gpgpu_math-
|
|
7
|
-
import { g as G, b as L } from "./kernel_funcs_utils-
|
|
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";
|
|
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 =
|
|
302
|
+
const z = U(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:
|
|
325
|
+
kernelName: K,
|
|
326
326
|
backendName: "webgl",
|
|
327
327
|
kernelFunc: te
|
|
328
328
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { R as C,
|
|
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-
|
|
3
|
-
class
|
|
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 {
|
|
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 S {
|
|
|
20
20
|
`;
|
|
21
21
|
}
|
|
22
22
|
this.userCode = `
|
|
23
|
-
${
|
|
23
|
+
${S(i, this.enableShapeUniforms)}
|
|
24
24
|
${this.enableShapeUniforms ? I() : x(t)}
|
|
25
25
|
|
|
26
26
|
void main() {
|
|
@@ -39,7 +39,7 @@ class S {
|
|
|
39
39
|
`;
|
|
40
40
|
}
|
|
41
41
|
}
|
|
42
|
-
function
|
|
42
|
+
function S(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
|
|
61
|
+
], r = new v(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
|
-
|
|
76
|
+
v as R,
|
|
77
77
|
U as a,
|
|
78
78
|
y as r
|
|
79
79
|
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { N as h, aj as d, v as c, R as m } from "./index-DSGwv2Yx.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 };
|
package/dist/TeachableLLM.d.ts
CHANGED
|
@@ -8,14 +8,8 @@ import { default as MemoryProfiler } from './utilities/profile';
|
|
|
8
8
|
import { default as Model, ModelForwardAttributes } from './models/model';
|
|
9
9
|
import { Task } from './training/tasks/Task';
|
|
10
10
|
import { TrainingLogEntry, TrainingOptions } from './training/types';
|
|
11
|
-
import { ModelPhase } from './loader/types';
|
|
11
|
+
import { ModelPhase, TransformersMetadata } from './loader/types';
|
|
12
12
|
type TeachableLLMStatus = 'warmup' | 'awaitingTokens' | 'ready' | 'training' | 'loading' | 'busy' | 'error';
|
|
13
|
-
interface TeachableLLMMeta {
|
|
14
|
-
name?: string;
|
|
15
|
-
id?: string;
|
|
16
|
-
reference?: string;
|
|
17
|
-
[key: string]: unknown;
|
|
18
|
-
}
|
|
19
13
|
export default class TeachableLLM {
|
|
20
14
|
private ee;
|
|
21
15
|
private _config?;
|
|
@@ -23,9 +17,10 @@ export default class TeachableLLM {
|
|
|
23
17
|
private _tokeniser?;
|
|
24
18
|
private _status;
|
|
25
19
|
private _memoryRequirements?;
|
|
26
|
-
meta:
|
|
20
|
+
meta: TransformersMetadata;
|
|
27
21
|
private _trainer;
|
|
28
22
|
constructor(tokeniser?: ITokeniser, model?: Model<ModelForwardAttributes, GPTConfig>);
|
|
23
|
+
get currentTrainer(): Trainer | null;
|
|
29
24
|
get vocab(): string[];
|
|
30
25
|
get phase(): ModelPhase;
|
|
31
26
|
set phase(phase: ModelPhase);
|
package/dist/TeachableLLM.js
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { validateConfig as
|
|
2
|
-
import { saveModel as
|
|
1
|
+
import { validateConfig as l } from "./models/config.js";
|
|
2
|
+
import { saveModel as p } from "./loader/save.js";
|
|
3
3
|
import { loadModel as u } from "./loader/load.js";
|
|
4
|
-
import
|
|
4
|
+
import f from "./Generator.js";
|
|
5
5
|
import h from "./Trainer.js";
|
|
6
|
-
import { E as
|
|
7
|
-
import { dummyPassTrainAsync as
|
|
8
|
-
import "./index-
|
|
9
|
-
import "./random_width-
|
|
10
|
-
import "./zeros_like-
|
|
6
|
+
import { E as c } from "./index-DvYrXKkX.js";
|
|
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";
|
|
11
11
|
import "./index-Cp39cXWe.js";
|
|
12
|
-
import "./dataset-
|
|
12
|
+
import "./dataset-DlqAN81i.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-
|
|
18
|
+
import "./rope-CC5RjmKU.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-
|
|
22
|
+
import "./matMul16-BIT70Vya.js";
|
|
23
23
|
import "./ops/webgl/matMul16.js";
|
|
24
24
|
import "./ops/cpu/matMul16.js";
|
|
25
|
-
import "./pack16-
|
|
25
|
+
import "./pack16-WlOSOuZA.js";
|
|
26
26
|
import "./ops/transpose16.js";
|
|
27
27
|
import "./ops/reshape16.js";
|
|
28
28
|
import "./ops/cpu/qkv.js";
|
|
@@ -34,8 +34,8 @@ import "./ops/grads/normRMS.js";
|
|
|
34
34
|
import "./ops/dropout16.js";
|
|
35
35
|
import "./ops/webgl/dropout16.js";
|
|
36
36
|
import "./ops/grads/add16.js";
|
|
37
|
-
import
|
|
38
|
-
import
|
|
37
|
+
import g from "./tokeniser/CharTokeniser.js";
|
|
38
|
+
import w from "./tokeniser/bpe.js";
|
|
39
39
|
import "./papaparse.min-C0cScC2i.js";
|
|
40
40
|
import "./jszip.min-BZhlzntC.js";
|
|
41
41
|
import "./ops/cpu/gatherSub.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-
|
|
46
|
+
import "./matMulGelu-CsZnh18H.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-
|
|
50
|
+
import "./gelu-DpTCC3eB.js";
|
|
51
51
|
import "./ops/webgl/log.js";
|
|
52
52
|
import "./ops/cpu/adamMoments.js";
|
|
53
53
|
import "./ops/webgl/adamMoments.js";
|
|
@@ -55,19 +55,25 @@ import "./ops/cpu/adamAdjust.js";
|
|
|
55
55
|
import "./ops/webgl/adamAdjust.js";
|
|
56
56
|
import "./checks/normRMS.js";
|
|
57
57
|
import "./checks/normRMSGrad.js";
|
|
58
|
-
import
|
|
59
|
-
import
|
|
60
|
-
class
|
|
61
|
-
ee = new
|
|
58
|
+
import k from "./utilities/profile.js";
|
|
59
|
+
import y from "./models/factory.js";
|
|
60
|
+
class _ {
|
|
61
|
+
ee = new c();
|
|
62
62
|
_config;
|
|
63
63
|
_model;
|
|
64
64
|
_tokeniser;
|
|
65
65
|
_status = "loading";
|
|
66
66
|
_memoryRequirements;
|
|
67
|
-
meta = {
|
|
67
|
+
meta = {
|
|
68
|
+
version: 2,
|
|
69
|
+
application: "@genai-fi/nanogpt"
|
|
70
|
+
};
|
|
68
71
|
_trainer = null;
|
|
69
72
|
constructor(t, i) {
|
|
70
|
-
this._config = i?.config, this._tokeniser = t, this._model = i;
|
|
73
|
+
this._config = i?.config, this._tokeniser = t, this._model = i, i?.metaData && (this.meta = i.metaData);
|
|
74
|
+
}
|
|
75
|
+
get currentTrainer() {
|
|
76
|
+
return this._trainer;
|
|
71
77
|
}
|
|
72
78
|
get vocab() {
|
|
73
79
|
return this._tokeniser?.getVocab() || [];
|
|
@@ -154,32 +160,43 @@ class a {
|
|
|
154
160
|
saveModel(t) {
|
|
155
161
|
if (!this._model || !this._tokeniser)
|
|
156
162
|
throw new Error("model_or_tokeniser_not_initialized.");
|
|
157
|
-
return
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
163
|
+
return p(
|
|
164
|
+
this._model,
|
|
165
|
+
this._tokeniser,
|
|
166
|
+
{
|
|
167
|
+
...t,
|
|
168
|
+
name: t?.name || this.meta.name
|
|
169
|
+
},
|
|
170
|
+
t?.includeOptimizer && this._trainer?.trainingType === "pretraining" ? { optimizer: this._trainer.optimizer, trainingLog: this._trainer.log } : void 0
|
|
171
|
+
);
|
|
161
172
|
}
|
|
162
173
|
static loadModel(t, i) {
|
|
163
|
-
const e = new
|
|
164
|
-
return u(t, i).then(({ model: o, tokeniser:
|
|
165
|
-
|
|
166
|
-
e._memoryRequirements =
|
|
167
|
-
|
|
168
|
-
|
|
174
|
+
const e = new _();
|
|
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) => {
|
|
177
|
+
e._memoryRequirements = m, n && (e._trainer = new h(
|
|
178
|
+
o,
|
|
179
|
+
s,
|
|
180
|
+
"pretraining",
|
|
181
|
+
o.metaData.pretrainingSettings,
|
|
182
|
+
n
|
|
183
|
+
), a && (e._trainer.log = a)), e.setStatus("ready"), e.ee.emit("loaded"), e.ee.emit("phase", e.phase);
|
|
184
|
+
}).catch((m) => {
|
|
185
|
+
e.setStatus("error"), e.ee.emit("error", m), console.error("Error during warmup:", m);
|
|
169
186
|
});
|
|
170
187
|
}).catch((o) => {
|
|
171
188
|
e.setStatus("error"), e.ee.emit("error", o), console.error("Error loading model:", o);
|
|
172
189
|
}), e;
|
|
173
190
|
}
|
|
174
191
|
static create(t, i) {
|
|
175
|
-
|
|
176
|
-
const e = i, o = t === "char" ? new
|
|
177
|
-
return r.setStatus("warmup"),
|
|
178
|
-
r._memoryRequirements =
|
|
179
|
-
|
|
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);
|
|
194
|
+
return r.setStatus("warmup"), d(s).then((n) => {
|
|
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
|
+
a === "trained" && r.setStatus("ready");
|
|
180
197
|
}));
|
|
181
|
-
}).catch((
|
|
182
|
-
r.setStatus("error"), r.ee.emit("error",
|
|
198
|
+
}).catch((n) => {
|
|
199
|
+
r.setStatus("error"), r.ee.emit("error", n), console.error("Error during warmup:", n);
|
|
183
200
|
}), r;
|
|
184
201
|
}
|
|
185
202
|
getProfiler() {
|
|
@@ -192,7 +209,7 @@ class a {
|
|
|
192
209
|
if (t) {
|
|
193
210
|
if (!this._config)
|
|
194
211
|
return;
|
|
195
|
-
this.model.getProfiler() || this.model.setProfiler(new
|
|
212
|
+
this.model.getProfiler() || this.model.setProfiler(new k());
|
|
196
213
|
} else
|
|
197
214
|
this.model.getProfiler() && this.model.setProfiler(null);
|
|
198
215
|
}
|
|
@@ -207,8 +224,8 @@ class a {
|
|
|
207
224
|
return e.on("start", () => {
|
|
208
225
|
this.setStatus("training"), this.phase = t === "sft" ? "finetuned" : "pretrained";
|
|
209
226
|
}), e.on("stop", () => this.setStatus("ready")), e.on("log", async (o) => {
|
|
210
|
-
const
|
|
211
|
-
for (const r of
|
|
227
|
+
const s = this.ee.listeners("trainStep");
|
|
228
|
+
for (const r of s)
|
|
212
229
|
await r(o);
|
|
213
230
|
}), this._trainer && this._trainer !== e && this._trainer.removeAllListeners(), this._trainer = e, e;
|
|
214
231
|
}
|
|
@@ -225,7 +242,7 @@ class a {
|
|
|
225
242
|
generator() {
|
|
226
243
|
if (!this._model || !this._tokeniser)
|
|
227
244
|
throw new Error("model_or_tokeniser_not_initialized.");
|
|
228
|
-
const t = new
|
|
245
|
+
const t = new f(this._model, this._tokeniser);
|
|
229
246
|
return t.on("start", () => {
|
|
230
247
|
this.status === "ready" && this.setStatus("busy");
|
|
231
248
|
}), t.on("stop", () => {
|
|
@@ -252,5 +269,5 @@ class a {
|
|
|
252
269
|
}
|
|
253
270
|
}
|
|
254
271
|
export {
|
|
255
|
-
|
|
272
|
+
_ as default
|
|
256
273
|
};
|
package/dist/Trainer.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ import { default as Model, ModelForwardAttributes } from './models/model';
|
|
|
4
4
|
import { Task } from './training/tasks/Task';
|
|
5
5
|
import { TrainingOptions, TrainingLogEntry } from './training/types';
|
|
6
6
|
import { AdamWOptimizer } from './training/AdamW';
|
|
7
|
+
import { DatasetMetadata } from './loader/types';
|
|
7
8
|
interface TrainingProgress {
|
|
8
9
|
lastLog: TrainingLogEntry;
|
|
9
10
|
progress: number;
|
|
@@ -16,21 +17,22 @@ export default class Trainer extends EE<'start' | 'stop' | 'log'> {
|
|
|
16
17
|
private hasTrained;
|
|
17
18
|
private trainDataset?;
|
|
18
19
|
private validationDataset?;
|
|
19
|
-
private
|
|
20
|
+
private totalTokens;
|
|
21
|
+
private tokensProcessed;
|
|
20
22
|
log: TrainingLogEntry[];
|
|
21
23
|
private progress;
|
|
22
24
|
options: TrainingOptions;
|
|
23
25
|
protected tokenizer: ITokeniser;
|
|
24
|
-
constructor(model: Model<ModelForwardAttributes>, tokeniser: ITokeniser, trainingType?: TrainingType, options?: TrainingOptions);
|
|
26
|
+
constructor(model: Model<ModelForwardAttributes>, tokeniser: ITokeniser, trainingType?: TrainingType, options?: TrainingOptions, optimizer?: AdamWOptimizer);
|
|
25
27
|
constructor(trainer: Trainer, options?: TrainingOptions);
|
|
26
28
|
get model(): Model<ModelForwardAttributes>;
|
|
27
29
|
get optimizer(): AdamWOptimizer;
|
|
28
30
|
stop(): void;
|
|
29
31
|
reset(): void;
|
|
30
32
|
dispose(): void;
|
|
31
|
-
|
|
33
|
+
getTotalTokens(): number;
|
|
32
34
|
setOptions(options: TrainingOptions): void;
|
|
33
|
-
prepare(tasks?: Task[] | Uint16Array): Promise<void>;
|
|
35
|
+
prepare(tasks?: Task[] | Uint16Array, datasets?: DatasetMetadata[]): Promise<void>;
|
|
34
36
|
private configureModel;
|
|
35
37
|
train(): Promise<void>;
|
|
36
38
|
step(options?: TrainingOptions): Promise<void>;
|