@genai-fi/nanogpt 0.19.1 → 0.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +9 -10
- package/dist/Generator.d.ts +0 -82
- package/dist/Generator.js +0 -11941
- package/dist/RealDiv-CGwv0liw.js +0 -365
- package/dist/Reshape-BW__R4mZ.js +0 -79
- package/dist/Reshape-CPBkTIH2.js +0 -14
- package/dist/TeachableLLM.d.ts +0 -70
- package/dist/TeachableLLM.js +0 -273
- package/dist/Trainer.d.ts +0 -43
- package/dist/Trainer.js +0 -244
- package/dist/_commonjsHelpers-ByX85dGu.js +0 -33
- package/dist/axis_util-GTVlo58H.js +0 -55
- package/dist/backend.d.ts +0 -2
- package/dist/backend.js +0 -13
- package/dist/backend_util-GaFarB78.js +0 -425
- package/dist/backend_webgpu-BqASlsbV.js +0 -545
- package/dist/binary_op_util-pKXltfxI.js +0 -192
- package/dist/broadcast_to-eS93CCN_.js +0 -28
- package/dist/checks/appendCache.d.ts +0 -1
- package/dist/checks/appendCache.js +0 -22
- package/dist/checks/attentionMask.d.ts +0 -1
- package/dist/checks/attentionMask.js +0 -37
- package/dist/checks/check.d.ts +0 -9
- package/dist/checks/check.js +0 -20
- package/dist/checks/gelu.d.ts +0 -1
- package/dist/checks/gelu.js +0 -18
- package/dist/checks/index.d.ts +0 -26
- package/dist/checks/index.js +0 -28
- package/dist/checks/matMulGelu.d.ts +0 -1
- package/dist/checks/matMulGelu.js +0 -28
- package/dist/checks/normRMS.d.ts +0 -1
- package/dist/checks/normRMS.js +0 -16
- package/dist/checks/normRMSGrad.d.ts +0 -1
- package/dist/checks/normRMSGrad.js +0 -12
- package/dist/checks/packUnpack.d.ts +0 -1
- package/dist/checks/packUnpack.js +0 -18
- package/dist/checks/qkv.d.ts +0 -1
- package/dist/checks/qkv.js +0 -34
- package/dist/checks/rope.d.ts +0 -1
- package/dist/checks/rope.js +0 -36
- package/dist/checks/weights.d.ts +0 -14
- package/dist/checks/weights.js +0 -31
- package/dist/clip_by_value-DDA7rrcT.js +0 -12
- package/dist/complex-DI35Q-gW.js +0 -11
- package/dist/complex_util-Yc1A_gV1.js +0 -55
- package/dist/concat-CAQpCret.js +0 -17
- package/dist/concat_util-D18dJ4fD.js +0 -22
- package/dist/data/docx.d.ts +0 -2
- package/dist/data/docx.js +0 -15
- package/dist/data/parquet.d.ts +0 -2
- package/dist/data/parquet.js +0 -17
- package/dist/data/pdf.d.ts +0 -2
- package/dist/data/pdf.js +0 -14
- package/dist/data/textLoader.d.ts +0 -7
- package/dist/data/textLoader.js +0 -118
- package/dist/dataset-CGGp1z9P.js +0 -1124
- package/dist/dropout_util--NxWuYg2.js +0 -27
- package/dist/expand_dims-Bkd1YD5x.js +0 -11
- package/dist/exports_initializers-CYzKLjN7.js +0 -7
- package/dist/floor-BQtb-Azg.js +0 -9
- package/dist/gather-qIqEqaGn.js +0 -9
- package/dist/gelu-B220X1Go.js +0 -26
- package/dist/gpgpu_math-BwvV12df.js +0 -2022
- package/dist/index-CUXkjxiT.js +0 -3516
- package/dist/index-CieiGp4Y.js +0 -349
- package/dist/index-CjOWnMXP.js +0 -7308
- package/dist/index-Cp39cXWe.js +0 -1016
- package/dist/index-D5v913EJ.js +0 -4
- package/dist/index-DmeWGGmS.js +0 -1074
- package/dist/index-DvYrXKkX.js +0 -113
- package/dist/index-Ksja3su6.js +0 -151
- package/dist/index-xuotMAFm.js +0 -118
- package/dist/inference/types.d.ts +0 -16
- package/dist/inference/types.js +0 -1
- package/dist/jszip.min-BZhlzntC.js +0 -2313
- package/dist/kernel_funcs_utils-pq0CK9co.js +0 -306
- package/dist/layers/BaseLayer.d.ts +0 -44
- package/dist/layers/BaseLayer.js +0 -74
- package/dist/layers/CausalSelfAttention.d.ts +0 -39
- package/dist/layers/CausalSelfAttention.js +0 -86
- package/dist/layers/LoRA.d.ts +0 -14
- package/dist/layers/LoRA.js +0 -58
- package/dist/layers/MLP.d.ts +0 -17
- package/dist/layers/MLP.js +0 -44
- package/dist/layers/PositionEmbedding.d.ts +0 -8
- package/dist/layers/PositionEmbedding.js +0 -31
- package/dist/layers/RMSNorm.d.ts +0 -12
- package/dist/layers/RMSNorm.js +0 -22
- package/dist/layers/RoPECache.d.ts +0 -18
- package/dist/layers/RoPECache.js +0 -50
- package/dist/layers/TiedEmbedding.d.ts +0 -13
- package/dist/layers/TiedEmbedding.js +0 -36
- package/dist/layers/TransformerBlock.d.ts +0 -27
- package/dist/layers/TransformerBlock.js +0 -40
- package/dist/layers/WeightStore.d.ts +0 -20
- package/dist/layers/WeightStore.js +0 -76
- package/dist/loader/load.d.ts +0 -6
- package/dist/loader/load.js +0 -68
- package/dist/loader/loadHF.d.ts +0 -8
- package/dist/loader/loadHF.js +0 -22
- package/dist/loader/loadTransformers.d.ts +0 -4
- package/dist/loader/loadTransformers.js +0 -44
- package/dist/loader/loadZipMeta.d.ts +0 -3
- package/dist/loader/loadZipMeta.js +0 -16
- package/dist/loader/newZipLoad.d.ts +0 -3
- package/dist/loader/newZipLoad.js +0 -31
- package/dist/loader/oldZipLoad.d.ts +0 -9
- package/dist/loader/oldZipLoad.js +0 -80
- package/dist/loader/save.d.ts +0 -16
- package/dist/loader/save.js +0 -90
- package/dist/loader/types.d.ts +0 -67
- package/dist/loader/types.js +0 -1
- package/dist/main.d.ts +0 -50
- package/dist/main.js +0 -109
- package/dist/matMul16-BcVC_E62.js +0 -80
- package/dist/matMulGelu-JNLZqKQp.js +0 -163
- package/dist/mat_mul-DhG0Newp.js +0 -11
- package/dist/mod-CSdCpRjf.js +0 -11
- package/dist/models/NanoGPTV1.d.ts +0 -16
- package/dist/models/NanoGPTV1.js +0 -99
- package/dist/models/NanoGPTV2.d.ts +0 -16
- package/dist/models/NanoGPTV2.js +0 -90
- package/dist/models/config.d.ts +0 -27
- package/dist/models/config.js +0 -50
- package/dist/models/factory.d.ts +0 -3
- package/dist/models/factory.js +0 -16
- package/dist/models/model.d.ts +0 -44
- package/dist/models/model.js +0 -134
- package/dist/non_max_suppression_impl-B2W7YjZB.js +0 -102
- package/dist/not_equal-hurPF26l.js +0 -64
- package/dist/ones-BytntneX.js +0 -14
- package/dist/ops/adamAdjust.d.ts +0 -2
- package/dist/ops/adamAdjust.js +0 -9
- package/dist/ops/adamMoments.d.ts +0 -2
- package/dist/ops/adamMoments.js +0 -9
- package/dist/ops/add16.d.ts +0 -2
- package/dist/ops/add16.js +0 -9
- package/dist/ops/appendCache.d.ts +0 -2
- package/dist/ops/appendCache.js +0 -22
- package/dist/ops/attentionMask.d.ts +0 -2
- package/dist/ops/attentionMask.js +0 -10
- package/dist/ops/concat16.d.ts +0 -2
- package/dist/ops/concat16.js +0 -9
- package/dist/ops/cpu/adamAdjust.d.ts +0 -1
- package/dist/ops/cpu/adamAdjust.js +0 -18
- package/dist/ops/cpu/adamMoments.d.ts +0 -1
- package/dist/ops/cpu/adamMoments.js +0 -16
- package/dist/ops/cpu/appendCache.d.ts +0 -1
- package/dist/ops/cpu/appendCache.js +0 -23
- package/dist/ops/cpu/attentionMask.d.ts +0 -1
- package/dist/ops/cpu/attentionMask.js +0 -22
- package/dist/ops/cpu/fusedSoftmax.d.ts +0 -9
- package/dist/ops/cpu/fusedSoftmax.js +0 -29
- package/dist/ops/cpu/gatherSub.d.ts +0 -1
- package/dist/ops/cpu/gatherSub.js +0 -18
- package/dist/ops/cpu/gelu.d.ts +0 -1
- package/dist/ops/cpu/gelu.js +0 -40
- package/dist/ops/cpu/matMul16.d.ts +0 -1
- package/dist/ops/cpu/matMul16.js +0 -15
- package/dist/ops/cpu/matMulGelu.d.ts +0 -1
- package/dist/ops/cpu/matMulGelu.js +0 -53
- package/dist/ops/cpu/matMulMul.d.ts +0 -1
- package/dist/ops/cpu/matMulMul.js +0 -23
- package/dist/ops/cpu/mulDropout.d.ts +0 -1
- package/dist/ops/cpu/mulDropout.js +0 -23
- package/dist/ops/cpu/normRMS.d.ts +0 -1
- package/dist/ops/cpu/normRMS.js +0 -39
- package/dist/ops/cpu/qkv.d.ts +0 -5
- package/dist/ops/cpu/qkv.js +0 -41
- package/dist/ops/cpu/rope.d.ts +0 -6
- package/dist/ops/cpu/rope.js +0 -38
- package/dist/ops/cpu/scatterSub.d.ts +0 -1
- package/dist/ops/cpu/scatterSub.js +0 -23
- package/dist/ops/dot16.d.ts +0 -2
- package/dist/ops/dot16.js +0 -42
- package/dist/ops/dropout.d.ts +0 -2
- package/dist/ops/dropout.js +0 -14
- package/dist/ops/dropout16.d.ts +0 -2
- package/dist/ops/dropout16.js +0 -25
- package/dist/ops/gatherSub.d.ts +0 -2
- package/dist/ops/gatherSub.js +0 -9
- package/dist/ops/gelu.d.ts +0 -3
- package/dist/ops/gelu.js +0 -8
- package/dist/ops/globalNorm.d.ts +0 -2
- package/dist/ops/globalNorm.js +0 -13
- package/dist/ops/grads/add16.d.ts +0 -1
- package/dist/ops/grads/add16.js +0 -26
- package/dist/ops/grads/attentionMask.d.ts +0 -1
- package/dist/ops/grads/attentionMask.js +0 -21
- package/dist/ops/grads/dropout16.d.ts +0 -1
- package/dist/ops/grads/dropout16.js +0 -2
- package/dist/ops/grads/gelu.d.ts +0 -2
- package/dist/ops/grads/gelu.js +0 -5
- package/dist/ops/grads/matMul16.d.ts +0 -2
- package/dist/ops/grads/matMul16.js +0 -9
- package/dist/ops/grads/matMulGelu.d.ts +0 -1
- package/dist/ops/grads/matMulGelu.js +0 -17
- package/dist/ops/grads/mul16.d.ts +0 -1
- package/dist/ops/grads/mul16.js +0 -4
- package/dist/ops/grads/normRMS.d.ts +0 -3
- package/dist/ops/grads/normRMS.js +0 -33
- package/dist/ops/grads/pack16.d.ts +0 -2
- package/dist/ops/grads/pack16.js +0 -6
- package/dist/ops/grads/qkv.d.ts +0 -3
- package/dist/ops/grads/qkv.js +0 -34
- package/dist/ops/grads/rope.d.ts +0 -2
- package/dist/ops/grads/rope.js +0 -5
- package/dist/ops/grads/softmax16.d.ts +0 -2
- package/dist/ops/grads/softmax16.js +0 -25
- package/dist/ops/grads/unpack16.d.ts +0 -2
- package/dist/ops/grads/unpack16.js +0 -5
- package/dist/ops/grads/utils.d.ts +0 -4
- package/dist/ops/grads/utils.js +0 -14
- package/dist/ops/log.d.ts +0 -0
- package/dist/ops/log.js +0 -1
- package/dist/ops/matMul16.d.ts +0 -15
- package/dist/ops/matMul16.js +0 -13
- package/dist/ops/matMulGelu.d.ts +0 -3
- package/dist/ops/matMulGelu.js +0 -14
- package/dist/ops/matMulMul.d.ts +0 -2
- package/dist/ops/matMulMul.js +0 -9
- package/dist/ops/mul16.d.ts +0 -2
- package/dist/ops/mul16.js +0 -39
- package/dist/ops/mulDrop.d.ts +0 -2
- package/dist/ops/mulDrop.js +0 -9
- package/dist/ops/normRMS.d.ts +0 -2
- package/dist/ops/normRMS.js +0 -19
- package/dist/ops/pack16.d.ts +0 -2
- package/dist/ops/pack16.js +0 -5
- package/dist/ops/qkv.d.ts +0 -2
- package/dist/ops/qkv.js +0 -10
- package/dist/ops/reshape16.d.ts +0 -2
- package/dist/ops/reshape16.js +0 -41
- package/dist/ops/rope.d.ts +0 -3
- package/dist/ops/rope.js +0 -7
- package/dist/ops/scatterSub.d.ts +0 -2
- package/dist/ops/scatterSub.js +0 -9
- package/dist/ops/slice16.d.ts +0 -2
- package/dist/ops/slice16.js +0 -9
- package/dist/ops/softmax16.d.ts +0 -2
- package/dist/ops/softmax16.js +0 -9
- package/dist/ops/sub16.d.ts +0 -2
- package/dist/ops/sub16.js +0 -8
- package/dist/ops/sum16.d.ts +0 -2
- package/dist/ops/sum16.js +0 -13
- package/dist/ops/transpose16.d.ts +0 -3
- package/dist/ops/transpose16.js +0 -40
- package/dist/ops/unpack16.d.ts +0 -2
- package/dist/ops/unpack16.js +0 -6
- package/dist/ops/webgl/adamAdjust.d.ts +0 -1
- package/dist/ops/webgl/adamAdjust.js +0 -49
- package/dist/ops/webgl/adamMoments.d.ts +0 -1
- package/dist/ops/webgl/adamMoments.js +0 -40
- package/dist/ops/webgl/appendCache.d.ts +0 -1
- package/dist/ops/webgl/appendCache.js +0 -44
- package/dist/ops/webgl/attentionMask.d.ts +0 -1
- package/dist/ops/webgl/attentionMask.js +0 -45
- package/dist/ops/webgl/dropout16.d.ts +0 -1
- package/dist/ops/webgl/dropout16.js +0 -11
- package/dist/ops/webgl/fusedSoftmax.d.ts +0 -11
- package/dist/ops/webgl/fusedSoftmax.js +0 -80
- package/dist/ops/webgl/gatherSub.d.ts +0 -1
- package/dist/ops/webgl/gatherSub.js +0 -27
- package/dist/ops/webgl/gelu.d.ts +0 -2
- package/dist/ops/webgl/gelu.js +0 -50
- package/dist/ops/webgl/log.d.ts +0 -17
- package/dist/ops/webgl/log.js +0 -23
- package/dist/ops/webgl/matMul16.d.ts +0 -1
- package/dist/ops/webgl/matMul16.js +0 -45
- package/dist/ops/webgl/matMulGelu.d.ts +0 -21
- package/dist/ops/webgl/matMulGelu.js +0 -9
- package/dist/ops/webgl/matMulMul.d.ts +0 -14
- package/dist/ops/webgl/matMulMul.js +0 -28
- package/dist/ops/webgl/mulDropout.d.ts +0 -1
- package/dist/ops/webgl/mulDropout.js +0 -41
- package/dist/ops/webgl/normRMS.d.ts +0 -1
- package/dist/ops/webgl/normRMS.js +0 -93
- package/dist/ops/webgl/qkv.d.ts +0 -1
- package/dist/ops/webgl/qkv.js +0 -46
- package/dist/ops/webgl/rope.d.ts +0 -1
- package/dist/ops/webgl/rope.js +0 -56
- package/dist/ops/webgl/scatterSub.d.ts +0 -1
- package/dist/ops/webgl/scatterSub.js +0 -27
- package/dist/ops/webgpu/adamAdjust.d.ts +0 -1
- package/dist/ops/webgpu/adamAdjust.js +0 -57
- package/dist/ops/webgpu/adamMoments.d.ts +0 -1
- package/dist/ops/webgpu/adamMoments.js +0 -60
- package/dist/ops/webgpu/add16.d.ts +0 -1
- package/dist/ops/webgpu/add16.js +0 -13
- package/dist/ops/webgpu/appendCache.d.ts +0 -1
- package/dist/ops/webgpu/appendCache.js +0 -105
- package/dist/ops/webgpu/attentionMask.d.ts +0 -1
- package/dist/ops/webgpu/attentionMask.js +0 -26
- package/dist/ops/webgpu/attentionMask32_program.d.ts +0 -19
- package/dist/ops/webgpu/attentionMask32_program.js +0 -54
- package/dist/ops/webgpu/clipScale.d.ts +0 -1
- package/dist/ops/webgpu/clipScale.js +0 -58
- package/dist/ops/webgpu/concat16.d.ts +0 -19
- package/dist/ops/webgpu/concat16.js +0 -126
- package/dist/ops/webgpu/dropout16.d.ts +0 -1
- package/dist/ops/webgpu/dropout16.js +0 -51
- package/dist/ops/webgpu/gatherSub.d.ts +0 -1
- package/dist/ops/webgpu/gatherSub.js +0 -39
- package/dist/ops/webgpu/gelu.d.ts +0 -14
- package/dist/ops/webgpu/gelu.js +0 -141
- package/dist/ops/webgpu/index.d.ts +0 -0
- package/dist/ops/webgpu/index.js +0 -26
- package/dist/ops/webgpu/matMul16.d.ts +0 -1
- package/dist/ops/webgpu/matMul16.js +0 -65
- package/dist/ops/webgpu/matMul16_program.d.ts +0 -42
- package/dist/ops/webgpu/matMul16_program.js +0 -343
- package/dist/ops/webgpu/mul16.d.ts +0 -1
- package/dist/ops/webgpu/mul16.js +0 -13
- package/dist/ops/webgpu/norm2.d.ts +0 -1
- package/dist/ops/webgpu/norm2.js +0 -76
- package/dist/ops/webgpu/normRMS.d.ts +0 -1
- package/dist/ops/webgpu/normRMS.js +0 -34
- package/dist/ops/webgpu/normRMS16_program.d.ts +0 -10
- package/dist/ops/webgpu/normRMS16_program.js +0 -25
- package/dist/ops/webgpu/normRMS32_program.d.ts +0 -10
- package/dist/ops/webgpu/normRMS32_program.js +0 -25
- package/dist/ops/webgpu/normRMSGrad.d.ts +0 -1
- package/dist/ops/webgpu/normRMSGrad.js +0 -284
- package/dist/ops/webgpu/pack16.d.ts +0 -1
- package/dist/ops/webgpu/pack16.js +0 -18
- package/dist/ops/webgpu/pack16_program.d.ts +0 -19
- package/dist/ops/webgpu/pack16_program.js +0 -92
- package/dist/ops/webgpu/qkv.d.ts +0 -1
- package/dist/ops/webgpu/qkv.js +0 -24
- package/dist/ops/webgpu/rope.d.ts +0 -1
- package/dist/ops/webgpu/rope.js +0 -135
- package/dist/ops/webgpu/scatterSub.d.ts +0 -1
- package/dist/ops/webgpu/scatterSub.js +0 -40
- package/dist/ops/webgpu/slice16.d.ts +0 -7
- package/dist/ops/webgpu/slice16.js +0 -69
- package/dist/ops/webgpu/softmax16.d.ts +0 -17
- package/dist/ops/webgpu/softmax16.js +0 -21
- package/dist/ops/webgpu/softmax16_program.d.ts +0 -13
- package/dist/ops/webgpu/softmax16_program.js +0 -73
- package/dist/ops/webgpu/softmax16_subgroup_program.d.ts +0 -17
- package/dist/ops/webgpu/softmax16_subgroup_program.js +0 -75
- package/dist/ops/webgpu/softmax16grad.d.ts +0 -1
- package/dist/ops/webgpu/softmax16grad.js +0 -37
- package/dist/ops/webgpu/sub16.d.ts +0 -1
- package/dist/ops/webgpu/sub16.js +0 -13
- package/dist/ops/webgpu/sum16.d.ts +0 -1
- package/dist/ops/webgpu/sum16.js +0 -38
- package/dist/ops/webgpu/transpose16.d.ts +0 -1
- package/dist/ops/webgpu/transpose16.js +0 -34
- package/dist/ops/webgpu/transpose16_program.d.ts +0 -16
- package/dist/ops/webgpu/transpose16_program.js +0 -50
- package/dist/ops/webgpu/transpose16_shared_program.d.ts +0 -15
- package/dist/ops/webgpu/transpose16_shared_program.js +0 -70
- package/dist/ops/webgpu/unpack16.d.ts +0 -1
- package/dist/ops/webgpu/unpack16.js +0 -48
- package/dist/ops/webgpu/utils/binary_op.d.ts +0 -35
- package/dist/ops/webgpu/utils/binary_op.js +0 -139
- package/dist/ops/webgpu/utils/deviceInfo.d.ts +0 -7
- package/dist/ops/webgpu/utils/deviceInfo.js +0 -11
- package/dist/ops/webgpu/utils/reductions.d.ts +0 -43
- package/dist/ops/webgpu/utils/reductions.js +0 -275
- package/dist/ops-CsXeTq1P.js +0 -476
- package/dist/pack16-bqltoUlR.js +0 -39
- package/dist/papaparse.min-C0cScC2i.js +0 -418
- package/dist/parquet-Bqjmp2vo.js +0 -44231
- package/dist/patches/webgpu_backend.d.ts +0 -18
- package/dist/patches/webgpu_backend.js +0 -56
- package/dist/patches/webgpu_base.d.ts +0 -21
- package/dist/patches/webgpu_base.js +0 -34
- package/dist/patches/webgpu_program.d.ts +0 -36
- package/dist/patches/webgpu_program.js +0 -400
- package/dist/pdf-NIhmP3sq.js +0 -19477
- package/dist/rand_util-CZ7yLoUm.js +0 -50
- package/dist/random_normal-IBRrha8a.js +0 -14
- package/dist/random_width-DN5ZtQkM.js +0 -9796
- package/dist/range-C-CjF-LI.js +0 -10
- package/dist/relu-J_X6MUzx.js +0 -9
- package/dist/reshape-BDOuCSNW.js +0 -9
- package/dist/resize_nearest_neighbor-BojqlfRe.js +0 -150
- package/dist/rope-DcrZM_e6.js +0 -24
- package/dist/scatter_nd_util-ByNJaL6I.js +0 -46
- package/dist/segment_util-Dasb2Zaf.js +0 -43
- package/dist/selu_util-BLhIqRkw.js +0 -44
- package/dist/shared-3agzAqQ_.js +0 -53
- package/dist/shared-CagdqkLh.js +0 -2143
- package/dist/slice-BzS11Qh0.js +0 -12
- package/dist/slice_util-CC35pLmT.js +0 -153
- package/dist/softmax-D4q1LJN7.js +0 -12
- package/dist/split-C2Sj255c.js +0 -9
- package/dist/squeeze-ho4wLUek.js +0 -10
- package/dist/stack-DudVrtmG.js +0 -11
- package/dist/step-BTxPtq1r.js +0 -261
- package/dist/sum-BpiwSWvg.js +0 -11
- package/dist/tensor-BWFldCso.js +0 -8
- package/dist/tensor1d-LMGMIUlr.js +0 -11
- package/dist/tensor2d-BnXMKScO.js +0 -14
- package/dist/tensor4d-C6UCG_u8.js +0 -14
- package/dist/tfjs_backend-BGnG-ppu.js +0 -654
- package/dist/tile-CFy-xTO6.js +0 -11
- package/dist/tokeniser/BaseTokeniser.d.ts +0 -33
- package/dist/tokeniser/BaseTokeniser.js +0 -124
- package/dist/tokeniser/CharTokeniser.d.ts +0 -24
- package/dist/tokeniser/CharTokeniser.js +0 -107
- package/dist/tokeniser/bpe.d.ts +0 -28
- package/dist/tokeniser/bpe.js +0 -173
- package/dist/tokeniser/messages.d.ts +0 -61
- package/dist/tokeniser/messages.js +0 -1
- package/dist/tokeniser/type.d.ts +0 -34
- package/dist/tokeniser/type.js +0 -1
- package/dist/training/AdamW.d.ts +0 -36
- package/dist/training/AdamW.js +0 -138
- package/dist/training/BasicTrainer.d.ts +0 -63
- package/dist/training/BasicTrainer.js +0 -265
- package/dist/training/DatasetBuilder.d.ts +0 -26
- package/dist/training/DatasetBuilder.js +0 -86
- package/dist/training/Evaluator.d.ts +0 -19
- package/dist/training/Evaluator.js +0 -39
- package/dist/training/LRScheduler.d.ts +0 -12
- package/dist/training/LRScheduler.js +0 -34
- package/dist/training/PreTrainer.d.ts +0 -11
- package/dist/training/PreTrainer.js +0 -20
- package/dist/training/SFTTrainer.d.ts +0 -12
- package/dist/training/SFTTrainer.js +0 -22
- package/dist/training/loss.d.ts +0 -3
- package/dist/training/loss.js +0 -24
- package/dist/training/orthoGrad.d.ts +0 -2
- package/dist/training/orthoGrad.js +0 -10
- package/dist/training/sparseCrossEntropy.d.ts +0 -7
- package/dist/training/sparseCrossEntropy.js +0 -69
- package/dist/training/tasks/ConversationTask.d.ts +0 -18
- package/dist/training/tasks/ConversationTask.js +0 -40
- package/dist/training/tasks/PretrainingTask.d.ts +0 -17
- package/dist/training/tasks/PretrainingTask.js +0 -47
- package/dist/training/tasks/StartSentenceTask.d.ts +0 -18
- package/dist/training/tasks/StartSentenceTask.js +0 -49
- package/dist/training/tasks/Task.d.ts +0 -22
- package/dist/training/tasks/Task.js +0 -68
- package/dist/training/tasks/splitter.d.ts +0 -5
- package/dist/training/tasks/splitter.js +0 -21
- package/dist/training/types.d.ts +0 -78
- package/dist/training/types.js +0 -1
- package/dist/training/validation.d.ts +0 -17
- package/dist/training/validation.js +0 -84
- package/dist/transpose-9kRxIXWR.js +0 -36
- package/dist/unsorted_segment_sum-DJvk5xnh.js +0 -277
- package/dist/utilities/arrayClose.d.ts +0 -1
- package/dist/utilities/arrayClose.js +0 -20
- package/dist/utilities/datasetID.d.ts +0 -2
- package/dist/utilities/datasetID.js +0 -21
- package/dist/utilities/dummy.d.ts +0 -9
- package/dist/utilities/dummy.js +0 -43
- package/dist/utilities/multinomialCPU.d.ts +0 -2
- package/dist/utilities/multinomialCPU.js +0 -13
- package/dist/utilities/naming.d.ts +0 -4
- package/dist/utilities/naming.js +0 -1
- package/dist/utilities/packed.d.ts +0 -4
- package/dist/utilities/packed.js +0 -15
- package/dist/utilities/parameters.d.ts +0 -11
- package/dist/utilities/parameters.js +0 -57
- package/dist/utilities/performance.d.ts +0 -2
- package/dist/utilities/performance.js +0 -16
- package/dist/utilities/profile.d.ts +0 -17
- package/dist/utilities/profile.js +0 -38
- package/dist/utilities/safetensors.d.ts +0 -3
- package/dist/utilities/safetensors.js +0 -83
- package/dist/utilities/sentences.d.ts +0 -5
- package/dist/utilities/sentences.js +0 -41
- package/dist/utilities/tokenParse.d.ts +0 -1
- package/dist/utilities/tokenParse.js +0 -21
- package/dist/utilities/topP.d.ts +0 -1
- package/dist/utilities/topP.js +0 -13
- package/dist/utilities/waitForModel.d.ts +0 -2
- package/dist/utilities/waitForModel.js +0 -12
- package/dist/utilities/weights.d.ts +0 -12
- package/dist/utilities/weights.js +0 -45
- package/dist/utilities/yielder.d.ts +0 -1
- package/dist/utilities/yielder.js +0 -7
- package/dist/variable-Ck482e3n.js +0 -7
- package/dist/webgpu_program-B4HmApL1.js +0 -525
- package/dist/webgpu_util-DYlGSwOJ.js +0 -64
- package/dist/zeros-DvZpK8s6.js +0 -13
- package/dist/zeros_like-CWjDdwr-.js +0 -721
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { default as Model, ModelForwardAttributes } from '../models/model';
|
|
2
|
-
import { default as BasicTrainer } from './BasicTrainer';
|
|
3
|
-
import { ITokeniser } from '../tokeniser/type';
|
|
4
|
-
import { DatasetBuilder } from './DatasetBuilder';
|
|
5
|
-
import { AdamWOptimizer } from './AdamW';
|
|
6
|
-
import { AdamWOptimizerConfig } from './types';
|
|
7
|
-
export default class PreTrainer extends BasicTrainer {
|
|
8
|
-
tokenizer: ITokeniser;
|
|
9
|
-
datasetBuilder: DatasetBuilder;
|
|
10
|
-
constructor(model: Model<ModelForwardAttributes>, tokenizer: ITokeniser, optConfig?: Partial<AdamWOptimizerConfig>, optimizer?: AdamWOptimizer);
|
|
11
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import r from "./BasicTrainer.js";
|
|
2
|
-
import { DatasetBuilder as n } from "./DatasetBuilder.js";
|
|
3
|
-
const s = {
|
|
4
|
-
decayEpochs: 100,
|
|
5
|
-
epochSteps: 1e4,
|
|
6
|
-
warmupSteps: 1e3,
|
|
7
|
-
minLearningRate: 3e-5,
|
|
8
|
-
weightDecay: 0.1,
|
|
9
|
-
learningRate: 3e-4
|
|
10
|
-
// clipNorm: 1.0,
|
|
11
|
-
};
|
|
12
|
-
class m extends r {
|
|
13
|
-
constructor(i, e, t, a) {
|
|
14
|
-
super(i, e, { ...s, ...t }, a), this.tokenizer = e, this.optimizerConfig.minLearningRate = t?.minLearningRate ?? this.optimizerConfig.learningRate / 20, this.updateOptimizer(), this.datasetBuilder = new n(e, i.config.blockSize);
|
|
15
|
-
}
|
|
16
|
-
datasetBuilder;
|
|
17
|
-
}
|
|
18
|
-
export {
|
|
19
|
-
m as default
|
|
20
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { default as Model, ModelForwardAttributes } from '../models/model';
|
|
2
|
-
import { default as BasicTrainer } from './BasicTrainer';
|
|
3
|
-
import { ITokeniser } from '../tokeniser/type';
|
|
4
|
-
import { AdamWOptimizer } from './AdamW';
|
|
5
|
-
import { AdamWOptimizerConfig } from './types';
|
|
6
|
-
import { DatasetBuilder } from './DatasetBuilder';
|
|
7
|
-
export default class SFTTrainer extends BasicTrainer {
|
|
8
|
-
tokenizer: ITokeniser;
|
|
9
|
-
datasetBuilder: DatasetBuilder;
|
|
10
|
-
loraName?: string;
|
|
11
|
-
constructor(model: Model<ModelForwardAttributes>, tokenizer: ITokeniser, optConfig?: Partial<AdamWOptimizerConfig>, optimizer?: AdamWOptimizer);
|
|
12
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import r from "./BasicTrainer.js";
|
|
2
|
-
import { DatasetBuilder as s } from "./DatasetBuilder.js";
|
|
3
|
-
const n = {
|
|
4
|
-
decayEpochs: 100,
|
|
5
|
-
epochSteps: 1e4,
|
|
6
|
-
warmupSteps: 100,
|
|
7
|
-
minLearningRate: 1e-5,
|
|
8
|
-
weightDecay: 0.1,
|
|
9
|
-
beta2: 0.95,
|
|
10
|
-
learningRate: 3e-4
|
|
11
|
-
// clipNorm: 1.0,
|
|
12
|
-
};
|
|
13
|
-
class c extends r {
|
|
14
|
-
constructor(t, e, i, a) {
|
|
15
|
-
super(t, e, { ...n, ...i }, a), this.tokenizer = e, this.optimizerConfig.minLearningRate = i?.minLearningRate ?? this.optimizerConfig.learningRate / 20, this.updateOptimizer(), this.datasetBuilder = new s(e, t.config.blockSize), this.maskedLoss = !0;
|
|
16
|
-
}
|
|
17
|
-
datasetBuilder;
|
|
18
|
-
loraName;
|
|
19
|
-
}
|
|
20
|
-
export {
|
|
21
|
-
c as default
|
|
22
|
-
};
|
package/dist/training/loss.d.ts
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { Tensor } from '@tensorflow/tfjs-core';
|
|
2
|
-
export declare function calculateLoss(logits: Tensor, targets: Tensor, masked?: boolean, keepBatch?: boolean, labelSmoothing?: number): Tensor;
|
|
3
|
-
export declare function calculateAccuracy(logits: Tensor, targets: Tensor): Tensor;
|
package/dist/training/loss.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { createSoftmaxCrossEntropyWithGrad as n } from "./sparseCrossEntropy.js";
|
|
2
|
-
function i(t, s, r, c, o) {
|
|
3
|
-
try {
|
|
4
|
-
return n(
|
|
5
|
-
r,
|
|
6
|
-
c,
|
|
7
|
-
o && o > 0 ? o : void 0
|
|
8
|
-
)(t, s);
|
|
9
|
-
} catch (a) {
|
|
10
|
-
throw console.error("Error computing loss:", a), new Error(`Loss computation failed: ${a}`);
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
function l(t, s) {
|
|
14
|
-
try {
|
|
15
|
-
const r = t.argMax(-1), c = r.equal(s).cast("float32"), o = c.mean();
|
|
16
|
-
return r.dispose(), c.dispose(), o;
|
|
17
|
-
} catch (r) {
|
|
18
|
-
throw console.error("Error computing accuracy:", r), new Error(`Accuracy computation failed: ${r}`);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
export {
|
|
22
|
-
l as calculateAccuracy,
|
|
23
|
-
i as calculateLoss
|
|
24
|
-
};
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { t as d } from "../index-CUXkjxiT.js";
|
|
2
|
-
function l(m, t, s) {
|
|
3
|
-
return d(() => {
|
|
4
|
-
const r = m.reshape([-1]), o = t.reshape([-1]), e = r.mul(r).sum().add(s), c = r.mul(o).sum().div(e), n = o.sub(r.mul(c)), a = o.norm(), u = n.norm().add(s);
|
|
5
|
-
return n.mul(a.div(u)).reshape(t.shape);
|
|
6
|
-
});
|
|
7
|
-
}
|
|
8
|
-
export {
|
|
9
|
-
l as orthogonalizeGradient
|
|
10
|
-
};
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import * as tf from '@tensorflow/tfjs-core';
|
|
2
|
-
/**
|
|
3
|
-
* Numerically stable sparse cross-entropy with gradient support
|
|
4
|
-
* This version handles potential numerical issues better
|
|
5
|
-
*/
|
|
6
|
-
export declare function sparseSoftmaxCrossEntropy(logits: tf.Tensor, labels: tf.Tensor, validMask?: tf.Tensor, keepBatch?: boolean, originalBatchShape?: number[], labelSmoothing?: number): tf.Tensor;
|
|
7
|
-
export declare function createSoftmaxCrossEntropyWithGrad(masked?: boolean, keepBatch?: boolean, labelSmoothing?: number): (...args: tf.Tensor[]) => tf.Tensor<tf.Rank>;
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { gatherSub as $ } from "../ops/gatherSub.js";
|
|
2
|
-
import { scatterSub as T } from "../ops/scatterSub.js";
|
|
3
|
-
import { t as F, a1 as G, j as A, m as x, i as U, a2 as D, a as j, a3 as q } from "../index-CUXkjxiT.js";
|
|
4
|
-
import { m as J, l as K, a as E, n as N, w as O } from "../not_equal-hurPF26l.js";
|
|
5
|
-
import { s as m } from "../sum-BpiwSWvg.js";
|
|
6
|
-
import { s as Q } from "../softmax-D4q1LJN7.js";
|
|
7
|
-
function R(e, l, a, g, v, t = 0) {
|
|
8
|
-
return F(() => {
|
|
9
|
-
const S = e.shape[e.shape.length - 1], i = v || e.shape.slice(0, -1), f = i.reduce((c, d) => c * d, 1), h = e.shape.length > 2 ? e.reshape([f, S]) : e, y = l.shape.length > 1 ? l.reshape([f]).cast("int32") : l.cast("int32"), u = J(h, -1, !0), o = G(h, u), n = K(o, -1), p = $(n, y, o);
|
|
10
|
-
let s;
|
|
11
|
-
if (t > 0) {
|
|
12
|
-
const c = G(n, E(o, -1));
|
|
13
|
-
s = A(x(p, 1 - t), x(c, t));
|
|
14
|
-
} else
|
|
15
|
-
s = p;
|
|
16
|
-
if (a)
|
|
17
|
-
if (s = x(s, a), g) {
|
|
18
|
-
const c = m(a.reshape(i), -1);
|
|
19
|
-
s = U(m(s.reshape(i), -1), c);
|
|
20
|
-
} else {
|
|
21
|
-
const c = m(a);
|
|
22
|
-
s = U(m(s), c);
|
|
23
|
-
}
|
|
24
|
-
else
|
|
25
|
-
g ? s = E(s.reshape(i), -1) : s = E(s);
|
|
26
|
-
return s;
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
function as(e, l, a = 0) {
|
|
30
|
-
return D(
|
|
31
|
-
// @ts-expect-error Invalid params
|
|
32
|
-
(t, S, i) => {
|
|
33
|
-
const f = t.shape[t.shape.length - 1], h = t.shape.slice(0, -1), y = h.reduce((d, r) => d * r, 1), u = t.reshape([y, f]), o = S.reshape([y]).cast("int32");
|
|
34
|
-
let n, p = null;
|
|
35
|
-
if (e) {
|
|
36
|
-
const d = j(65535, "int32"), r = N(o, d);
|
|
37
|
-
p = r.cast("float32"), n = O(r, o, q(o)), d.dispose(), r.dispose();
|
|
38
|
-
} else
|
|
39
|
-
n = o;
|
|
40
|
-
const s = R(
|
|
41
|
-
u,
|
|
42
|
-
n,
|
|
43
|
-
p || void 0,
|
|
44
|
-
l,
|
|
45
|
-
h,
|
|
46
|
-
a
|
|
47
|
-
);
|
|
48
|
-
return i(p ? [u, n, p] : [u, n]), u.dispose(), o.dispose(), { value: s, gradFunc: (d, r) => F(() => {
|
|
49
|
-
const C = r[0], z = r[1], b = e ? r[2] : void 0, w = Q(C), H = b ? m(b) : j(C.shape[0], "float32"), I = d.div(H).broadcastTo([C.shape[0]]), M = b && e ? x(I, b) : I;
|
|
50
|
-
let L;
|
|
51
|
-
if (a > 0) {
|
|
52
|
-
const V = a / f, W = G(w, V);
|
|
53
|
-
L = T(
|
|
54
|
-
W,
|
|
55
|
-
z,
|
|
56
|
-
x(M, 1 - a)
|
|
57
|
-
);
|
|
58
|
-
} else
|
|
59
|
-
L = T(w, z, M);
|
|
60
|
-
const P = q(S);
|
|
61
|
-
return [L.reshape(t.shape), P];
|
|
62
|
-
}) };
|
|
63
|
-
}
|
|
64
|
-
);
|
|
65
|
-
}
|
|
66
|
-
export {
|
|
67
|
-
as as createSoftmaxCrossEntropyWithGrad,
|
|
68
|
-
R as sparseSoftmaxCrossEntropy
|
|
69
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Conversation, ITokeniser } from '../../main';
|
|
2
|
-
import { Task } from './Task';
|
|
3
|
-
export default class ConversationTask extends Task {
|
|
4
|
-
private rawConvo;
|
|
5
|
-
private shuffledIndices;
|
|
6
|
-
private index;
|
|
7
|
-
get length(): number;
|
|
8
|
-
constructor(conversations: Conversation[][]);
|
|
9
|
-
hasMoreConversations(): boolean;
|
|
10
|
-
nextConversation(): Conversation[] | null;
|
|
11
|
-
nextTokens(tokeniser: ITokeniser): number[] | null;
|
|
12
|
-
nextTokens(tokeniser: ITokeniser, masking: boolean): {
|
|
13
|
-
tokens: number[];
|
|
14
|
-
mask: boolean[];
|
|
15
|
-
} | null;
|
|
16
|
-
shuffle(): void;
|
|
17
|
-
estimateTokens(tokeniser: ITokeniser): Promise<number>;
|
|
18
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { Task as t } from "./Task.js";
|
|
2
|
-
import { shuffle as i } from "../DatasetBuilder.js";
|
|
3
|
-
class f extends t {
|
|
4
|
-
rawConvo;
|
|
5
|
-
shuffledIndices = null;
|
|
6
|
-
index = 0;
|
|
7
|
-
get length() {
|
|
8
|
-
return this.rawConvo.length;
|
|
9
|
-
}
|
|
10
|
-
constructor(n) {
|
|
11
|
-
super(), this.rawConvo = n;
|
|
12
|
-
}
|
|
13
|
-
hasMoreConversations() {
|
|
14
|
-
return this.index < this.rawConvo.length;
|
|
15
|
-
}
|
|
16
|
-
nextConversation() {
|
|
17
|
-
if (this.index >= this.rawConvo.length)
|
|
18
|
-
return null;
|
|
19
|
-
const n = this.rawConvo[this.shuffledIndices ? this.shuffledIndices[this.index] : this.index];
|
|
20
|
-
return this.index++, n;
|
|
21
|
-
}
|
|
22
|
-
nextTokens(n, s) {
|
|
23
|
-
const e = this.nextConversation();
|
|
24
|
-
return e ? n.encodeConversation(e, !1, s) : null;
|
|
25
|
-
}
|
|
26
|
-
shuffle() {
|
|
27
|
-
if (!this.shuffledIndices) {
|
|
28
|
-
this.shuffledIndices = new Uint32Array(this.rawConvo.length);
|
|
29
|
-
for (let n = 0; n < this.rawConvo.length; n++)
|
|
30
|
-
this.shuffledIndices[n] = n;
|
|
31
|
-
}
|
|
32
|
-
i(this.shuffledIndices), this.index = 0;
|
|
33
|
-
}
|
|
34
|
-
async estimateTokens(n) {
|
|
35
|
-
return n.encodeConversation(this.rawConvo[0]).length * this.length;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
export {
|
|
39
|
-
f as default
|
|
40
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { Conversation, ITokeniser } from '../../main';
|
|
2
|
-
import { Task } from './Task';
|
|
3
|
-
export default class PretrainingTask extends Task {
|
|
4
|
-
private rawText;
|
|
5
|
-
private index;
|
|
6
|
-
get length(): number;
|
|
7
|
-
constructor(texts: string[]);
|
|
8
|
-
hasMoreConversations(): boolean;
|
|
9
|
-
nextConversation(): Conversation[] | null;
|
|
10
|
-
nextTokens(tokeniser: ITokeniser): number[] | null;
|
|
11
|
-
nextTokens(tokeniser: ITokeniser, masking: boolean): {
|
|
12
|
-
tokens: number[];
|
|
13
|
-
mask: boolean[];
|
|
14
|
-
} | null;
|
|
15
|
-
shuffle(): void;
|
|
16
|
-
estimateTokens(tokeniser: ITokeniser): Promise<number>;
|
|
17
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { Task as r } from "./Task.js";
|
|
2
|
-
class h extends r {
|
|
3
|
-
rawText;
|
|
4
|
-
index = 0;
|
|
5
|
-
get length() {
|
|
6
|
-
return this.rawText.length;
|
|
7
|
-
}
|
|
8
|
-
constructor(t) {
|
|
9
|
-
super(), this.rawText = t;
|
|
10
|
-
}
|
|
11
|
-
hasMoreConversations() {
|
|
12
|
-
return this.index < this.rawText.length;
|
|
13
|
-
}
|
|
14
|
-
nextConversation() {
|
|
15
|
-
if (this.index >= this.rawText.length)
|
|
16
|
-
return null;
|
|
17
|
-
const t = {
|
|
18
|
-
role: "assistant",
|
|
19
|
-
content: this.rawText[this.index]
|
|
20
|
-
};
|
|
21
|
-
return this.index++, [t];
|
|
22
|
-
}
|
|
23
|
-
nextTokens(t, n) {
|
|
24
|
-
if (this.index >= this.rawText.length)
|
|
25
|
-
return null;
|
|
26
|
-
const e = t.encodeSequence(this.rawText[this.index]);
|
|
27
|
-
if (this.index++, n) {
|
|
28
|
-
const s = new Array(e.length).fill(!0);
|
|
29
|
-
return { tokens: e, mask: s };
|
|
30
|
-
}
|
|
31
|
-
return e;
|
|
32
|
-
}
|
|
33
|
-
shuffle() {
|
|
34
|
-
this.index = 0;
|
|
35
|
-
}
|
|
36
|
-
async estimateTokens(t) {
|
|
37
|
-
return t.encodeConversation([
|
|
38
|
-
{
|
|
39
|
-
role: "assistant",
|
|
40
|
-
content: this.rawText[0]
|
|
41
|
-
}
|
|
42
|
-
]).length * this.length;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
export {
|
|
46
|
-
h as default
|
|
47
|
-
};
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Conversation, ITokeniser } from '../../main';
|
|
2
|
-
import { Task } from './Task';
|
|
3
|
-
export default class StartSentenceTask extends Task {
|
|
4
|
-
private rawText;
|
|
5
|
-
private index;
|
|
6
|
-
get length(): number;
|
|
7
|
-
constructor(texts: string[]);
|
|
8
|
-
hasMoreConversations(): boolean;
|
|
9
|
-
nextConversation(): Conversation[] | null;
|
|
10
|
-
nextTokens(tokeniser: ITokeniser): number[] | null;
|
|
11
|
-
nextTokens(tokeniser: ITokeniser, masking: boolean): {
|
|
12
|
-
tokens: number[];
|
|
13
|
-
mask: boolean[];
|
|
14
|
-
} | null;
|
|
15
|
-
shuffle(): void;
|
|
16
|
-
private conversationFromString;
|
|
17
|
-
estimateTokens(tokeniser: ITokeniser): Promise<number>;
|
|
18
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { Task as r } from "./Task.js";
|
|
2
|
-
class a extends r {
|
|
3
|
-
rawText;
|
|
4
|
-
index = 0;
|
|
5
|
-
get length() {
|
|
6
|
-
return this.rawText.length;
|
|
7
|
-
}
|
|
8
|
-
constructor(t) {
|
|
9
|
-
super(), this.rawText = t;
|
|
10
|
-
}
|
|
11
|
-
hasMoreConversations() {
|
|
12
|
-
return this.index < this.rawText.length;
|
|
13
|
-
}
|
|
14
|
-
nextConversation() {
|
|
15
|
-
if (this.index >= this.rawText.length)
|
|
16
|
-
return null;
|
|
17
|
-
const t = this.rawText[this.index];
|
|
18
|
-
return this.index++, this.conversationFromString(t);
|
|
19
|
-
}
|
|
20
|
-
nextTokens(t, n) {
|
|
21
|
-
const e = this.nextConversation();
|
|
22
|
-
return e ? t.encodeConversation(e, !1, n) : null;
|
|
23
|
-
}
|
|
24
|
-
shuffle() {
|
|
25
|
-
this.index = 0;
|
|
26
|
-
}
|
|
27
|
-
conversationFromString(t) {
|
|
28
|
-
const n = t.indexOf(".");
|
|
29
|
-
return n === -1 ? [{
|
|
30
|
-
role: "assistant",
|
|
31
|
-
content: this.rawText[this.index]
|
|
32
|
-
}] : [
|
|
33
|
-
{
|
|
34
|
-
role: "user",
|
|
35
|
-
content: t.slice(0, n + 1).trim()
|
|
36
|
-
},
|
|
37
|
-
{
|
|
38
|
-
role: "assistant",
|
|
39
|
-
content: t.slice(n + 1).trim()
|
|
40
|
-
}
|
|
41
|
-
];
|
|
42
|
-
}
|
|
43
|
-
async estimateTokens(t) {
|
|
44
|
-
return (await t.encodeConversation(this.conversationFromString(this.rawText[0]))).length * this.length;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
export {
|
|
48
|
-
a as default
|
|
49
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Conversation, ITokeniser } from '../../main';
|
|
2
|
-
export declare abstract class Task {
|
|
3
|
-
abstract get length(): number;
|
|
4
|
-
abstract hasMoreConversations(): boolean;
|
|
5
|
-
abstract nextConversation(): Conversation[] | null;
|
|
6
|
-
abstract nextTokens(tokeniser: ITokeniser): number[] | null;
|
|
7
|
-
abstract nextTokens(tokeniser: ITokeniser, masking: boolean): {
|
|
8
|
-
tokens: number[];
|
|
9
|
-
mask: boolean[];
|
|
10
|
-
} | null;
|
|
11
|
-
abstract nextTokens(tokeniser: ITokeniser, masking?: boolean): number[] | {
|
|
12
|
-
tokens: number[];
|
|
13
|
-
mask: boolean[];
|
|
14
|
-
} | null;
|
|
15
|
-
abstract estimateTokens(tokeniser: ITokeniser): Promise<number>;
|
|
16
|
-
abstract shuffle(): void;
|
|
17
|
-
}
|
|
18
|
-
export declare function tokensFromTasks(tasks: Task[], tokenizer: ITokeniser, cb?: (tokens: number) => void): Promise<Uint16Array>;
|
|
19
|
-
export declare function tokensFromTasks(tasks: Task[], tokenizer: ITokeniser, cb?: (tokens: number) => void, masking?: boolean): Promise<{
|
|
20
|
-
tokens: Uint16Array;
|
|
21
|
-
mask: Uint8Array;
|
|
22
|
-
}>;
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { yieldIfNeeded as k } from "../../utilities/yielder.js";
|
|
2
|
-
class w {
|
|
3
|
-
}
|
|
4
|
-
function m(y, i, u, o, g, n) {
|
|
5
|
-
for (const a of y) {
|
|
6
|
-
const e = a.nextTokens(u, n ? !0 : void 0);
|
|
7
|
-
if (e) {
|
|
8
|
-
const f = Array.isArray(e) ? e : e.tokens;
|
|
9
|
-
o.total += f.length;
|
|
10
|
-
const c = i[i.length - 1], l = n ? n[n.length - 1] : null;
|
|
11
|
-
if (o.offset + f.length > c.length) {
|
|
12
|
-
const s = c.length - o.offset;
|
|
13
|
-
c.set(f.slice(0, s), o.offset);
|
|
14
|
-
const t = new Uint16Array(Math.floor(g * 0.1) + 100);
|
|
15
|
-
if (t.set(f.slice(s), 0), i.push(t), n && l && !Array.isArray(e)) {
|
|
16
|
-
l.set(
|
|
17
|
-
e.mask.slice(0, s).map((h) => h ? 1 : 0),
|
|
18
|
-
o.offset
|
|
19
|
-
);
|
|
20
|
-
const r = new Uint8Array(t.length);
|
|
21
|
-
r.set(
|
|
22
|
-
e.mask.slice(s).map((h) => h ? 1 : 0),
|
|
23
|
-
0
|
|
24
|
-
), n.push(r);
|
|
25
|
-
}
|
|
26
|
-
o.offset = f.length - s;
|
|
27
|
-
} else
|
|
28
|
-
c.set(f, o.offset), l && !Array.isArray(e) && l.set(
|
|
29
|
-
e.mask.map((s) => s ? 1 : 0),
|
|
30
|
-
o.offset
|
|
31
|
-
), o.offset += f.length;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
async function p(y, i, u, o) {
|
|
36
|
-
const g = Math.min(
|
|
37
|
-
(await Promise.all(y.map((t) => t.estimateTokens(i)))).reduce((t, r) => t + r, 0),
|
|
38
|
-
i.vocabSize * 1e4
|
|
39
|
-
), n = [new Uint16Array(g)], a = o ? [new Uint8Array(g)] : null, e = {
|
|
40
|
-
offset: 0,
|
|
41
|
-
total: 0
|
|
42
|
-
};
|
|
43
|
-
let f = performance.now();
|
|
44
|
-
for (; e.offset < g && (m(y, n, i, e, g, a || void 0), !y.every((t) => !t.hasMoreConversations())); )
|
|
45
|
-
f = await k(f, u, e.total);
|
|
46
|
-
if (n.length === 1)
|
|
47
|
-
return a ? { tokens: n[0].subarray(0, e.offset), mask: a[0].subarray(0, e.offset) } : n[0].subarray(0, e.offset);
|
|
48
|
-
const c = n.reduce((t, r) => t + r.length, 0) - (n[n.length - 1].length - e.offset), l = new Uint16Array(c);
|
|
49
|
-
let s = 0;
|
|
50
|
-
for (let t = 0; t < n.length; t++) {
|
|
51
|
-
const r = n[t];
|
|
52
|
-
t === n.length - 1 ? (l.set(r.subarray(0, e.offset), s), s += e.offset) : (l.set(r, s), s += r.length);
|
|
53
|
-
}
|
|
54
|
-
if (a) {
|
|
55
|
-
const t = new Uint8Array(c);
|
|
56
|
-
s = 0;
|
|
57
|
-
for (let r = 0; r < a.length; r++) {
|
|
58
|
-
const h = a[r];
|
|
59
|
-
r === a.length - 1 ? (t.set(h.subarray(0, e.offset), s), s += e.offset) : (t.set(h, s), s += h.length);
|
|
60
|
-
}
|
|
61
|
-
return { tokens: l, mask: t };
|
|
62
|
-
}
|
|
63
|
-
return l;
|
|
64
|
-
}
|
|
65
|
-
export {
|
|
66
|
-
w as Task,
|
|
67
|
-
p as tokensFromTasks
|
|
68
|
-
};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import s from "./ConversationTask.js";
|
|
2
|
-
function f(e, o) {
|
|
3
|
-
if (o <= 0 || o >= 1)
|
|
4
|
-
throw new Error("validationSplit must be between 0 and 1");
|
|
5
|
-
e.forEach((n) => n.shuffle());
|
|
6
|
-
const r = [], a = [];
|
|
7
|
-
for (const n of e)
|
|
8
|
-
for (; n.hasMoreConversations(); ) {
|
|
9
|
-
const t = n.nextConversation();
|
|
10
|
-
if (!t)
|
|
11
|
-
break;
|
|
12
|
-
Math.random() < o ? a.push(t) : r.push(t);
|
|
13
|
-
}
|
|
14
|
-
return {
|
|
15
|
-
training: new s(r),
|
|
16
|
-
validation: new s(a)
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
export {
|
|
20
|
-
f as default
|
|
21
|
-
};
|
package/dist/training/types.d.ts
DELETED
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { TensorStatistics } from '../checks/weights';
|
|
2
|
-
import { LoRAConfig } from '../models/config';
|
|
3
|
-
import { NamedTensorMap, Tensor } from '@tensorflow/tfjs-core';
|
|
4
|
-
export interface Metrics {
|
|
5
|
-
accuracy?: number;
|
|
6
|
-
perplexity?: number;
|
|
7
|
-
loss: number;
|
|
8
|
-
}
|
|
9
|
-
export interface TrainingLogEntry {
|
|
10
|
-
trainingMetrics: Metrics;
|
|
11
|
-
validationMetrics?: Metrics;
|
|
12
|
-
step: number;
|
|
13
|
-
time: number;
|
|
14
|
-
example?: string;
|
|
15
|
-
batchSize: number;
|
|
16
|
-
gradientMetrics?: Map<string, TensorStatistics>;
|
|
17
|
-
learningRate?: number;
|
|
18
|
-
gradientNorm?: number;
|
|
19
|
-
weightNorm?: number;
|
|
20
|
-
weightStatistics?: Map<string, TensorStatistics>;
|
|
21
|
-
memoryUsage?: number;
|
|
22
|
-
tokensPerSecond: number;
|
|
23
|
-
duration: number;
|
|
24
|
-
totalTokens: number;
|
|
25
|
-
}
|
|
26
|
-
export interface LRSchedulerConfig {
|
|
27
|
-
warmupSteps: number;
|
|
28
|
-
decayEpochs: number;
|
|
29
|
-
minLearningRate: number;
|
|
30
|
-
epochSteps: number;
|
|
31
|
-
step?: number;
|
|
32
|
-
}
|
|
33
|
-
export interface AdamWOptimizerConfig extends LRSchedulerConfig {
|
|
34
|
-
learningRate: number;
|
|
35
|
-
beta1: number;
|
|
36
|
-
beta2: number;
|
|
37
|
-
accBeta1?: number;
|
|
38
|
-
accBeta2?: number;
|
|
39
|
-
epsilon?: number;
|
|
40
|
-
weightDecay: number;
|
|
41
|
-
lossScaling: number;
|
|
42
|
-
clipNorm?: number;
|
|
43
|
-
orthoGrad?: boolean;
|
|
44
|
-
}
|
|
45
|
-
export type TrainingMetrics = 'accuracy' | 'perplexity' | 'gradientNorm' | 'gradientStatistics' | 'weightNorm' | 'weightStatistics' | 'memoryUsage' | 'tokensPerSecond' | 'learningRate';
|
|
46
|
-
export interface TrainingOptions extends Partial<AdamWOptimizerConfig> {
|
|
47
|
-
batchSize: number;
|
|
48
|
-
maxEpochs?: number;
|
|
49
|
-
logInterval?: number;
|
|
50
|
-
prompt?: string;
|
|
51
|
-
validationSplit?: number;
|
|
52
|
-
gradientCheckpointing?: boolean;
|
|
53
|
-
mixedPrecision?: boolean;
|
|
54
|
-
trainableWeights?: string[];
|
|
55
|
-
loraConfig?: LoRAConfig;
|
|
56
|
-
loraName?: string;
|
|
57
|
-
sftMode: 'full' | 'lora' | 'last-layer';
|
|
58
|
-
maskedLoss?: boolean;
|
|
59
|
-
metrics?: TrainingMetrics[];
|
|
60
|
-
contextScaling?: number;
|
|
61
|
-
labelSmoothing?: number;
|
|
62
|
-
dropout?: number;
|
|
63
|
-
layerDrop?: number;
|
|
64
|
-
debug?: boolean;
|
|
65
|
-
onStep?: (log: TrainingLogEntry) => void;
|
|
66
|
-
}
|
|
67
|
-
export interface TrainingState {
|
|
68
|
-
step: number;
|
|
69
|
-
lastLoss: number;
|
|
70
|
-
totalSteps: number;
|
|
71
|
-
losses: number[];
|
|
72
|
-
validationLosses: number[];
|
|
73
|
-
logStartTime: number;
|
|
74
|
-
trainingDuration: number;
|
|
75
|
-
gradients?: NamedTensorMap;
|
|
76
|
-
gradientNorm?: Tensor;
|
|
77
|
-
accuracy?: Tensor;
|
|
78
|
-
}
|
package/dist/training/types.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { ITokeniser, Task } from '../main';
|
|
2
|
-
import { Tensor } from '@tensorflow/tfjs-core';
|
|
3
|
-
import { Dataset } from '@tensorflow/tfjs-data';
|
|
4
|
-
import { DatasetBuilder, DatasetState } from './DatasetBuilder';
|
|
5
|
-
export declare function createTrainValidationSplit(tasks: Task[] | Uint16Array, tokeniser: ITokeniser, datasetBuilder: DatasetBuilder, batchSize: number, validationSplit?: number, masking?: boolean): Promise<{
|
|
6
|
-
trainDataset: Dataset<{
|
|
7
|
-
xs: Tensor;
|
|
8
|
-
ys: Tensor;
|
|
9
|
-
}>;
|
|
10
|
-
validationDataset: Dataset<{
|
|
11
|
-
xs: Tensor;
|
|
12
|
-
ys: Tensor;
|
|
13
|
-
}>;
|
|
14
|
-
size: number;
|
|
15
|
-
validationState: DatasetState;
|
|
16
|
-
trainState: DatasetState;
|
|
17
|
-
}>;
|