@genai-fi/nanogpt 0.19.0 → 0.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (482) hide show
  1. package/package.json +9 -10
  2. package/dist/Generator.d.ts +0 -82
  3. package/dist/Generator.js +0 -11941
  4. package/dist/RealDiv-CGwv0liw.js +0 -365
  5. package/dist/Reshape-BW__R4mZ.js +0 -79
  6. package/dist/Reshape-CPBkTIH2.js +0 -14
  7. package/dist/TeachableLLM.d.ts +0 -70
  8. package/dist/TeachableLLM.js +0 -273
  9. package/dist/Trainer.d.ts +0 -43
  10. package/dist/Trainer.js +0 -244
  11. package/dist/_commonjsHelpers-ByX85dGu.js +0 -33
  12. package/dist/axis_util-GTVlo58H.js +0 -55
  13. package/dist/backend.d.ts +0 -2
  14. package/dist/backend.js +0 -13
  15. package/dist/backend_util-GaFarB78.js +0 -425
  16. package/dist/backend_webgpu-BqASlsbV.js +0 -545
  17. package/dist/binary_op_util-pKXltfxI.js +0 -192
  18. package/dist/broadcast_to-eS93CCN_.js +0 -28
  19. package/dist/checks/appendCache.d.ts +0 -1
  20. package/dist/checks/appendCache.js +0 -22
  21. package/dist/checks/attentionMask.d.ts +0 -1
  22. package/dist/checks/attentionMask.js +0 -37
  23. package/dist/checks/check.d.ts +0 -9
  24. package/dist/checks/check.js +0 -20
  25. package/dist/checks/gelu.d.ts +0 -1
  26. package/dist/checks/gelu.js +0 -18
  27. package/dist/checks/index.d.ts +0 -26
  28. package/dist/checks/index.js +0 -28
  29. package/dist/checks/matMulGelu.d.ts +0 -1
  30. package/dist/checks/matMulGelu.js +0 -28
  31. package/dist/checks/normRMS.d.ts +0 -1
  32. package/dist/checks/normRMS.js +0 -16
  33. package/dist/checks/normRMSGrad.d.ts +0 -1
  34. package/dist/checks/normRMSGrad.js +0 -12
  35. package/dist/checks/packUnpack.d.ts +0 -1
  36. package/dist/checks/packUnpack.js +0 -18
  37. package/dist/checks/qkv.d.ts +0 -1
  38. package/dist/checks/qkv.js +0 -34
  39. package/dist/checks/rope.d.ts +0 -1
  40. package/dist/checks/rope.js +0 -36
  41. package/dist/checks/weights.d.ts +0 -14
  42. package/dist/checks/weights.js +0 -31
  43. package/dist/clip_by_value-DDA7rrcT.js +0 -12
  44. package/dist/complex-DI35Q-gW.js +0 -11
  45. package/dist/complex_util-Yc1A_gV1.js +0 -55
  46. package/dist/concat-CAQpCret.js +0 -17
  47. package/dist/concat_util-D18dJ4fD.js +0 -22
  48. package/dist/data/docx.d.ts +0 -2
  49. package/dist/data/docx.js +0 -15
  50. package/dist/data/parquet.d.ts +0 -2
  51. package/dist/data/parquet.js +0 -17
  52. package/dist/data/pdf.d.ts +0 -2
  53. package/dist/data/pdf.js +0 -14
  54. package/dist/data/textLoader.d.ts +0 -7
  55. package/dist/data/textLoader.js +0 -108
  56. package/dist/dataset-CGGp1z9P.js +0 -1124
  57. package/dist/dropout_util--NxWuYg2.js +0 -27
  58. package/dist/expand_dims-Bkd1YD5x.js +0 -11
  59. package/dist/exports_initializers-CYzKLjN7.js +0 -7
  60. package/dist/floor-BQtb-Azg.js +0 -9
  61. package/dist/gather-qIqEqaGn.js +0 -9
  62. package/dist/gelu-B220X1Go.js +0 -26
  63. package/dist/gpgpu_math-BwvV12df.js +0 -2022
  64. package/dist/index-CUXkjxiT.js +0 -3516
  65. package/dist/index-CieiGp4Y.js +0 -349
  66. package/dist/index-CjOWnMXP.js +0 -7308
  67. package/dist/index-Cp39cXWe.js +0 -1016
  68. package/dist/index-D5v913EJ.js +0 -4
  69. package/dist/index-DmeWGGmS.js +0 -1074
  70. package/dist/index-DvYrXKkX.js +0 -113
  71. package/dist/index-Ksja3su6.js +0 -151
  72. package/dist/index-xuotMAFm.js +0 -118
  73. package/dist/inference/types.d.ts +0 -16
  74. package/dist/inference/types.js +0 -1
  75. package/dist/jszip.min-BZhlzntC.js +0 -2313
  76. package/dist/kernel_funcs_utils-pq0CK9co.js +0 -306
  77. package/dist/layers/BaseLayer.d.ts +0 -44
  78. package/dist/layers/BaseLayer.js +0 -74
  79. package/dist/layers/CausalSelfAttention.d.ts +0 -39
  80. package/dist/layers/CausalSelfAttention.js +0 -86
  81. package/dist/layers/LoRA.d.ts +0 -14
  82. package/dist/layers/LoRA.js +0 -58
  83. package/dist/layers/MLP.d.ts +0 -17
  84. package/dist/layers/MLP.js +0 -44
  85. package/dist/layers/PositionEmbedding.d.ts +0 -8
  86. package/dist/layers/PositionEmbedding.js +0 -31
  87. package/dist/layers/RMSNorm.d.ts +0 -12
  88. package/dist/layers/RMSNorm.js +0 -22
  89. package/dist/layers/RoPECache.d.ts +0 -18
  90. package/dist/layers/RoPECache.js +0 -50
  91. package/dist/layers/TiedEmbedding.d.ts +0 -13
  92. package/dist/layers/TiedEmbedding.js +0 -36
  93. package/dist/layers/TransformerBlock.d.ts +0 -27
  94. package/dist/layers/TransformerBlock.js +0 -40
  95. package/dist/layers/WeightStore.d.ts +0 -20
  96. package/dist/layers/WeightStore.js +0 -76
  97. package/dist/loader/load.d.ts +0 -6
  98. package/dist/loader/load.js +0 -68
  99. package/dist/loader/loadHF.d.ts +0 -8
  100. package/dist/loader/loadHF.js +0 -22
  101. package/dist/loader/loadTransformers.d.ts +0 -4
  102. package/dist/loader/loadTransformers.js +0 -44
  103. package/dist/loader/loadZipMeta.d.ts +0 -3
  104. package/dist/loader/loadZipMeta.js +0 -16
  105. package/dist/loader/newZipLoad.d.ts +0 -3
  106. package/dist/loader/newZipLoad.js +0 -31
  107. package/dist/loader/oldZipLoad.d.ts +0 -9
  108. package/dist/loader/oldZipLoad.js +0 -80
  109. package/dist/loader/save.d.ts +0 -16
  110. package/dist/loader/save.js +0 -90
  111. package/dist/loader/types.d.ts +0 -67
  112. package/dist/loader/types.js +0 -1
  113. package/dist/main.d.ts +0 -50
  114. package/dist/main.js +0 -109
  115. package/dist/matMul16-BcVC_E62.js +0 -80
  116. package/dist/matMulGelu-JNLZqKQp.js +0 -163
  117. package/dist/mat_mul-DhG0Newp.js +0 -11
  118. package/dist/mod-CSdCpRjf.js +0 -11
  119. package/dist/models/NanoGPTV1.d.ts +0 -16
  120. package/dist/models/NanoGPTV1.js +0 -99
  121. package/dist/models/NanoGPTV2.d.ts +0 -16
  122. package/dist/models/NanoGPTV2.js +0 -90
  123. package/dist/models/config.d.ts +0 -27
  124. package/dist/models/config.js +0 -50
  125. package/dist/models/factory.d.ts +0 -3
  126. package/dist/models/factory.js +0 -16
  127. package/dist/models/model.d.ts +0 -44
  128. package/dist/models/model.js +0 -134
  129. package/dist/non_max_suppression_impl-B2W7YjZB.js +0 -102
  130. package/dist/not_equal-hurPF26l.js +0 -64
  131. package/dist/ones-BytntneX.js +0 -14
  132. package/dist/ops/adamAdjust.d.ts +0 -2
  133. package/dist/ops/adamAdjust.js +0 -9
  134. package/dist/ops/adamMoments.d.ts +0 -2
  135. package/dist/ops/adamMoments.js +0 -9
  136. package/dist/ops/add16.d.ts +0 -2
  137. package/dist/ops/add16.js +0 -9
  138. package/dist/ops/appendCache.d.ts +0 -2
  139. package/dist/ops/appendCache.js +0 -22
  140. package/dist/ops/attentionMask.d.ts +0 -2
  141. package/dist/ops/attentionMask.js +0 -10
  142. package/dist/ops/concat16.d.ts +0 -2
  143. package/dist/ops/concat16.js +0 -9
  144. package/dist/ops/cpu/adamAdjust.d.ts +0 -1
  145. package/dist/ops/cpu/adamAdjust.js +0 -18
  146. package/dist/ops/cpu/adamMoments.d.ts +0 -1
  147. package/dist/ops/cpu/adamMoments.js +0 -16
  148. package/dist/ops/cpu/appendCache.d.ts +0 -1
  149. package/dist/ops/cpu/appendCache.js +0 -23
  150. package/dist/ops/cpu/attentionMask.d.ts +0 -1
  151. package/dist/ops/cpu/attentionMask.js +0 -22
  152. package/dist/ops/cpu/fusedSoftmax.d.ts +0 -9
  153. package/dist/ops/cpu/fusedSoftmax.js +0 -29
  154. package/dist/ops/cpu/gatherSub.d.ts +0 -1
  155. package/dist/ops/cpu/gatherSub.js +0 -18
  156. package/dist/ops/cpu/gelu.d.ts +0 -1
  157. package/dist/ops/cpu/gelu.js +0 -40
  158. package/dist/ops/cpu/matMul16.d.ts +0 -1
  159. package/dist/ops/cpu/matMul16.js +0 -15
  160. package/dist/ops/cpu/matMulGelu.d.ts +0 -1
  161. package/dist/ops/cpu/matMulGelu.js +0 -53
  162. package/dist/ops/cpu/matMulMul.d.ts +0 -1
  163. package/dist/ops/cpu/matMulMul.js +0 -23
  164. package/dist/ops/cpu/mulDropout.d.ts +0 -1
  165. package/dist/ops/cpu/mulDropout.js +0 -23
  166. package/dist/ops/cpu/normRMS.d.ts +0 -1
  167. package/dist/ops/cpu/normRMS.js +0 -39
  168. package/dist/ops/cpu/qkv.d.ts +0 -5
  169. package/dist/ops/cpu/qkv.js +0 -41
  170. package/dist/ops/cpu/rope.d.ts +0 -6
  171. package/dist/ops/cpu/rope.js +0 -38
  172. package/dist/ops/cpu/scatterSub.d.ts +0 -1
  173. package/dist/ops/cpu/scatterSub.js +0 -23
  174. package/dist/ops/dot16.d.ts +0 -2
  175. package/dist/ops/dot16.js +0 -42
  176. package/dist/ops/dropout.d.ts +0 -2
  177. package/dist/ops/dropout.js +0 -14
  178. package/dist/ops/dropout16.d.ts +0 -2
  179. package/dist/ops/dropout16.js +0 -25
  180. package/dist/ops/gatherSub.d.ts +0 -2
  181. package/dist/ops/gatherSub.js +0 -9
  182. package/dist/ops/gelu.d.ts +0 -3
  183. package/dist/ops/gelu.js +0 -8
  184. package/dist/ops/globalNorm.d.ts +0 -2
  185. package/dist/ops/globalNorm.js +0 -13
  186. package/dist/ops/grads/add16.d.ts +0 -1
  187. package/dist/ops/grads/add16.js +0 -26
  188. package/dist/ops/grads/attentionMask.d.ts +0 -1
  189. package/dist/ops/grads/attentionMask.js +0 -21
  190. package/dist/ops/grads/dropout16.d.ts +0 -1
  191. package/dist/ops/grads/dropout16.js +0 -2
  192. package/dist/ops/grads/gelu.d.ts +0 -2
  193. package/dist/ops/grads/gelu.js +0 -5
  194. package/dist/ops/grads/matMul16.d.ts +0 -2
  195. package/dist/ops/grads/matMul16.js +0 -9
  196. package/dist/ops/grads/matMulGelu.d.ts +0 -1
  197. package/dist/ops/grads/matMulGelu.js +0 -17
  198. package/dist/ops/grads/mul16.d.ts +0 -1
  199. package/dist/ops/grads/mul16.js +0 -4
  200. package/dist/ops/grads/normRMS.d.ts +0 -3
  201. package/dist/ops/grads/normRMS.js +0 -33
  202. package/dist/ops/grads/pack16.d.ts +0 -2
  203. package/dist/ops/grads/pack16.js +0 -6
  204. package/dist/ops/grads/qkv.d.ts +0 -3
  205. package/dist/ops/grads/qkv.js +0 -34
  206. package/dist/ops/grads/rope.d.ts +0 -2
  207. package/dist/ops/grads/rope.js +0 -5
  208. package/dist/ops/grads/softmax16.d.ts +0 -2
  209. package/dist/ops/grads/softmax16.js +0 -25
  210. package/dist/ops/grads/unpack16.d.ts +0 -2
  211. package/dist/ops/grads/unpack16.js +0 -5
  212. package/dist/ops/grads/utils.d.ts +0 -4
  213. package/dist/ops/grads/utils.js +0 -14
  214. package/dist/ops/log.d.ts +0 -0
  215. package/dist/ops/log.js +0 -1
  216. package/dist/ops/matMul16.d.ts +0 -15
  217. package/dist/ops/matMul16.js +0 -13
  218. package/dist/ops/matMulGelu.d.ts +0 -3
  219. package/dist/ops/matMulGelu.js +0 -14
  220. package/dist/ops/matMulMul.d.ts +0 -2
  221. package/dist/ops/matMulMul.js +0 -9
  222. package/dist/ops/mul16.d.ts +0 -2
  223. package/dist/ops/mul16.js +0 -39
  224. package/dist/ops/mulDrop.d.ts +0 -2
  225. package/dist/ops/mulDrop.js +0 -9
  226. package/dist/ops/normRMS.d.ts +0 -2
  227. package/dist/ops/normRMS.js +0 -19
  228. package/dist/ops/pack16.d.ts +0 -2
  229. package/dist/ops/pack16.js +0 -5
  230. package/dist/ops/qkv.d.ts +0 -2
  231. package/dist/ops/qkv.js +0 -10
  232. package/dist/ops/reshape16.d.ts +0 -2
  233. package/dist/ops/reshape16.js +0 -41
  234. package/dist/ops/rope.d.ts +0 -3
  235. package/dist/ops/rope.js +0 -7
  236. package/dist/ops/scatterSub.d.ts +0 -2
  237. package/dist/ops/scatterSub.js +0 -9
  238. package/dist/ops/slice16.d.ts +0 -2
  239. package/dist/ops/slice16.js +0 -9
  240. package/dist/ops/softmax16.d.ts +0 -2
  241. package/dist/ops/softmax16.js +0 -9
  242. package/dist/ops/sub16.d.ts +0 -2
  243. package/dist/ops/sub16.js +0 -8
  244. package/dist/ops/sum16.d.ts +0 -2
  245. package/dist/ops/sum16.js +0 -13
  246. package/dist/ops/transpose16.d.ts +0 -3
  247. package/dist/ops/transpose16.js +0 -40
  248. package/dist/ops/unpack16.d.ts +0 -2
  249. package/dist/ops/unpack16.js +0 -6
  250. package/dist/ops/webgl/adamAdjust.d.ts +0 -1
  251. package/dist/ops/webgl/adamAdjust.js +0 -49
  252. package/dist/ops/webgl/adamMoments.d.ts +0 -1
  253. package/dist/ops/webgl/adamMoments.js +0 -40
  254. package/dist/ops/webgl/appendCache.d.ts +0 -1
  255. package/dist/ops/webgl/appendCache.js +0 -44
  256. package/dist/ops/webgl/attentionMask.d.ts +0 -1
  257. package/dist/ops/webgl/attentionMask.js +0 -45
  258. package/dist/ops/webgl/dropout16.d.ts +0 -1
  259. package/dist/ops/webgl/dropout16.js +0 -11
  260. package/dist/ops/webgl/fusedSoftmax.d.ts +0 -11
  261. package/dist/ops/webgl/fusedSoftmax.js +0 -80
  262. package/dist/ops/webgl/gatherSub.d.ts +0 -1
  263. package/dist/ops/webgl/gatherSub.js +0 -27
  264. package/dist/ops/webgl/gelu.d.ts +0 -2
  265. package/dist/ops/webgl/gelu.js +0 -50
  266. package/dist/ops/webgl/log.d.ts +0 -17
  267. package/dist/ops/webgl/log.js +0 -23
  268. package/dist/ops/webgl/matMul16.d.ts +0 -1
  269. package/dist/ops/webgl/matMul16.js +0 -45
  270. package/dist/ops/webgl/matMulGelu.d.ts +0 -21
  271. package/dist/ops/webgl/matMulGelu.js +0 -9
  272. package/dist/ops/webgl/matMulMul.d.ts +0 -14
  273. package/dist/ops/webgl/matMulMul.js +0 -28
  274. package/dist/ops/webgl/mulDropout.d.ts +0 -1
  275. package/dist/ops/webgl/mulDropout.js +0 -41
  276. package/dist/ops/webgl/normRMS.d.ts +0 -1
  277. package/dist/ops/webgl/normRMS.js +0 -93
  278. package/dist/ops/webgl/qkv.d.ts +0 -1
  279. package/dist/ops/webgl/qkv.js +0 -46
  280. package/dist/ops/webgl/rope.d.ts +0 -1
  281. package/dist/ops/webgl/rope.js +0 -56
  282. package/dist/ops/webgl/scatterSub.d.ts +0 -1
  283. package/dist/ops/webgl/scatterSub.js +0 -27
  284. package/dist/ops/webgpu/adamAdjust.d.ts +0 -1
  285. package/dist/ops/webgpu/adamAdjust.js +0 -57
  286. package/dist/ops/webgpu/adamMoments.d.ts +0 -1
  287. package/dist/ops/webgpu/adamMoments.js +0 -60
  288. package/dist/ops/webgpu/add16.d.ts +0 -1
  289. package/dist/ops/webgpu/add16.js +0 -13
  290. package/dist/ops/webgpu/appendCache.d.ts +0 -1
  291. package/dist/ops/webgpu/appendCache.js +0 -105
  292. package/dist/ops/webgpu/attentionMask.d.ts +0 -1
  293. package/dist/ops/webgpu/attentionMask.js +0 -26
  294. package/dist/ops/webgpu/attentionMask32_program.d.ts +0 -19
  295. package/dist/ops/webgpu/attentionMask32_program.js +0 -54
  296. package/dist/ops/webgpu/clipScale.d.ts +0 -1
  297. package/dist/ops/webgpu/clipScale.js +0 -58
  298. package/dist/ops/webgpu/concat16.d.ts +0 -19
  299. package/dist/ops/webgpu/concat16.js +0 -126
  300. package/dist/ops/webgpu/dropout16.d.ts +0 -1
  301. package/dist/ops/webgpu/dropout16.js +0 -51
  302. package/dist/ops/webgpu/gatherSub.d.ts +0 -1
  303. package/dist/ops/webgpu/gatherSub.js +0 -39
  304. package/dist/ops/webgpu/gelu.d.ts +0 -14
  305. package/dist/ops/webgpu/gelu.js +0 -141
  306. package/dist/ops/webgpu/index.d.ts +0 -0
  307. package/dist/ops/webgpu/index.js +0 -26
  308. package/dist/ops/webgpu/matMul16.d.ts +0 -1
  309. package/dist/ops/webgpu/matMul16.js +0 -65
  310. package/dist/ops/webgpu/matMul16_program.d.ts +0 -42
  311. package/dist/ops/webgpu/matMul16_program.js +0 -343
  312. package/dist/ops/webgpu/mul16.d.ts +0 -1
  313. package/dist/ops/webgpu/mul16.js +0 -13
  314. package/dist/ops/webgpu/norm2.d.ts +0 -1
  315. package/dist/ops/webgpu/norm2.js +0 -76
  316. package/dist/ops/webgpu/normRMS.d.ts +0 -1
  317. package/dist/ops/webgpu/normRMS.js +0 -34
  318. package/dist/ops/webgpu/normRMS16_program.d.ts +0 -10
  319. package/dist/ops/webgpu/normRMS16_program.js +0 -25
  320. package/dist/ops/webgpu/normRMS32_program.d.ts +0 -10
  321. package/dist/ops/webgpu/normRMS32_program.js +0 -25
  322. package/dist/ops/webgpu/normRMSGrad.d.ts +0 -1
  323. package/dist/ops/webgpu/normRMSGrad.js +0 -284
  324. package/dist/ops/webgpu/pack16.d.ts +0 -1
  325. package/dist/ops/webgpu/pack16.js +0 -18
  326. package/dist/ops/webgpu/pack16_program.d.ts +0 -19
  327. package/dist/ops/webgpu/pack16_program.js +0 -92
  328. package/dist/ops/webgpu/qkv.d.ts +0 -1
  329. package/dist/ops/webgpu/qkv.js +0 -24
  330. package/dist/ops/webgpu/rope.d.ts +0 -1
  331. package/dist/ops/webgpu/rope.js +0 -135
  332. package/dist/ops/webgpu/scatterSub.d.ts +0 -1
  333. package/dist/ops/webgpu/scatterSub.js +0 -40
  334. package/dist/ops/webgpu/slice16.d.ts +0 -7
  335. package/dist/ops/webgpu/slice16.js +0 -69
  336. package/dist/ops/webgpu/softmax16.d.ts +0 -17
  337. package/dist/ops/webgpu/softmax16.js +0 -21
  338. package/dist/ops/webgpu/softmax16_program.d.ts +0 -13
  339. package/dist/ops/webgpu/softmax16_program.js +0 -73
  340. package/dist/ops/webgpu/softmax16_subgroup_program.d.ts +0 -17
  341. package/dist/ops/webgpu/softmax16_subgroup_program.js +0 -75
  342. package/dist/ops/webgpu/softmax16grad.d.ts +0 -1
  343. package/dist/ops/webgpu/softmax16grad.js +0 -37
  344. package/dist/ops/webgpu/sub16.d.ts +0 -1
  345. package/dist/ops/webgpu/sub16.js +0 -13
  346. package/dist/ops/webgpu/sum16.d.ts +0 -1
  347. package/dist/ops/webgpu/sum16.js +0 -38
  348. package/dist/ops/webgpu/transpose16.d.ts +0 -1
  349. package/dist/ops/webgpu/transpose16.js +0 -34
  350. package/dist/ops/webgpu/transpose16_program.d.ts +0 -16
  351. package/dist/ops/webgpu/transpose16_program.js +0 -50
  352. package/dist/ops/webgpu/transpose16_shared_program.d.ts +0 -15
  353. package/dist/ops/webgpu/transpose16_shared_program.js +0 -70
  354. package/dist/ops/webgpu/unpack16.d.ts +0 -1
  355. package/dist/ops/webgpu/unpack16.js +0 -48
  356. package/dist/ops/webgpu/utils/binary_op.d.ts +0 -35
  357. package/dist/ops/webgpu/utils/binary_op.js +0 -139
  358. package/dist/ops/webgpu/utils/deviceInfo.d.ts +0 -7
  359. package/dist/ops/webgpu/utils/deviceInfo.js +0 -11
  360. package/dist/ops/webgpu/utils/reductions.d.ts +0 -43
  361. package/dist/ops/webgpu/utils/reductions.js +0 -275
  362. package/dist/ops-CsXeTq1P.js +0 -476
  363. package/dist/pack16-bqltoUlR.js +0 -39
  364. package/dist/papaparse.min-C0cScC2i.js +0 -418
  365. package/dist/parquet-Bqjmp2vo.js +0 -44231
  366. package/dist/patches/webgpu_backend.d.ts +0 -18
  367. package/dist/patches/webgpu_backend.js +0 -56
  368. package/dist/patches/webgpu_base.d.ts +0 -21
  369. package/dist/patches/webgpu_base.js +0 -34
  370. package/dist/patches/webgpu_program.d.ts +0 -36
  371. package/dist/patches/webgpu_program.js +0 -400
  372. package/dist/pdf-NIhmP3sq.js +0 -19477
  373. package/dist/rand_util-CZ7yLoUm.js +0 -50
  374. package/dist/random_normal-IBRrha8a.js +0 -14
  375. package/dist/random_width-DN5ZtQkM.js +0 -9796
  376. package/dist/range-C-CjF-LI.js +0 -10
  377. package/dist/relu-J_X6MUzx.js +0 -9
  378. package/dist/reshape-BDOuCSNW.js +0 -9
  379. package/dist/resize_nearest_neighbor-BojqlfRe.js +0 -150
  380. package/dist/rope-DcrZM_e6.js +0 -24
  381. package/dist/scatter_nd_util-ByNJaL6I.js +0 -46
  382. package/dist/segment_util-Dasb2Zaf.js +0 -43
  383. package/dist/selu_util-BLhIqRkw.js +0 -44
  384. package/dist/shared-3agzAqQ_.js +0 -53
  385. package/dist/shared-CagdqkLh.js +0 -2143
  386. package/dist/slice-BzS11Qh0.js +0 -12
  387. package/dist/slice_util-CC35pLmT.js +0 -153
  388. package/dist/softmax-D4q1LJN7.js +0 -12
  389. package/dist/split-C2Sj255c.js +0 -9
  390. package/dist/squeeze-ho4wLUek.js +0 -10
  391. package/dist/stack-DudVrtmG.js +0 -11
  392. package/dist/step-BTxPtq1r.js +0 -261
  393. package/dist/sum-BpiwSWvg.js +0 -11
  394. package/dist/tensor-BWFldCso.js +0 -8
  395. package/dist/tensor1d-LMGMIUlr.js +0 -11
  396. package/dist/tensor2d-BnXMKScO.js +0 -14
  397. package/dist/tensor4d-C6UCG_u8.js +0 -14
  398. package/dist/tfjs_backend-BGnG-ppu.js +0 -654
  399. package/dist/tile-CFy-xTO6.js +0 -11
  400. package/dist/tokeniser/BaseTokeniser.d.ts +0 -33
  401. package/dist/tokeniser/BaseTokeniser.js +0 -124
  402. package/dist/tokeniser/CharTokeniser.d.ts +0 -24
  403. package/dist/tokeniser/CharTokeniser.js +0 -107
  404. package/dist/tokeniser/bpe.d.ts +0 -28
  405. package/dist/tokeniser/bpe.js +0 -173
  406. package/dist/tokeniser/messages.d.ts +0 -61
  407. package/dist/tokeniser/messages.js +0 -1
  408. package/dist/tokeniser/type.d.ts +0 -34
  409. package/dist/tokeniser/type.js +0 -1
  410. package/dist/training/AdamW.d.ts +0 -36
  411. package/dist/training/AdamW.js +0 -138
  412. package/dist/training/BasicTrainer.d.ts +0 -63
  413. package/dist/training/BasicTrainer.js +0 -265
  414. package/dist/training/DatasetBuilder.d.ts +0 -26
  415. package/dist/training/DatasetBuilder.js +0 -86
  416. package/dist/training/Evaluator.d.ts +0 -19
  417. package/dist/training/Evaluator.js +0 -39
  418. package/dist/training/LRScheduler.d.ts +0 -12
  419. package/dist/training/LRScheduler.js +0 -34
  420. package/dist/training/PreTrainer.d.ts +0 -11
  421. package/dist/training/PreTrainer.js +0 -20
  422. package/dist/training/SFTTrainer.d.ts +0 -12
  423. package/dist/training/SFTTrainer.js +0 -22
  424. package/dist/training/loss.d.ts +0 -3
  425. package/dist/training/loss.js +0 -24
  426. package/dist/training/orthoGrad.d.ts +0 -2
  427. package/dist/training/orthoGrad.js +0 -10
  428. package/dist/training/sparseCrossEntropy.d.ts +0 -7
  429. package/dist/training/sparseCrossEntropy.js +0 -69
  430. package/dist/training/tasks/ConversationTask.d.ts +0 -18
  431. package/dist/training/tasks/ConversationTask.js +0 -40
  432. package/dist/training/tasks/PretrainingTask.d.ts +0 -17
  433. package/dist/training/tasks/PretrainingTask.js +0 -47
  434. package/dist/training/tasks/StartSentenceTask.d.ts +0 -18
  435. package/dist/training/tasks/StartSentenceTask.js +0 -49
  436. package/dist/training/tasks/Task.d.ts +0 -22
  437. package/dist/training/tasks/Task.js +0 -68
  438. package/dist/training/tasks/splitter.d.ts +0 -5
  439. package/dist/training/tasks/splitter.js +0 -21
  440. package/dist/training/types.d.ts +0 -78
  441. package/dist/training/types.js +0 -1
  442. package/dist/training/validation.d.ts +0 -17
  443. package/dist/training/validation.js +0 -84
  444. package/dist/transpose-9kRxIXWR.js +0 -36
  445. package/dist/unsorted_segment_sum-DJvk5xnh.js +0 -277
  446. package/dist/utilities/arrayClose.d.ts +0 -1
  447. package/dist/utilities/arrayClose.js +0 -20
  448. package/dist/utilities/datasetID.d.ts +0 -2
  449. package/dist/utilities/datasetID.js +0 -21
  450. package/dist/utilities/dummy.d.ts +0 -9
  451. package/dist/utilities/dummy.js +0 -43
  452. package/dist/utilities/multinomialCPU.d.ts +0 -2
  453. package/dist/utilities/multinomialCPU.js +0 -13
  454. package/dist/utilities/naming.d.ts +0 -4
  455. package/dist/utilities/naming.js +0 -1
  456. package/dist/utilities/packed.d.ts +0 -4
  457. package/dist/utilities/packed.js +0 -15
  458. package/dist/utilities/parameters.d.ts +0 -11
  459. package/dist/utilities/parameters.js +0 -57
  460. package/dist/utilities/performance.d.ts +0 -2
  461. package/dist/utilities/performance.js +0 -16
  462. package/dist/utilities/profile.d.ts +0 -17
  463. package/dist/utilities/profile.js +0 -38
  464. package/dist/utilities/safetensors.d.ts +0 -3
  465. package/dist/utilities/safetensors.js +0 -83
  466. package/dist/utilities/sentences.d.ts +0 -5
  467. package/dist/utilities/sentences.js +0 -41
  468. package/dist/utilities/tokenParse.d.ts +0 -1
  469. package/dist/utilities/tokenParse.js +0 -21
  470. package/dist/utilities/topP.d.ts +0 -1
  471. package/dist/utilities/topP.js +0 -13
  472. package/dist/utilities/waitForModel.d.ts +0 -2
  473. package/dist/utilities/waitForModel.js +0 -12
  474. package/dist/utilities/weights.d.ts +0 -12
  475. package/dist/utilities/weights.js +0 -45
  476. package/dist/utilities/yielder.d.ts +0 -1
  477. package/dist/utilities/yielder.js +0 -7
  478. package/dist/variable-Ck482e3n.js +0 -7
  479. package/dist/webgpu_program-B4HmApL1.js +0 -525
  480. package/dist/webgpu_util-DYlGSwOJ.js +0 -64
  481. package/dist/zeros-DvZpK8s6.js +0 -13
  482. package/dist/zeros_like-CWjDdwr-.js +0 -721
@@ -1,18 +0,0 @@
1
- import { DataType, TensorInfo } from '@tensorflow/tfjs-core';
2
- import { WebGPUBackend } from '@tensorflow/tfjs-backend-webgpu/dist/webgpu';
3
- import { WebGPUProgram } from './webgpu_program';
4
- type ProgramUniform = {
5
- type: string;
6
- data: number[];
7
- }[];
8
- interface ExtendedAdapterInfo extends GPUAdapterInfo {
9
- subgroupMaxSize?: number;
10
- subgroupMinSize?: number;
11
- }
12
- export default class WebGPUBackendPatch extends WebGPUBackend {
13
- readonly subgroupMaxSize: number;
14
- readonly subgroupMinSize: number;
15
- constructor(device: GPUDevice, adapterInfo?: ExtendedAdapterInfo);
16
- runWebGPUProgram(program: WebGPUProgram, inputs: TensorInfo[], outputDtype: DataType, programDefinedUniform?: ProgramUniform, output?: TensorInfo): TensorInfo;
17
- }
18
- export {};
@@ -1,56 +0,0 @@
1
- import { U as c, af as l, ab as m, x as n } from "../index-CUXkjxiT.js";
2
- import "../webgpu_util-DYlGSwOJ.js";
3
- import { W as P } from "../backend_webgpu-BqASlsbV.js";
4
- import { compileProgram as y } from "./webgpu_program.js";
5
- import { m as M } from "../webgpu_program-B4HmApL1.js";
6
- const b = (o, s) => {
7
- const i = o.limits.maxComputeWorkgroupsPerDimension, t = s.dispatchLayout, a = s.dispatch;
8
- if (a.every((r) => r <= i))
9
- return a;
10
- n(
11
- a[0] > i && t.y === void 0 && t.z === void 0,
12
- () => "Dispatch size exceeds WebGPU limits in Y or Z dimension."
13
- );
14
- let e = Math.ceil(Math.sqrt(a[0]));
15
- return e > i ? (e = Math.ceil(Math.cbrt(a[0])), n(
16
- e <= i,
17
- () => "Total dispatch size exceeds WebGPU maximum."
18
- ), [e, e, e]) : [e, e, 1];
19
- };
20
- class U extends P {
21
- subgroupMaxSize;
22
- subgroupMinSize;
23
- constructor(s, i) {
24
- super(s, i), this.subgroupMaxSize = i?.subgroupMaxSize ?? 0, this.subgroupMinSize = i?.subgroupMinSize ?? 0;
25
- }
26
- runWebGPUProgram(s, i, t, a, e) {
27
- if (e || (e = this.makeTensorInfo(s.outputShape, t)), c(e.shape) === 0)
28
- return this.tensorMap.get(e.dataId).values = l(e.dtype, 0), e;
29
- this.uploadToGPU(e.dataId), s.dispatch = b(this.device, s);
30
- const r = i.map((h, p) => {
31
- if (h.dtype === "complex64")
32
- throw new Error(
33
- "GPGPUProgram does not support complex64 input. For complex64 dtypes, please separate the program into real and imaginary parts."
34
- );
35
- return this.uploadToGPU(h.dataId), {
36
- // Returning dtype from tensorMap because it reflects dtype
37
- // of underlying buffer, rather than abstract dtype.
38
- dtype: this.tensorMap.get(h.dataId).dtype,
39
- shape: h.shape,
40
- name: s.variableNames[p]
41
- };
42
- });
43
- s.shaderKey = M(s, r, e);
44
- const d = m().getBool("WEBGPU_ENGINE_COMPILE_ONLY");
45
- return s.shaderKey in this.pipelineCache || (this.pipelineCache[s.shaderKey] = y(
46
- this.device,
47
- s,
48
- r,
49
- e,
50
- d
51
- )), s.pipeline = this.pipelineCache[s.shaderKey], d || this.recordAndSubmit(s, e, i, a), e;
52
- }
53
- }
54
- export {
55
- U as default
56
- };
@@ -1,21 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2022 Google Inc. All Rights Reserved.
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- * =============================================================================
16
- */
17
- export interface GPUOptions {
18
- powerPreference?: 'low-power' | 'high-performance';
19
- disableSubgroups?: boolean;
20
- }
21
- export declare function registerWebGPUBackend(options?: GPUOptions): void;
@@ -1,34 +0,0 @@
1
- import { ae as n } from "../index-CUXkjxiT.js";
2
- import p from "./webgpu_backend.js";
3
- function c(a) {
4
- n(
5
- "webgpu",
6
- async () => {
7
- const i = {
8
- powerPreference: a?.powerPreference ?? "high-performance"
9
- };
10
- console.log("Using custom WebGPU backend with power preference:", i.powerPreference);
11
- const e = await navigator.gpu.requestAdapter(i), t = {}, o = [];
12
- e.features.has("timestamp-query") && o.push("timestamp-query"), e.features.has("bgra8unorm-storage") && o.push(["bgra8unorm-storage"]), !a?.disableSubgroups && e.features.has("subgroups") && o.push("subgroups"), t.requiredFeatures = o;
13
- const r = e.limits;
14
- t.requiredLimits = {
15
- maxComputeWorkgroupStorageSize: r.maxComputeWorkgroupStorageSize,
16
- maxComputeWorkgroupsPerDimension: r.maxComputeWorkgroupsPerDimension,
17
- maxStorageBufferBindingSize: r.maxStorageBufferBindingSize,
18
- maxBufferSize: r.maxBufferSize,
19
- maxComputeWorkgroupSizeX: r.maxComputeWorkgroupSizeX,
20
- maxComputeInvocationsPerWorkgroup: r.maxComputeInvocationsPerWorkgroup
21
- };
22
- const u = await e.requestDevice(t), s = "info" in e ? e.info : "requestAdapterInfo" in e ? (
23
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
24
- await e.requestAdapterInfo()
25
- ) : void 0;
26
- return new p(u, s);
27
- },
28
- 3
29
- /*priority*/
30
- );
31
- }
32
- export {
33
- c as registerWebGPUBackend
34
- };
@@ -1,36 +0,0 @@
1
- import { DataType, TensorInfo } from '@tensorflow/tfjs-core';
2
- export declare enum PixelsOpType {
3
- FROM_PIXELS = 0,
4
- DRAW = 1
5
- }
6
- export interface WebGPUProgram {
7
- atomic?: boolean;
8
- subgroups?: boolean;
9
- subgroupBuiltins?: boolean;
10
- dispatch: [number, number, number];
11
- dispatchLayout: {
12
- x: number[];
13
- y?: number[];
14
- z?: number[];
15
- };
16
- outputComponent?: number;
17
- outputShape: number[];
18
- pixelsOpType?: PixelsOpType;
19
- shaderKey: string;
20
- size?: boolean;
21
- uniforms?: string;
22
- variableNames: string[];
23
- variableComponents?: number[];
24
- workgroupSize: [number, number, number];
25
- workPerThread?: number;
26
- pipeline?: GPUComputePipeline | Promise<GPUComputePipeline>;
27
- getUserCode: () => string;
28
- }
29
- export declare const compileProgram: (device: GPUDevice, program: WebGPUProgram, inputsData: InputInfo[], output: TensorInfo, parallelCompilation: boolean) => GPUComputePipeline | Promise<GPUComputePipeline>;
30
- interface InputInfo {
31
- dtype: DataType;
32
- shape: number[];
33
- name: string;
34
- }
35
- export declare function getStartHeaderString(useGlobalIndex: boolean, program: WebGPUProgram): string;
36
- export {};
@@ -1,400 +0,0 @@
1
- import { ab as z, x as F, ac as O, ad as _ } from "../index-CUXkjxiT.js";
2
- import { g as A, d as b, a as x, b as g, s as L, t as l, c as y } from "../webgpu_program-B4HmApL1.js";
3
- var N = /* @__PURE__ */ ((s) => (s[s.FROM_PIXELS = 0] = "FROM_PIXELS", s[s.DRAW = 1] = "DRAW", s))(N || {});
4
- const H = (s, t, e, o, u) => {
5
- const a = { dtype: o.dtype, shape: o.shape }, n = D(e, a, t), r = s.createShaderModule({ code: n, label: t.constructor.name });
6
- let d = z().get("WEBGPU_PRINT_SHADER");
7
- if (d !== "") {
8
- d = d.toLowerCase();
9
- const f = d.split(",");
10
- (d === "all" || f.some((v) => t.shaderKey.toLowerCase().includes(v))) && (console.group(t.shaderKey), console.debug(n), console.groupEnd());
11
- }
12
- return u ? s.createComputePipelineAsync({
13
- compute: { module: r, entryPoint: "_start" },
14
- label: t.constructor.name,
15
- layout: "auto"
16
- }) : s.createComputePipeline({
17
- compute: { module: r, entryPoint: "_start" },
18
- label: t.constructor.name,
19
- layout: "auto"
20
- });
21
- };
22
- function D(s, t, e) {
23
- const o = [], u = e.workgroupSize[0] * e.workgroupSize[1] * e.workgroupSize[2];
24
- if (e.outputComponent = e.outputComponent ? e.outputComponent : 1, o.push(`
25
-
26
- var<private> localId: vec3<u32>;
27
- var<private> localIndex: u32;
28
- var<private> globalId: vec3<u32>;
29
- var<private> numWorkgroups: vec3<u32>;
30
- var<private> workgroupId: vec3<u32>;
31
- ${e.subgroupBuiltins ? "var<private> subgroupInvocationId: u32;" : ""}
32
- ${e.subgroupBuiltins ? "var<private> subgroupSize: u32;" : ""}
33
-
34
- // Only used when the y/z dimension of workgroup size is 1.
35
- fn getGlobalIndex() -> i32 {
36
- ${R(e) ? " return i32(globalId.x);" : ` return i32((workgroupId.z * numWorkgroups.x * numWorkgroups.y +
37
- workgroupId.y * numWorkgroups.x + workgroupId.x) * ${u}u +
38
- localIndex);
39
- `}
40
- }
41
- `), e.pixelsOpType != null) {
42
- const i = e.pixelsOpType === 0 ? `@group(0) @binding(0) var<storage, read_write> result: array<${b(
43
- t.dtype,
44
- e.outputComponent
45
- )}>;` : `@group(0) @binding(1) var<storage, read> inBuf : array<${b(
46
- s[0].dtype,
47
- e.outputComponent
48
- )}>;`, h = t.shape.length === 3 ? "vec2<i32>" : "i32";
49
- o.push(`
50
- struct Uniform {
51
- outShapeStrides : ${h},
52
- size : i32,
53
- numChannels : i32,
54
- alpha : f32,
55
- };
56
-
57
- ${i}
58
- @group(0) @binding(2) var<uniform> uniforms: Uniform;
59
- `);
60
- const I = w(e);
61
- return [
62
- C,
63
- o.join(`
64
- `),
65
- x(t.shape),
66
- e.getUserCode(),
67
- k(I, e)
68
- ].join(`
69
- `);
70
- }
71
- let a, n, r = "struct Uniforms { NAN : f32, INFINITY : f32, ";
72
- e.variableNames.forEach((i, h) => {
73
- const I = g(s[h].shape.length);
74
- r += `${i.charAt(0).toLowerCase() + i.slice(1)}Shape : ${I}, `, a = s[h].shape.length - 1, n = g(a), r += `${i.charAt(0).toLowerCase() + i.slice(1)}ShapeStrides: ${n}, `;
75
- });
76
- const d = g(t.shape.length);
77
- r += `outShape : ${d}, `, a = t.shape.length - 1, n = g(a), r += `
78
- outShapeStrides: ${n}, `, e.size && (r += "size : i32, "), e.uniforms && (r += e.uniforms), r += "};", r = P(r), o.push(r), e.atomic ? o.push(`
79
- @group(0) @binding(0) var<storage, read_write> result: array<atomic<i32>>;
80
- `) : o.push(`
81
- @group(0) @binding(0) var<storage, read_write> result: array<${b(
82
- t.dtype,
83
- e.outputComponent
84
- )}>;
85
- `), e.variableNames.forEach((i, h) => {
86
- o.push(`
87
- @group(0) @binding(${1 + h}) var<storage, read> ${i}: array<${e.variableComponents ? b(s[h].dtype, e.variableComponents[h]) : b(s[h].dtype, e.outputComponent)}>;
88
- `);
89
- }), r !== "" && o.push(`
90
- @group(0) @binding(${1 + e.variableNames.length}) var<uniform> uniforms: Uniforms;
91
- `);
92
- const f = B(t.shape, e.dispatchLayout), $ = [
93
- e.subgroups ? "enable subgroups;" : "",
94
- C,
95
- o.join(`
96
- `) + T,
97
- x(t.shape),
98
- f,
99
- W(t.shape.length)
100
- ];
101
- e.atomic || $.push(G(t.shape, t.dtype, e.outputComponent)), e.variableNames.forEach((i, h) => {
102
- $.push(`${x(s[h].shape, i)}`);
103
- });
104
- const c = s.map(
105
- (i, h) => U(
106
- i,
107
- t.shape,
108
- e.variableComponents ? e.variableComponents[h] : e.outputComponent,
109
- e.dispatchLayout.x.length === t.shape.length
110
- )
111
- ).join(`
112
- `);
113
- $.push(c), $.push(e.getUserCode());
114
- const p = w(e);
115
- return $.push(k(p, e)), $.join(`
116
- `);
117
- }
118
- const C = `
119
- struct vec5 {x: i32, y: i32, z: i32, w: i32, u: i32};
120
- struct vec6 {x: i32, y: i32, z: i32, w: i32, u: i32, v: i32};
121
-
122
- // Checks whether coordinates lie within the bounds of the shape.
123
- fn coordsInBounds2D(coord : vec2<i32>, shape : vec2<i32>) -> bool {
124
- return all(coord >= vec2<i32>(0)) && all(coord < shape);
125
- }
126
- fn coordsInBounds3D(coord : vec3<i32>, shape : vec3<i32>) -> bool {
127
- return all(coord >= vec3<i32>(0)) && all(coord < shape);
128
- }
129
- fn coordsInBounds4D(coord : vec4<i32>, shape : vec4<i32>) -> bool {
130
- return all(coord >= vec4<i32>(0)) && all(coord < shape);
131
- }
132
-
133
- fn getIndexFromCoords1D(coord : i32, shape : i32) -> i32 {
134
- return coord;
135
- }
136
- fn getIndexFromCoords2D(coords : vec2<i32>, shape : vec2<i32>) -> i32 {
137
- return dot(coords, vec2<i32>(shape.y, 1));
138
- }
139
- fn getIndexFromCoords3D(coords : vec3<i32>, shape : vec3<i32>) -> i32 {
140
- return dot(coords, vec3<i32>(shape.y * shape.z, shape.z, 1));
141
- }
142
- fn getIndexFromCoords4D(coords : vec4<i32>, shape : vec4<i32>) -> i32 {
143
- return dot(coords, vec4<i32>(
144
- shape.y * shape.z * shape.w, shape.z * shape.w, shape.w, 1));
145
- }
146
- fn getIndexFromCoords5D(coords : vec5, shape : vec5) -> i32 {
147
- let shapeStrides: vec5 = vec5(shape.y * shape.z * shape.w * shape.u, shape.z * shape.w * shape.u, shape.w * shape.u, shape.u, 1);
148
- return coords.x*shapeStrides.x + coords.y*shapeStrides.y + coords.z*shapeStrides.z + coords.w*shapeStrides.w + coords.u*shapeStrides.u;
149
- }
150
- fn getIndexFromCoords6D(coords : vec6, shape : vec6) -> i32 {
151
- let shapeStrides: vec6 = vec6(shape.y * shape.z * shape.w * shape.u * shape.v, shape.z * shape.w * shape.u * shape.v, shape.w * shape.u * shape.v, shape.u * shape.v, shape.v, 1);
152
- return coords.x*shapeStrides.x + coords.y*shapeStrides.y + coords.z*shapeStrides.z + coords.w*shapeStrides.w + coords.u*shapeStrides.u + coords.v*shapeStrides.v;
153
- }
154
-
155
- // NaN defination in IEEE 754-1985 is :
156
- // - sign = either 0 or 1.
157
- // - biased exponent = all 1 bits.
158
- // - fraction = anything except all 0 bits (since all 0 bits represents infinity).
159
- // https://en.wikipedia.org/wiki/IEEE_754-1985#Representation_of_non-numbers
160
- fn isnan(val: f32) -> bool {
161
- let floatToUint: u32 = bitcast<u32>(val);
162
- return (floatToUint & 0x7fffffffu) > 0x7f800000u;
163
- }
164
- fn isnanVec4(val : vec4<f32>) -> vec4<bool> {
165
- let floatToUint: vec4<u32> = bitcast<vec4<u32>>(val);
166
- return (floatToUint & vec4<u32>(0x7fffffffu)) > vec4<u32>(0x7f800000u);
167
- }
168
- `, T = `
169
- fn isinf(val: f32) -> bool {
170
- return abs(val) == uniforms.INFINITY;
171
- }
172
- `;
173
- function j(s, t) {
174
- const e = s.name, o = s.shape.length, u = g(o), a = "get" + e.charAt(0).toUpperCase() + e.slice(1), n = ["d0", "d1", "d2", "d3", "d4", "d5"].slice(0, o), r = n.map((v) => `${v} : i32`).join(", ");
175
- if (o < 1)
176
- return `
177
- fn ${a}() -> ${l(t)} {
178
- return ${l(t)}(${e}[0]);
179
- }
180
- `;
181
- const d = `uniforms.${e.charAt(0).toLowerCase() + e.slice(1)}Shape`;
182
- let f = `${o}D`;
183
- return o === 0 && (f = "1D"), `
184
- fn ${a}(${r}) -> ${l(t)} {
185
- return ${l(t)}(${e}[getIndexFromCoords${f}(${u}(${n.join(",")}),
186
- ${d})${t === 1 ? "" : ` / ${t}`}]);
187
- }
188
- `;
189
- }
190
- function E(s, t, e, o) {
191
- const u = s.name, a = u.charAt(0).toUpperCase() + u.slice(1), n = "get" + a + "ByOutput", r = s.shape.length, d = t.length, f = g(d);
192
- if (O(s.shape, t) && o)
193
- return `
194
- fn ${n}Index(globalIndex : i32) -> ${l(e)} {
195
- return ${l(e)}(${u}[globalIndex]);
196
- }
197
-
198
- fn ${n}Coords(coords : ${f}) -> ${l(e)} {
199
- return ${l(e)}(${u}[${d > 1 ? "getOutputIndexFromCoords(coords)" : "coords"}${e === 1 ? "" : ` / ${e}`}]);
200
- }
201
- `;
202
- const v = _(s.shape, t), $ = d - r;
203
- let c = "";
204
- if (r === 0)
205
- return `
206
- fn ${n}Index(globalIndex : i32) -> ${l(e)}{
207
- return get${a}();
208
- }
209
-
210
- fn ${n}Coords(coords : ${f}) -> ${l(e)}{
211
- return get${a}();
212
- }
213
- `;
214
- d < 2 && v.length >= 1 ? c = "coords = 0;" : c = v.map((h) => `coords.${y(h + $)} = 0;`).join(`
215
- `);
216
- let p = "";
217
- if (d < 2 && r > 0)
218
- p = "coords";
219
- else if (d > 1) {
220
- const h = g(r), I = s.shape.map((M, m) => `coords.${y(m + $)}`).join(", ");
221
- p = `${h}(${I})`;
222
- } else
223
- p = "coords";
224
- const S = `uniforms.${u.charAt(0).toLowerCase() + u.slice(1)}Shape`, i = `${r}D`;
225
- return `
226
- fn ${n}Index(globalIndex : i32) -> ${l(e)} {
227
- var coords = getCoordsFromIndex(globalIndex);
228
- ${c}
229
- return ${l(e)}(${u}[getIndexFromCoords${i}(${p}, ${S})${e === 1 ? "" : ` / ${e}`}]);
230
- }
231
-
232
- fn ${n}Coords(coordsIn : ${f}) -> ${l(e)} {
233
- var coords = coordsIn;
234
- ${c}
235
- return ${l(e)}(${u}[getIndexFromCoords${i}(${p}, ${S})${e === 1 ? "" : ` / ${e}`}]);
236
- }
237
- `;
238
- }
239
- function U(s, t, e, o) {
240
- let u = j(s, e);
241
- return s.shape.length <= t.length && (u += E(s, t, e, o)), u;
242
- }
243
- function B(s, t) {
244
- const { x: e, y: o = [], z: u = [] } = t, a = s.length, n = e.length + o.length + u.length;
245
- if (n !== a)
246
- return "";
247
- if (e.length === a)
248
- return `fn getOutputCoords() -> ${g(a)}{
249
- let globalIndex = getGlobalIndex();
250
- return getCoordsFromIndex(globalIndex);
251
- }
252
- `;
253
- let r = "";
254
- const d = [e, o, u];
255
- for (let c = 0; c < d.length; c++) {
256
- const p = d[c];
257
- if (p.length !== 0)
258
- if (p.length === 1)
259
- r += `let d${p[0]} = i32(globalId[${c}]);`;
260
- else {
261
- const S = L(p, "uniforms.outShape");
262
- r += `var index${c} = i32(globalId[${c}]);`;
263
- for (let i = 0; i < S.length; i++)
264
- r += `let d${p[i]} = index${c} / ${S[i]};`, i === S.length - 1 ? r += `let d${p[i + 1]} = index${c} - d${p[i]} * ${S[i]};` : r += `index${c} = index${c} - d${p[i]} * ${S[i]};`;
265
- }
266
- }
267
- const f = [];
268
- for (let c = 0; c < n; c++)
269
- f.push(`d${c}`);
270
- const v = g(n);
271
- let $ = `fn getOutputCoords() -> ${v} {
272
- ${r}
273
- `;
274
- return f.length === 0 ? $ += `return ${v}(0); }` : $ += `return ${v}(${f.join(",")}); }`, $;
275
- }
276
- function W(s) {
277
- let t = "";
278
- switch (s) {
279
- case 0:
280
- case 1:
281
- t += `
282
- fn getOutputIndexFromCoords(coords : i32) -> i32 {
283
- return coords;
284
- }
285
- `;
286
- break;
287
- case 2:
288
- t += `
289
- fn getOutputIndexFromCoords(coords : vec2<i32>) -> i32 {
290
- return dot(coords, vec2<i32>(uniforms.outShapeStrides, 1));
291
- }
292
- `;
293
- break;
294
- case 3:
295
- t += `
296
- fn getOutputIndexFromCoords(coords : vec3<i32>) -> i32 {
297
- return dot(coords, vec3<i32>(uniforms.outShapeStrides.x, uniforms.outShapeStrides.y, 1));
298
- }
299
- `;
300
- break;
301
- case 4:
302
- t += `
303
- fn getOutputIndexFromCoords(coords : vec4<i32>) -> i32 {
304
- return dot(coords, vec4<i32>(
305
- uniforms.outShapeStrides.x, uniforms.outShapeStrides.y, uniforms.outShapeStrides.z, 1));
306
- }
307
- `;
308
- break;
309
- case 5:
310
- t += `
311
- fn getOutputIndexFromCoords(coords : vec5) -> i32 {
312
- return coords.x * uniforms.outShapeStrides.x +
313
- coords.y * uniforms.outShapeStrides.y +
314
- coords.z * uniforms.outShapeStrides.z +
315
- coords.w * uniforms.outShapeStrides.w +
316
- coords.u;
317
- }
318
- `;
319
- break;
320
- case 6:
321
- t += `
322
- fn getOutputIndexFromCoords(coords : vec6) -> i32 {
323
- return coords.x * uniforms.outShapeStrides.x +
324
- coords.y * uniforms.outShapeStrides.y +
325
- coords.z * uniforms.outShapeStrides.z +
326
- coords.w * uniforms.outShapeStrides.w +
327
- coords.u * uniforms.outShapeStrides.u +
328
- coords.v;
329
- }
330
- `;
331
- break;
332
- default:
333
- F(!1, () => `Unsupported ${s}D shape`);
334
- break;
335
- }
336
- return t;
337
- }
338
- function R(s) {
339
- return s.dispatch[1] === 1 && s.dispatch[2] === 1;
340
- }
341
- function G(s, t, e) {
342
- const o = s.length, u = b(t, e);
343
- let a = `fn setOutputAtIndex(flatIndex : i32, value : ${l(e)}) {
344
- result[flatIndex] = ${u}(value);
345
- }
346
-
347
- fn setOutputAtIndexI32(flatIndex : i32, value : ${l(e, "i32")}) {
348
- result[flatIndex] = ${u}(value);
349
- }
350
- `;
351
- if (o >= 2) {
352
- const n = ["d0", "d1", "d2", "d3", "d4", "d5"].slice(0, o), r = g(o);
353
- a += `
354
- fn setOutputAtCoords(${n.map((d) => `${d} : i32`).join(", ")}, value : ${l(e)}) {
355
- let flatIndex = getOutputIndexFromCoords(${r}(${n.join(", ")}));
356
- setOutputAtIndex(flatIndex${e === 1 ? "" : ` / ${e}`}, value);
357
- }
358
- fn setOutputAtCoordsI32(${n.map((d) => `${d} : i32`).join(", ")}, value : ${l(e, "i32")}) {
359
- let flatIndex = getOutputIndexFromCoords(${r}(${n.join(", ")}));
360
- setOutputAtIndexI32(flatIndex${e === 1 ? "" : ` / ${e}`}, value);
361
- }
362
- `;
363
- }
364
- return a;
365
- }
366
- function P(s) {
367
- const t = /(\w+)\s*:\s*vec(5|6)/g;
368
- s = s.replace(t, (o) => "@align(16) " + o);
369
- const e = /vec(5|6)\s*,\s*(\w+)/g;
370
- return s = s.replace(e, (o, u, a) => `vec${u}, @align(16) ${a}`), s;
371
- }
372
- function w(s) {
373
- return !(s.dispatchLayout.hasOwnProperty("y") && s.dispatchLayout.y?.length !== 0 || s.dispatchLayout.hasOwnProperty("z") && s.dispatchLayout.z?.length !== 0);
374
- }
375
- function k(s, t) {
376
- return `
377
- ${A(t)}
378
- fn _start(@builtin(local_invocation_id) LocalId : vec3<u32>,
379
- @builtin(global_invocation_id) GlobalId : vec3<u32>,
380
- @builtin(local_invocation_index) LocalIndex: u32,
381
- @builtin(workgroup_id) WorkgroupId : vec3<u32>,
382
- ${t.subgroupBuiltins ? "@builtin(subgroup_invocation_id) SubgroupInvocationId : u32," : ""}
383
- ${t.subgroupBuiltins ? "@builtin(subgroup_size) SubgroupSize : u32," : ""}
384
- @builtin(num_workgroups) NumWorkgroups : vec3<u32>) {
385
- localId = LocalId;
386
- localIndex = LocalIndex;
387
- globalId = GlobalId;
388
- numWorkgroups = NumWorkgroups;
389
- workgroupId = WorkgroupId;
390
- ${t.subgroupBuiltins ? "subgroupInvocationId = SubgroupInvocationId" : ""};
391
- ${t.subgroupBuiltins ? "subgroupSize = SubgroupSize" : ""};
392
- ${s ? "main(getGlobalIndex());" : "main();"};
393
- }
394
- `;
395
- }
396
- export {
397
- N as PixelsOpType,
398
- H as compileProgram,
399
- k as getStartHeaderString
400
- };