mambacode.js 1.0.0 → 1.0.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 (73) hide show
  1. package/README.md +198 -76
  2. package/dist/index.d.ts +18 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +18 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/kernels/activations.d.ts +3 -0
  7. package/dist/kernels/activations.d.ts.map +1 -0
  8. package/dist/kernels/activations.js +87 -0
  9. package/dist/kernels/activations.js.map +1 -0
  10. package/dist/kernels/conv1d.d.ts +3 -0
  11. package/dist/kernels/conv1d.d.ts.map +1 -0
  12. package/dist/kernels/conv1d.js +152 -0
  13. package/dist/kernels/conv1d.js.map +1 -0
  14. package/dist/kernels/linear_projection.d.ts +3 -0
  15. package/dist/kernels/linear_projection.d.ts.map +1 -0
  16. package/dist/kernels/linear_projection.js +219 -0
  17. package/dist/kernels/linear_projection.js.map +1 -0
  18. package/dist/kernels/selective_scan.d.ts +3 -0
  19. package/dist/kernels/selective_scan.d.ts.map +1 -0
  20. package/dist/kernels/selective_scan.js +348 -0
  21. package/dist/kernels/selective_scan.js.map +1 -0
  22. package/dist/kernels/weight_update.d.ts +3 -0
  23. package/dist/kernels/weight_update.d.ts.map +1 -0
  24. package/dist/kernels/weight_update.js +119 -0
  25. package/dist/kernels/weight_update.js.map +1 -0
  26. package/dist/model/mamba_block.d.ts +64 -0
  27. package/dist/model/mamba_block.d.ts.map +1 -0
  28. package/dist/model/mamba_block.js +309 -0
  29. package/dist/model/mamba_block.js.map +1 -0
  30. package/dist/model/mamba_model.d.ts +66 -0
  31. package/dist/model/mamba_model.d.ts.map +1 -0
  32. package/dist/model/mamba_model.js +289 -0
  33. package/dist/model/mamba_model.js.map +1 -0
  34. package/dist/tokenizer/bpe.d.ts +29 -0
  35. package/dist/tokenizer/bpe.d.ts.map +1 -0
  36. package/dist/tokenizer/bpe.js +164 -0
  37. package/dist/tokenizer/bpe.js.map +1 -0
  38. package/dist/training/autograd.d.ts +27 -0
  39. package/dist/training/autograd.d.ts.map +1 -0
  40. package/dist/training/autograd.js +120 -0
  41. package/dist/training/autograd.js.map +1 -0
  42. package/dist/training/trainer.d.ts +37 -0
  43. package/dist/training/trainer.d.ts.map +1 -0
  44. package/dist/training/trainer.js +183 -0
  45. package/dist/training/trainer.js.map +1 -0
  46. package/dist/utils/gpu_utils.d.ts +21 -0
  47. package/dist/utils/gpu_utils.d.ts.map +1 -0
  48. package/dist/utils/gpu_utils.js +111 -0
  49. package/dist/utils/gpu_utils.js.map +1 -0
  50. package/dist/utils/quantization.d.ts +26 -0
  51. package/dist/utils/quantization.d.ts.map +1 -0
  52. package/dist/utils/quantization.js +116 -0
  53. package/dist/utils/quantization.js.map +1 -0
  54. package/package.json +43 -18
  55. package/src/index.ts +59 -0
  56. package/src/kernels/{activations.js → activations.ts} +2 -2
  57. package/src/kernels/{linear_projection.js → linear_projection.ts} +2 -2
  58. package/src/kernels/{selective_scan.js → selective_scan.ts} +2 -2
  59. package/src/kernels/{weight_update.js → weight_update.ts} +2 -2
  60. package/src/model/{mamba_block.js → mamba_block.ts} +139 -175
  61. package/src/model/{mamba_model.js → mamba_model.ts} +168 -124
  62. package/src/tokenizer/bpe.ts +186 -0
  63. package/src/training/autograd.ts +135 -0
  64. package/src/training/trainer.ts +312 -0
  65. package/src/utils/gpu_utils.ts +147 -0
  66. package/src/utils/quantization.ts +154 -0
  67. package/src/index.js +0 -89
  68. package/src/tokenizer/bpe.js +0 -256
  69. package/src/training/autograd.js +0 -221
  70. package/src/training/trainer.js +0 -394
  71. package/src/utils/gpu_utils.js +0 -217
  72. package/src/utils/quantization.js +0 -215
  73. /package/src/kernels/{conv1d.js → conv1d.ts} +0 -0
@@ -0,0 +1,309 @@
1
+ /**
2
+ * mamba_block.ts – Mamba Mixer Block
3
+ */
4
+ import { createComputePipeline, createBindGroup, createStorageBuffer, createEmptyStorageBuffer, createUniformBuffer, dispatchKernel, cdiv, } from '../utils/gpu_utils';
5
+ import { SELECTIVE_SCAN_FORWARD_WGSL } from '../kernels/selective_scan';
6
+ import { CONV1D_FORWARD_WGSL } from '../kernels/conv1d';
7
+ import { LINEAR_FORWARD_WGSL } from '../kernels/linear_projection';
8
+ import { ACTIVATIONS_WGSL } from '../kernels/activations';
9
+ export class MambaBlock {
10
+ device;
11
+ config;
12
+ dInner;
13
+ dtRank;
14
+ wInProj;
15
+ bInProj;
16
+ wConv;
17
+ bConv;
18
+ wXProj;
19
+ bXProj;
20
+ wDtProj;
21
+ bDtProj;
22
+ A_log;
23
+ D_vec;
24
+ wOutProj;
25
+ bOutProj;
26
+ normWeight;
27
+ gpuWeights;
28
+ pipelines;
29
+ _wslaMode = false;
30
+ constructor(device, config) {
31
+ this.device = device;
32
+ this.config = {
33
+ dState: 16,
34
+ dConv: 4,
35
+ expand: 2,
36
+ biasConv: true,
37
+ dtRank: Math.ceil(config.dModel / 16),
38
+ ...config,
39
+ };
40
+ const { dModel, expand } = this.config;
41
+ this.dInner = expand * dModel;
42
+ this.dtRank = config.dtRank ?? Math.ceil(dModel / 16);
43
+ // Initialize these before _initWeights so TypeScript is happy
44
+ this.wInProj = new Float32Array(0);
45
+ this.bInProj = new Float32Array(0);
46
+ this.wConv = new Float32Array(0);
47
+ this.bConv = new Float32Array(0);
48
+ this.wXProj = new Float32Array(0);
49
+ this.bXProj = new Float32Array(0);
50
+ this.wDtProj = new Float32Array(0);
51
+ this.bDtProj = new Float32Array(0);
52
+ this.A_log = new Float32Array(0);
53
+ this.D_vec = new Float32Array(0);
54
+ this.wOutProj = new Float32Array(0);
55
+ this.bOutProj = new Float32Array(0);
56
+ this.normWeight = new Float32Array(0);
57
+ this.gpuWeights = {};
58
+ this.pipelines = {};
59
+ this._initWeights();
60
+ this._buildPipelines();
61
+ }
62
+ _initWeights() {
63
+ const { dModel, dState, dConv } = this.config;
64
+ const D = this.dInner;
65
+ const N = dState;
66
+ const K = dConv;
67
+ const R = this.dtRank;
68
+ const randn = (n, std = 0.02) => {
69
+ const a = new Float32Array(n);
70
+ for (let i = 0; i < n; i++) {
71
+ const u1 = Math.random(), u2 = Math.random();
72
+ a[i] = std * Math.sqrt(-2 * Math.log(u1 + 1e-12)) * Math.cos(2 * Math.PI * u2);
73
+ }
74
+ return a;
75
+ };
76
+ const zeros = (n) => new Float32Array(n);
77
+ const ones = (n) => new Float32Array(n).fill(1.0);
78
+ this.wInProj = randn(2 * D * dModel);
79
+ this.bInProj = zeros(2 * D);
80
+ this.wConv = randn(D * K, 0.01);
81
+ this.bConv = zeros(D);
82
+ this.wXProj = randn((R + 2 * N) * D, 0.01);
83
+ this.bXProj = zeros(R + 2 * N);
84
+ this.wDtProj = randn(D * R, 0.02);
85
+ this.bDtProj = zeros(D);
86
+ this.A_log = new Float32Array(D * N);
87
+ for (let d = 0; d < D; d++) {
88
+ for (let n = 0; n < N; n++) {
89
+ this.A_log[d * N + n] = Math.log(n + 1);
90
+ }
91
+ }
92
+ this.D_vec = ones(D);
93
+ this.wOutProj = randn(dModel * D, 0.02);
94
+ this.bOutProj = zeros(dModel);
95
+ this.normWeight = ones(dModel);
96
+ this._uploadWeightsToGPU();
97
+ }
98
+ _uploadWeightsToGPU() {
99
+ const d = this.device;
100
+ const mk = (arr, readable = true) => createStorageBuffer(d, arr, readable);
101
+ this.gpuWeights = {
102
+ wInProj: mk(this.wInProj),
103
+ bInProj: mk(this.bInProj),
104
+ wConv: mk(this.wConv),
105
+ bConv: mk(this.bConv),
106
+ wXProj: mk(this.wXProj),
107
+ bXProj: mk(this.bXProj),
108
+ wDtProj: mk(this.wDtProj),
109
+ bDtProj: mk(this.bDtProj),
110
+ A_log: mk(this.A_log),
111
+ D_vec: mk(this.D_vec),
112
+ wOutProj: mk(this.wOutProj),
113
+ bOutProj: mk(this.bOutProj),
114
+ normWeight: mk(this.normWeight),
115
+ };
116
+ }
117
+ _buildPipelines() {
118
+ const d = this.device;
119
+ this.pipelines = {
120
+ linear: createComputePipeline(d, LINEAR_FORWARD_WGSL, 'linear_forward'),
121
+ conv1d: createComputePipeline(d, CONV1D_FORWARD_WGSL, 'conv1d_forward'),
122
+ silu: createComputePipeline(d, ACTIVATIONS_WGSL, 'silu_forward'),
123
+ rmsnorm: createComputePipeline(d, ACTIVATIONS_WGSL, 'rmsnorm_forward'),
124
+ scan_fwd: createComputePipeline(d, SELECTIVE_SCAN_FORWARD_WGSL, 'forward_scan'),
125
+ scan_reduce: createComputePipeline(d, SELECTIVE_SCAN_FORWARD_WGSL, 'forward_reduce'),
126
+ };
127
+ }
128
+ forward(xBuf, batch, seqLen) {
129
+ const d = this.device;
130
+ const { dModel, dState, dConv } = this.config;
131
+ const D = this.dInner;
132
+ const N = dState;
133
+ const B = batch;
134
+ const L = seqLen;
135
+ const M = B * L;
136
+ const R = this.dtRank;
137
+ const cache = {};
138
+ const normOut = createEmptyStorageBuffer(d, M * dModel * 4, true);
139
+ const normInv = createEmptyStorageBuffer(d, M * 4, true);
140
+ cache.normInv = normInv;
141
+ cache.normIn = xBuf;
142
+ {
143
+ const params = new ArrayBuffer(16);
144
+ new Uint32Array(params, 0, 2).set([M, dModel]);
145
+ new Float32Array(params, 8, 1).set([1e-6]);
146
+ const pBuf = createUniformBuffer(d, params);
147
+ const bg = createBindGroup(d, this.pipelines['rmsnorm'], [pBuf, xBuf, this.gpuWeights['normWeight'], normOut, normInv]);
148
+ dispatchKernel(d, this.pipelines['rmsnorm'], bg, [cdiv(M, 64), 1, 1]);
149
+ }
150
+ const inProjOut = createEmptyStorageBuffer(d, M * 2 * D * 4, true);
151
+ cache.normOut = normOut;
152
+ {
153
+ const params = new Uint32Array([M, dModel, 2 * D]).buffer;
154
+ const pBuf = createUniformBuffer(d, params);
155
+ const bg = createBindGroup(d, this.pipelines['linear'], [pBuf, normOut, this.gpuWeights['wInProj'], this.gpuWeights['bInProj'], inProjOut]);
156
+ dispatchKernel(d, this.pipelines['linear'], bg, [cdiv(M, 16), cdiv(2 * D, 16), 1]);
157
+ }
158
+ const xConvIn = createEmptyStorageBuffer(d, M * D * 4, true);
159
+ const zBuf = createEmptyStorageBuffer(d, M * D * 4, true);
160
+ {
161
+ const enc = d.createCommandEncoder();
162
+ enc.copyBufferToBuffer(inProjOut, 0, xConvIn, 0, M * D * 4);
163
+ enc.copyBufferToBuffer(inProjOut, M * D * 4, zBuf, 0, M * D * 4);
164
+ d.queue.submit([enc.finish()]);
165
+ }
166
+ cache.zBuf = zBuf;
167
+ const convOut = createEmptyStorageBuffer(d, M * D * 4, true);
168
+ cache.xConvIn = xConvIn;
169
+ {
170
+ const params = new Uint32Array([L, D, dConv, B]).buffer;
171
+ const pBuf = createUniformBuffer(d, params);
172
+ const bg = createBindGroup(d, this.pipelines['conv1d'], [pBuf, xConvIn, this.gpuWeights['wConv'], this.gpuWeights['bConv'], convOut]);
173
+ dispatchKernel(d, this.pipelines['conv1d'], bg, [cdiv(L, 16), cdiv(D, 16), B]);
174
+ }
175
+ const siluOut = createEmptyStorageBuffer(d, M * D * 4, true);
176
+ cache.convOut = convOut;
177
+ {
178
+ const params = new Uint32Array([M * D]).buffer;
179
+ const pBuf = createUniformBuffer(d, params);
180
+ const bg = createBindGroup(d, this.pipelines['silu'], [pBuf, convOut, siluOut]);
181
+ dispatchKernel(d, this.pipelines['silu'], bg, [cdiv(M * D, 256), 1, 1]);
182
+ }
183
+ const xProjOut = createEmptyStorageBuffer(d, M * (R + 2 * N) * 4, true);
184
+ {
185
+ const params = new Uint32Array([M, D, R + 2 * N]).buffer;
186
+ const pBuf = createUniformBuffer(d, params);
187
+ const bg = createBindGroup(d, this.pipelines['linear'], [pBuf, siluOut, this.gpuWeights['wXProj'], this.gpuWeights['bXProj'], xProjOut]);
188
+ dispatchKernel(d, this.pipelines['linear'], bg, [cdiv(M, 16), cdiv(R + 2 * N, 16), 1]);
189
+ }
190
+ const dtRaw = createEmptyStorageBuffer(d, M * R * 4, true);
191
+ const B_raw = createEmptyStorageBuffer(d, B * L * N * 4, true);
192
+ const C_raw = createEmptyStorageBuffer(d, B * L * N * 4, true);
193
+ {
194
+ const enc = d.createCommandEncoder();
195
+ enc.copyBufferToBuffer(xProjOut, 0, dtRaw, 0, M * R * 4);
196
+ enc.copyBufferToBuffer(xProjOut, M * R * 4, B_raw, 0, B * L * N * 4);
197
+ enc.copyBufferToBuffer(xProjOut, M * (R + N) * 4, C_raw, 0, B * L * N * 4);
198
+ d.queue.submit([enc.finish()]);
199
+ }
200
+ const deltaFull = createEmptyStorageBuffer(d, M * D * 4, true);
201
+ {
202
+ const params = new Uint32Array([M, R, D]).buffer;
203
+ const pBuf = createUniformBuffer(d, params);
204
+ const bg = createBindGroup(d, this.pipelines['linear'], [pBuf, dtRaw, this.gpuWeights['wDtProj'], this.gpuWeights['bDtProj'], deltaFull]);
205
+ dispatchKernel(d, this.pipelines['linear'], bg, [cdiv(M, 16), cdiv(D, 16), 1]);
206
+ }
207
+ const scanY = createEmptyStorageBuffer(d, B * L * D * 4, true);
208
+ const hCache = createEmptyStorageBuffer(d, 2 * B * L * D * N * 4, true);
209
+ cache.siluOut = siluOut;
210
+ cache.deltaFull = deltaFull;
211
+ cache.B_raw = B_raw;
212
+ cache.C_raw = C_raw;
213
+ cache.hCache = hCache;
214
+ {
215
+ const params = new Uint32Array([L, N, D, B]).buffer;
216
+ const pBuf = createUniformBuffer(d, params);
217
+ const bg = createBindGroup(d, this.pipelines['scan_fwd'], [pBuf, siluOut, deltaFull, this.gpuWeights['A_log'], B_raw, C_raw,
218
+ this.gpuWeights['D_vec'], scanY, hCache]);
219
+ dispatchKernel(d, this.pipelines['scan_fwd'], bg, [cdiv(D, 8), cdiv(N, 8), B]);
220
+ const bg2 = createBindGroup(d, this.pipelines['scan_reduce'], [pBuf, siluOut, deltaFull, this.gpuWeights['A_log'], B_raw, C_raw,
221
+ this.gpuWeights['D_vec'], scanY, hCache]);
222
+ dispatchKernel(d, this.pipelines['scan_reduce'], bg2, [cdiv(L, 64), D, B]);
223
+ }
224
+ const siluZ = createEmptyStorageBuffer(d, M * D * 4, true);
225
+ const gatedOut = createEmptyStorageBuffer(d, M * D * 4, true);
226
+ {
227
+ const params = new Uint32Array([M * D]).buffer;
228
+ const pBuf = createUniformBuffer(d, params);
229
+ const bg = createBindGroup(d, this.pipelines['silu'], [pBuf, zBuf, siluZ]);
230
+ dispatchKernel(d, this.pipelines['silu'], bg, [cdiv(M * D, 256), 1, 1]);
231
+ const mulShader = /* wgsl */ `
232
+ @group(0) @binding(0) var<storage, read> a : array<f32>;
233
+ @group(0) @binding(1) var<storage, read> b : array<f32>;
234
+ @group(0) @binding(2) var<storage, read_write> c : array<f32>;
235
+ @group(0) @binding(3) var<uniform> n : u32;
236
+ @compute @workgroup_size(256)
237
+ fn main(@builtin(global_invocation_id) gid: vec3<u32>) {
238
+ let i = gid.x;
239
+ if (i < n) { c[i] = a[i] * b[i]; }
240
+ }
241
+ `;
242
+ const mulPipeline = createComputePipeline(d, mulShader, 'main');
243
+ const nBuf = createUniformBuffer(d, new Uint32Array([M * D]).buffer);
244
+ const bgMul = createBindGroup(d, mulPipeline, [scanY, siluZ, gatedOut, nBuf]);
245
+ dispatchKernel(d, mulPipeline, bgMul, [cdiv(M * D, 256), 1, 1]);
246
+ }
247
+ const outProjOut = createEmptyStorageBuffer(d, M * dModel * 4, true);
248
+ {
249
+ const params = new Uint32Array([M, D, dModel]).buffer;
250
+ const pBuf = createUniformBuffer(d, params);
251
+ const bg = createBindGroup(d, this.pipelines['linear'], [pBuf, gatedOut, this.gpuWeights['wOutProj'], this.gpuWeights['bOutProj'], outProjOut]);
252
+ dispatchKernel(d, this.pipelines['linear'], bg, [cdiv(M, 16), cdiv(dModel, 16), 1]);
253
+ }
254
+ const output = createEmptyStorageBuffer(d, M * dModel * 4, true);
255
+ {
256
+ const addShader = /* wgsl */ `
257
+ @group(0) @binding(0) var<storage, read> a : array<f32>;
258
+ @group(0) @binding(1) var<storage, read> b : array<f32>;
259
+ @group(0) @binding(2) var<storage, read_write> c : array<f32>;
260
+ @group(0) @binding(3) var<uniform> n : u32;
261
+ @compute @workgroup_size(256)
262
+ fn main(@builtin(global_invocation_id) gid: vec3<u32>) {
263
+ let i = gid.x;
264
+ if (i < n) { c[i] = a[i] + b[i]; }
265
+ }
266
+ `;
267
+ const addPipeline = createComputePipeline(d, addShader, 'main');
268
+ const nBuf = createUniformBuffer(d, new Uint32Array([M * dModel]).buffer);
269
+ const bgAdd = createBindGroup(d, addPipeline, [outProjOut, xBuf, output, nBuf]);
270
+ dispatchKernel(d, addPipeline, bgAdd, [cdiv(M * dModel, 256), 1, 1]);
271
+ }
272
+ return { output, cache };
273
+ }
274
+ parameters() {
275
+ const { dModel, dState, dConv } = this.config;
276
+ const D = this.dInner;
277
+ const N = dState;
278
+ const K = dConv;
279
+ const R = this.dtRank;
280
+ return [
281
+ { buf: this.gpuWeights['wInProj'], numel: 2 * D * dModel, name: 'wInProj' },
282
+ { buf: this.gpuWeights['bInProj'], numel: 2 * D, name: 'bInProj' },
283
+ { buf: this.gpuWeights['wConv'], numel: D * K, name: 'wConv' },
284
+ { buf: this.gpuWeights['bConv'], numel: D, name: 'bConv' },
285
+ { buf: this.gpuWeights['wXProj'], numel: (R + 2 * N) * D, name: 'wXProj' },
286
+ { buf: this.gpuWeights['bXProj'], numel: R + 2 * N, name: 'bXProj' },
287
+ { buf: this.gpuWeights['wDtProj'], numel: D * R, name: 'wDtProj' },
288
+ { buf: this.gpuWeights['bDtProj'], numel: D, name: 'bDtProj' },
289
+ { buf: this.gpuWeights['A_log'], numel: D * N, name: 'A_log' },
290
+ { buf: this.gpuWeights['D_vec'], numel: D, name: 'D_vec' },
291
+ { buf: this.gpuWeights['wOutProj'], numel: dModel * D, name: 'wOutProj' },
292
+ { buf: this.gpuWeights['bOutProj'], numel: dModel, name: 'bOutProj' },
293
+ { buf: this.gpuWeights['normWeight'], numel: dModel, name: 'normWeight' },
294
+ ];
295
+ }
296
+ setWSLAMode(enabled) {
297
+ this._wslaMode = enabled;
298
+ }
299
+ getTrainableParams() {
300
+ if (this._wslaMode) {
301
+ return [
302
+ { buf: this.gpuWeights['wXProj'], numel: this.wXProj.length, name: 'wXProj' },
303
+ { buf: this.gpuWeights['bXProj'], numel: this.bXProj.length, name: 'bXProj' },
304
+ ];
305
+ }
306
+ return this.parameters();
307
+ }
308
+ }
309
+ //# sourceMappingURL=mamba_block.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mamba_block.js","sourceRoot":"","sources":["../../src/model/mamba_block.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ /**
2
+ * mamba_model.ts – Full Mamba language model.
3
+ */
4
+ import { MambaBlock, BlockCache, BlockParam } from './mamba_block';
5
+ export interface MambaModelConfig {
6
+ vocabSize: number;
7
+ dModel: number;
8
+ numLayers: number;
9
+ dState?: number;
10
+ dConv?: number;
11
+ expand?: number;
12
+ eosId?: number;
13
+ }
14
+ export interface ModelForwardResult {
15
+ logits: Float32Array;
16
+ gpuLogits: GPUBuffer;
17
+ caches: BlockCache[];
18
+ }
19
+ export interface SamplingOptions {
20
+ temperature?: number;
21
+ topK?: number;
22
+ topP?: number;
23
+ }
24
+ export declare class MambaModel {
25
+ device: GPUDevice;
26
+ config: Required<MambaModelConfig>;
27
+ gpuEmbedding: GPUBuffer;
28
+ blocks: MambaBlock[];
29
+ gpuFinalNorm: GPUBuffer;
30
+ tiedEmbedding: boolean;
31
+ gpuLMHeadBias: GPUBuffer;
32
+ private _lmHeadPipeline;
33
+ private _rmsnormPipeline;
34
+ private _embedPipeline;
35
+ private _wslaMode;
36
+ constructor(device: GPUDevice, config: MambaModelConfig);
37
+ embedTokens(tokenIds: number[] | Uint32Array, batch: number, seqLen: number): GPUBuffer;
38
+ forward(tokenIds: number[] | Uint32Array, batch: number, seqLen: number): Promise<ModelForwardResult>;
39
+ generate(promptIds: number[], maxNewTokens?: number, samplingOpts?: SamplingOptions): Promise<number[]>;
40
+ parameters(): BlockParam[];
41
+ setWSLAMode(enabled: boolean): void;
42
+ /**
43
+ * Serialise all model parameters to an ArrayBuffer.
44
+ *
45
+ * Binary format:
46
+ * [0..3] magic : uint32 = 0x4D424A53 ('MBJS')
47
+ * [4..7] version: uint32 = 1
48
+ * [8..11] nParams: uint32
49
+ * [12 .. 12+4*nParams-1] numel[i]: uint32 for each parameter i
50
+ * [12+4*nParams ..] float32 data for each parameter, concatenated
51
+ *
52
+ * Save the returned buffer to a file or IndexedDB and reload it with
53
+ * `loadWeights()` to resume from a checkpoint.
54
+ */
55
+ exportWeights(): Promise<ArrayBuffer>;
56
+ /**
57
+ * Load model parameters from an ArrayBuffer previously produced by
58
+ * `exportWeights()`. The parameter count and element counts must match
59
+ * the current model configuration exactly.
60
+ *
61
+ * @throws {Error} if the magic number, version, or parameter layout do
62
+ * not match the current model.
63
+ */
64
+ loadWeights(buffer: ArrayBuffer): Promise<void>;
65
+ }
66
+ //# sourceMappingURL=mamba_model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mamba_model.d.ts","sourceRoot":"","sources":["../../src/model/mamba_model.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAenE,MAAM,WAAW,gBAAgB;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,YAAY,CAAC;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,UAAU,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,eAAe;IAC9B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,qBAAa,UAAU;IACnB,MAAM,EAAE,SAAS,CAAC;IAClB,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,CAAC;IACnC,YAAY,EAAE,SAAS,CAAC;IACxB,MAAM,EAAE,UAAU,EAAE,CAAC;IACrB,YAAY,EAAE,SAAS,CAAC;IACxB,aAAa,EAAE,OAAO,CAAC;IACvB,aAAa,EAAE,SAAS,CAAC;IACzB,OAAO,CAAC,eAAe,CAAqB;IAC5C,OAAO,CAAC,gBAAgB,CAAqB;IAC7C,OAAO,CAAC,cAAc,CAAqB;IAC3C,OAAO,CAAC,SAAS,CAAS;gBAEd,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,gBAAgB;IA2CvD,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,SAAS;IAoBjF,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IA6CrG,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE,YAAY,SAAM,EAAE,YAAY,GAAE,eAAoB,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAqB9G,UAAU,IAAI,UAAU,EAAE;IAwB1B,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAKnC;;;;;;;;;;;;OAYG;IACG,aAAa,IAAI,OAAO,CAAC,WAAW,CAAC;IAiC3C;;;;;;;OAOG;IACG,WAAW,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAiDxD"}