cactus-react-native 1.4.0 → 1.7.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 (226) hide show
  1. package/Cactus.podspec +1 -1
  2. package/README.md +465 -174
  3. package/android/CMakeLists.txt +24 -5
  4. package/android/src/main/jniLibs/arm64-v8a/libcactus.a +0 -0
  5. package/android/src/main/jniLibs/arm64-v8a/libcurl.a +0 -0
  6. package/android/src/main/jniLibs/arm64-v8a/libmbedcrypto.a +0 -0
  7. package/android/src/main/jniLibs/arm64-v8a/libmbedtls.a +0 -0
  8. package/android/src/main/jniLibs/arm64-v8a/libmbedx509.a +0 -0
  9. package/cpp/HybridCactus.cpp +157 -6
  10. package/cpp/HybridCactus.hpp +20 -3
  11. package/cpp/cactus_ffi.h +65 -30
  12. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/cactus.h +0 -1
  13. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/cactus_ffi.h +65 -30
  14. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/cactus_utils.h +357 -122
  15. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/engine.h +184 -63
  16. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/gemma_tools.h +549 -0
  17. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/graph.h +153 -27
  18. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/kernel.h +90 -178
  19. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/kernel_utils.h +276 -151
  20. package/ios/cactus.xcframework/ios-arm64/cactus.framework/cactus +0 -0
  21. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/cactus.h +0 -1
  22. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/cactus_ffi.h +65 -30
  23. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/cactus_utils.h +357 -122
  24. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/engine.h +184 -63
  25. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/gemma_tools.h +549 -0
  26. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/graph.h +153 -27
  27. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/kernel.h +90 -178
  28. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/kernel_utils.h +276 -151
  29. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/cactus +0 -0
  30. package/lib/module/classes/CactusLM.js +43 -58
  31. package/lib/module/classes/CactusLM.js.map +1 -1
  32. package/lib/module/classes/CactusSTT.js +64 -38
  33. package/lib/module/classes/CactusSTT.js.map +1 -1
  34. package/lib/module/classes/CactusVAD.js +95 -0
  35. package/lib/module/classes/CactusVAD.js.map +1 -0
  36. package/lib/module/hooks/useCactusLM.js +23 -15
  37. package/lib/module/hooks/useCactusLM.js.map +1 -1
  38. package/lib/module/hooks/useCactusSTT.js +85 -28
  39. package/lib/module/hooks/useCactusSTT.js.map +1 -1
  40. package/lib/module/hooks/useCactusVAD.js +171 -0
  41. package/lib/module/hooks/useCactusVAD.js.map +1 -0
  42. package/lib/module/index.js +2 -3
  43. package/lib/module/index.js.map +1 -1
  44. package/lib/module/modelRegistry.js +52 -0
  45. package/lib/module/modelRegistry.js.map +1 -0
  46. package/lib/module/native/Cactus.js +107 -8
  47. package/lib/module/native/Cactus.js.map +1 -1
  48. package/lib/module/native/CactusIndex.js.map +1 -1
  49. package/lib/module/native/index.js +0 -3
  50. package/lib/module/native/index.js.map +1 -1
  51. package/lib/module/types/CactusLM.js +2 -0
  52. package/lib/module/types/CactusSTT.js +2 -0
  53. package/lib/module/types/CactusVAD.js +4 -0
  54. package/lib/module/types/{CactusModel.js.map → CactusVAD.js.map} +1 -1
  55. package/lib/module/types/common.js +2 -0
  56. package/lib/module/types/{CactusSTTModel.js.map → common.js.map} +1 -1
  57. package/lib/typescript/src/classes/CactusLM.d.ts +8 -6
  58. package/lib/typescript/src/classes/CactusLM.d.ts.map +1 -1
  59. package/lib/typescript/src/classes/CactusSTT.d.ts +11 -6
  60. package/lib/typescript/src/classes/CactusSTT.d.ts.map +1 -1
  61. package/lib/typescript/src/classes/CactusVAD.d.ts +20 -0
  62. package/lib/typescript/src/classes/CactusVAD.d.ts.map +1 -0
  63. package/lib/typescript/src/hooks/useCactusLM.d.ts +3 -3
  64. package/lib/typescript/src/hooks/useCactusLM.d.ts.map +1 -1
  65. package/lib/typescript/src/hooks/useCactusSTT.d.ts +11 -5
  66. package/lib/typescript/src/hooks/useCactusSTT.d.ts.map +1 -1
  67. package/lib/typescript/src/hooks/useCactusVAD.d.ts +15 -0
  68. package/lib/typescript/src/hooks/useCactusVAD.d.ts.map +1 -0
  69. package/lib/typescript/src/index.d.ts +7 -6
  70. package/lib/typescript/src/index.d.ts.map +1 -1
  71. package/lib/typescript/src/modelRegistry.d.ts +5 -0
  72. package/lib/typescript/src/modelRegistry.d.ts.map +1 -0
  73. package/lib/typescript/src/native/Cactus.d.ts +12 -6
  74. package/lib/typescript/src/native/Cactus.d.ts.map +1 -1
  75. package/lib/typescript/src/native/CactusIndex.d.ts +2 -2
  76. package/lib/typescript/src/native/CactusIndex.d.ts.map +1 -1
  77. package/lib/typescript/src/native/index.d.ts +0 -3
  78. package/lib/typescript/src/native/index.d.ts.map +1 -1
  79. package/lib/typescript/src/specs/Cactus.nitro.d.ts +6 -1
  80. package/lib/typescript/src/specs/Cactus.nitro.d.ts.map +1 -1
  81. package/lib/typescript/src/types/CactusIndex.d.ts +2 -2
  82. package/lib/typescript/src/types/CactusIndex.d.ts.map +1 -1
  83. package/lib/typescript/src/types/CactusLM.d.ts +19 -9
  84. package/lib/typescript/src/types/CactusLM.d.ts.map +1 -1
  85. package/lib/typescript/src/types/CactusSTT.d.ts +45 -4
  86. package/lib/typescript/src/types/CactusSTT.d.ts.map +1 -1
  87. package/lib/typescript/src/types/CactusVAD.d.ts +34 -0
  88. package/lib/typescript/src/types/CactusVAD.d.ts.map +1 -0
  89. package/lib/typescript/src/types/common.d.ts +23 -0
  90. package/lib/typescript/src/types/common.d.ts.map +1 -0
  91. package/nitro.json +0 -11
  92. package/nitrogen/generated/android/cactus+autolinking.cmake +0 -5
  93. package/nitrogen/generated/android/cactusOnLoad.cpp +0 -30
  94. package/nitrogen/generated/ios/Cactus-Swift-Cxx-Bridge.cpp +0 -50
  95. package/nitrogen/generated/ios/Cactus-Swift-Cxx-Bridge.hpp +9 -147
  96. package/nitrogen/generated/ios/Cactus-Swift-Cxx-Umbrella.hpp +0 -13
  97. package/nitrogen/generated/ios/CactusAutolinking.mm +0 -26
  98. package/nitrogen/generated/ios/CactusAutolinking.swift +0 -30
  99. package/nitrogen/generated/shared/c++/HybridCactusSpec.cpp +5 -0
  100. package/nitrogen/generated/shared/c++/HybridCactusSpec.hpp +6 -1
  101. package/package.json +3 -3
  102. package/src/classes/CactusLM.ts +59 -74
  103. package/src/classes/CactusSTT.ts +92 -49
  104. package/src/classes/CactusVAD.ts +129 -0
  105. package/src/hooks/useCactusLM.ts +26 -9
  106. package/src/hooks/useCactusSTT.ts +105 -44
  107. package/src/hooks/useCactusVAD.ts +215 -0
  108. package/src/index.tsx +20 -10
  109. package/src/modelRegistry.ts +65 -0
  110. package/src/native/Cactus.ts +130 -14
  111. package/src/native/CactusIndex.ts +2 -2
  112. package/src/native/index.ts +0 -3
  113. package/src/specs/Cactus.nitro.ts +11 -2
  114. package/src/types/CactusIndex.ts +2 -2
  115. package/src/types/CactusLM.ts +20 -9
  116. package/src/types/CactusSTT.ts +50 -4
  117. package/src/types/CactusVAD.ts +39 -0
  118. package/src/types/common.ts +23 -0
  119. package/android/src/main/java/com/margelo/nitro/cactus/HybridCactusCrypto.kt +0 -46
  120. package/android/src/main/java/com/margelo/nitro/cactus/HybridCactusDeviceInfo.kt +0 -27
  121. package/android/src/main/jniLibs/arm64-v8a/libcactus_util.a +0 -0
  122. package/cpp/HybridCactusUtil.cpp +0 -47
  123. package/cpp/HybridCactusUtil.hpp +0 -27
  124. package/cpp/cactus_util.h +0 -25
  125. package/ios/HybridCactusCrypto.swift +0 -37
  126. package/ios/HybridCactusDeviceInfo.swift +0 -32
  127. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/cactus_telemetry.h +0 -656
  128. package/ios/cactus.xcframework/ios-arm64-simulator/cactus.framework/Headers/cactus_telemetry.h +0 -656
  129. package/ios/cactus_util.xcframework/Info.plist +0 -39
  130. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/Headers/cactus_util.h +0 -25
  131. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/Headers/database.h +0 -27
  132. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/Headers/ios_utils.h +0 -10
  133. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/Headers/logging.h +0 -25
  134. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/Info.plist +0 -0
  135. package/ios/cactus_util.xcframework/ios-arm64/cactus_util.framework/cactus_util +0 -0
  136. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/Headers/cactus_util.h +0 -25
  137. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/Headers/database.h +0 -27
  138. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/Headers/ios_utils.h +0 -10
  139. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/Headers/logging.h +0 -25
  140. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/Info.plist +0 -0
  141. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/_CodeSignature/CodeResources +0 -135
  142. package/ios/cactus_util.xcframework/ios-arm64-simulator/cactus_util.framework/cactus_util +0 -0
  143. package/lib/module/api/Database.js +0 -137
  144. package/lib/module/api/Database.js.map +0 -1
  145. package/lib/module/api/RemoteLM.js +0 -201
  146. package/lib/module/api/RemoteLM.js.map +0 -1
  147. package/lib/module/config/CactusConfig.js +0 -12
  148. package/lib/module/config/CactusConfig.js.map +0 -1
  149. package/lib/module/native/CactusCrypto.js +0 -10
  150. package/lib/module/native/CactusCrypto.js.map +0 -1
  151. package/lib/module/native/CactusDeviceInfo.js +0 -13
  152. package/lib/module/native/CactusDeviceInfo.js.map +0 -1
  153. package/lib/module/native/CactusUtil.js +0 -36
  154. package/lib/module/native/CactusUtil.js.map +0 -1
  155. package/lib/module/specs/CactusCrypto.nitro.js +0 -4
  156. package/lib/module/specs/CactusCrypto.nitro.js.map +0 -1
  157. package/lib/module/specs/CactusDeviceInfo.nitro.js +0 -4
  158. package/lib/module/specs/CactusDeviceInfo.nitro.js.map +0 -1
  159. package/lib/module/specs/CactusUtil.nitro.js +0 -4
  160. package/lib/module/specs/CactusUtil.nitro.js.map +0 -1
  161. package/lib/module/telemetry/Telemetry.js +0 -154
  162. package/lib/module/telemetry/Telemetry.js.map +0 -1
  163. package/lib/module/types/CactusModel.js +0 -2
  164. package/lib/module/types/CactusSTTModel.js +0 -2
  165. package/lib/typescript/src/api/Database.d.ts +0 -18
  166. package/lib/typescript/src/api/Database.d.ts.map +0 -1
  167. package/lib/typescript/src/api/RemoteLM.d.ts +0 -14
  168. package/lib/typescript/src/api/RemoteLM.d.ts.map +0 -1
  169. package/lib/typescript/src/config/CactusConfig.d.ts +0 -7
  170. package/lib/typescript/src/config/CactusConfig.d.ts.map +0 -1
  171. package/lib/typescript/src/native/CactusCrypto.d.ts +0 -5
  172. package/lib/typescript/src/native/CactusCrypto.d.ts.map +0 -1
  173. package/lib/typescript/src/native/CactusDeviceInfo.d.ts +0 -7
  174. package/lib/typescript/src/native/CactusDeviceInfo.d.ts.map +0 -1
  175. package/lib/typescript/src/native/CactusUtil.d.ts +0 -6
  176. package/lib/typescript/src/native/CactusUtil.d.ts.map +0 -1
  177. package/lib/typescript/src/specs/CactusCrypto.nitro.d.ts +0 -8
  178. package/lib/typescript/src/specs/CactusCrypto.nitro.d.ts.map +0 -1
  179. package/lib/typescript/src/specs/CactusDeviceInfo.nitro.d.ts +0 -16
  180. package/lib/typescript/src/specs/CactusDeviceInfo.nitro.d.ts.map +0 -1
  181. package/lib/typescript/src/specs/CactusUtil.nitro.d.ts +0 -10
  182. package/lib/typescript/src/specs/CactusUtil.nitro.d.ts.map +0 -1
  183. package/lib/typescript/src/telemetry/Telemetry.d.ts +0 -34
  184. package/lib/typescript/src/telemetry/Telemetry.d.ts.map +0 -1
  185. package/lib/typescript/src/types/CactusModel.d.ts +0 -13
  186. package/lib/typescript/src/types/CactusModel.d.ts.map +0 -1
  187. package/lib/typescript/src/types/CactusSTTModel.d.ts +0 -8
  188. package/lib/typescript/src/types/CactusSTTModel.d.ts.map +0 -1
  189. package/nitrogen/generated/android/c++/JDeviceInfo.hpp +0 -74
  190. package/nitrogen/generated/android/c++/JHybridCactusCryptoSpec.cpp +0 -65
  191. package/nitrogen/generated/android/c++/JHybridCactusCryptoSpec.hpp +0 -65
  192. package/nitrogen/generated/android/c++/JHybridCactusDeviceInfoSpec.cpp +0 -85
  193. package/nitrogen/generated/android/c++/JHybridCactusDeviceInfoSpec.hpp +0 -66
  194. package/nitrogen/generated/android/kotlin/com/margelo/nitro/cactus/DeviceInfo.kt +0 -50
  195. package/nitrogen/generated/android/kotlin/com/margelo/nitro/cactus/HybridCactusCryptoSpec.kt +0 -58
  196. package/nitrogen/generated/android/kotlin/com/margelo/nitro/cactus/HybridCactusDeviceInfoSpec.kt +0 -62
  197. package/nitrogen/generated/ios/c++/HybridCactusCryptoSpecSwift.cpp +0 -11
  198. package/nitrogen/generated/ios/c++/HybridCactusCryptoSpecSwift.hpp +0 -77
  199. package/nitrogen/generated/ios/c++/HybridCactusDeviceInfoSpecSwift.cpp +0 -11
  200. package/nitrogen/generated/ios/c++/HybridCactusDeviceInfoSpecSwift.hpp +0 -88
  201. package/nitrogen/generated/ios/swift/DeviceInfo.swift +0 -98
  202. package/nitrogen/generated/ios/swift/Func_void_DeviceInfo.swift +0 -47
  203. package/nitrogen/generated/ios/swift/Func_void_std__optional_std__string_.swift +0 -54
  204. package/nitrogen/generated/ios/swift/HybridCactusCryptoSpec.swift +0 -57
  205. package/nitrogen/generated/ios/swift/HybridCactusCryptoSpec_cxx.swift +0 -139
  206. package/nitrogen/generated/ios/swift/HybridCactusDeviceInfoSpec.swift +0 -58
  207. package/nitrogen/generated/ios/swift/HybridCactusDeviceInfoSpec_cxx.swift +0 -164
  208. package/nitrogen/generated/shared/c++/DeviceInfo.hpp +0 -92
  209. package/nitrogen/generated/shared/c++/HybridCactusCryptoSpec.cpp +0 -21
  210. package/nitrogen/generated/shared/c++/HybridCactusCryptoSpec.hpp +0 -63
  211. package/nitrogen/generated/shared/c++/HybridCactusDeviceInfoSpec.cpp +0 -22
  212. package/nitrogen/generated/shared/c++/HybridCactusDeviceInfoSpec.hpp +0 -67
  213. package/nitrogen/generated/shared/c++/HybridCactusUtilSpec.cpp +0 -23
  214. package/nitrogen/generated/shared/c++/HybridCactusUtilSpec.hpp +0 -66
  215. package/src/api/Database.ts +0 -188
  216. package/src/api/RemoteLM.ts +0 -273
  217. package/src/config/CactusConfig.ts +0 -11
  218. package/src/native/CactusCrypto.ts +0 -11
  219. package/src/native/CactusDeviceInfo.ts +0 -18
  220. package/src/native/CactusUtil.ts +0 -43
  221. package/src/specs/CactusCrypto.nitro.ts +0 -6
  222. package/src/specs/CactusDeviceInfo.nitro.ts +0 -15
  223. package/src/specs/CactusUtil.nitro.ts +0 -8
  224. package/src/telemetry/Telemetry.ts +0 -236
  225. package/src/types/CactusModel.ts +0 -15
  226. package/src/types/CactusSTTModel.ts +0 -10
@@ -1,32 +1,38 @@
1
1
  "use strict";
2
2
 
3
3
  import { Cactus, CactusFileSystem } from "../native/index.js";
4
- import { Telemetry } from "../telemetry/Telemetry.js";
5
- import { CactusConfig } from "../config/CactusConfig.js";
6
- import { Database } from "../api/Database.js";
7
- import { getErrorMessage } from "../utils/error.js";
8
- import { RemoteLM } from "../api/RemoteLM.js";
4
+ import { getRegistry } from "../modelRegistry.js";
9
5
  export class CactusLM {
10
6
  cactus = new Cactus();
11
7
  isDownloading = false;
12
8
  isInitialized = false;
13
9
  isGenerating = false;
14
- static defaultModel = 'qwen3-0.6';
15
- static defaultContextSize = 2048;
10
+ static defaultModel = 'qwen3-0.6b';
11
+ static defaultOptions = {
12
+ quantization: 'int8',
13
+ pro: false
14
+ };
15
+ static quantizationExceptions = {
16
+ 'gemma-3-270m-it': 'int8',
17
+ 'functiongemma-270m-it': 'int8'
18
+ };
16
19
  static defaultCompleteOptions = {
17
20
  maxTokens: 512
18
21
  };
19
- static defaultCompleteMode = 'local';
20
22
  static defaultEmbedBufferSize = 2048;
21
23
  constructor({
22
24
  model,
23
- contextSize,
24
- corpusDir
25
+ corpusDir,
26
+ cacheIndex,
27
+ options
25
28
  } = {}) {
26
- Telemetry.init(CactusConfig.telemetryToken);
27
29
  this.model = model ?? CactusLM.defaultModel;
28
- this.contextSize = contextSize ?? CactusLM.defaultContextSize;
29
30
  this.corpusDir = corpusDir;
31
+ this.cacheIndex = cacheIndex ?? false;
32
+ this.options = {
33
+ quantization: options?.quantization ?? CactusLM.quantizationExceptions[this.model] ?? CactusLM.defaultOptions.quantization,
34
+ pro: options?.pro ?? CactusLM.defaultOptions.pro
35
+ };
30
36
  }
31
37
  async download({
32
38
  onProgress
@@ -38,14 +44,20 @@ export class CactusLM {
38
44
  if (this.isDownloading) {
39
45
  throw new Error('CactusLM is already downloading');
40
46
  }
41
- if (await CactusFileSystem.modelExists(this.model)) {
47
+ if (await CactusFileSystem.modelExists(this.getModelName())) {
48
+ console.log('Model already exists', this.getModelName());
42
49
  onProgress?.(1.0);
43
50
  return;
44
51
  }
45
52
  this.isDownloading = true;
46
53
  try {
47
- const model = await Database.getModel(this.model);
48
- await CactusFileSystem.downloadModel(this.model, model.downloadUrl, onProgress);
54
+ const registry = await getRegistry();
55
+ const modelConfig = registry[this.model]?.quantization[this.options.quantization];
56
+ const url = this.options.pro ? modelConfig?.pro?.apple : modelConfig?.url;
57
+ if (!url) {
58
+ throw new Error(`Model ${this.model} with specified options not found`);
59
+ }
60
+ await CactusFileSystem.downloadModel(this.getModelName(), url, onProgress);
49
61
  } finally {
50
62
  this.isDownloading = false;
51
63
  }
@@ -58,26 +70,22 @@ export class CactusLM {
58
70
  if (this.isModelPath(this.model)) {
59
71
  modelPath = this.model.replace('file://', '');
60
72
  } else {
61
- if (!(await CactusFileSystem.modelExists(this.model))) {
62
- throw new Error(`Model "${this.model}" is not downloaded`);
73
+ if (!(await CactusFileSystem.modelExists(this.getModelName()))) {
74
+ console.log('Model not found:', this.getModelName());
75
+ throw new Error(`Model "${this.model}" with options ${JSON.stringify(this.options)} is not downloaded`);
63
76
  }
64
- modelPath = await CactusFileSystem.getModelPath(this.model);
65
- }
66
- try {
67
- await this.cactus.init(modelPath, this.contextSize, this.corpusDir);
68
- Telemetry.logInit(this.model, true);
69
- this.isInitialized = true;
70
- } catch (error) {
71
- Telemetry.logInit(this.model, false, getErrorMessage(error));
72
- throw error;
77
+ modelPath = await CactusFileSystem.getModelPath(this.getModelName());
73
78
  }
79
+ const cacheDir = await CactusFileSystem.getCactusDirectory();
80
+ await this.cactus.setTelemetryEnvironment(cacheDir);
81
+ await this.cactus.init(modelPath, this.corpusDir, this.cacheIndex);
82
+ this.isInitialized = true;
74
83
  }
75
84
  async complete({
76
85
  messages,
77
86
  options,
78
87
  tools,
79
- onToken,
80
- mode
88
+ onToken
81
89
  }) {
82
90
  if (this.isGenerating) {
83
91
  throw new Error('CactusLM is already generating');
@@ -90,25 +98,11 @@ export class CactusLM {
90
98
  type: 'function',
91
99
  function: tool
92
100
  }));
93
- mode = mode ?? CactusLM.defaultCompleteMode;
94
101
  const responseBufferSize = 8 * (options.maxTokens ?? CactusLM.defaultCompleteOptions.maxTokens) + 256;
102
+ await this.init();
103
+ this.isGenerating = true;
95
104
  try {
96
- await this.init();
97
- this.isGenerating = true;
98
- const result = await this.cactus.complete(messages, responseBufferSize, options, toolsInternal, onToken);
99
- Telemetry.logCompletion(this.model, result.success, result.success ? undefined : result.response, result);
100
- return result;
101
- } catch (localError) {
102
- if (mode === 'local') {
103
- Telemetry.logCompletion(this.model, false, getErrorMessage(localError));
104
- throw localError;
105
- }
106
- Telemetry.logCompletion(this.model, false, `Local completion error: ${getErrorMessage(localError)}. Falling back to remote completion.`);
107
- try {
108
- return RemoteLM.complete(messages, options, toolsInternal, onToken);
109
- } catch (remoteError) {
110
- throw new Error(`Remote completion error: ${getErrorMessage(remoteError)}`);
111
- }
105
+ return await this.cactus.complete(messages, responseBufferSize, options, toolsInternal, onToken);
112
106
  } finally {
113
107
  this.isGenerating = false;
114
108
  }
@@ -141,13 +135,9 @@ export class CactusLM {
141
135
  this.isGenerating = true;
142
136
  try {
143
137
  const embedding = await this.cactus.embed(text, CactusLM.defaultEmbedBufferSize, normalize);
144
- Telemetry.logEmbedding(this.model, true);
145
138
  return {
146
139
  embedding
147
140
  };
148
- } catch (error) {
149
- Telemetry.logEmbedding(this.model, false, getErrorMessage(error));
150
- throw error;
151
141
  } finally {
152
142
  this.isGenerating = false;
153
143
  }
@@ -162,13 +152,9 @@ export class CactusLM {
162
152
  this.isGenerating = true;
163
153
  try {
164
154
  const embedding = await this.cactus.imageEmbed(imagePath, CactusLM.defaultEmbedBufferSize);
165
- Telemetry.logImageEmbedding(this.model, true);
166
155
  return {
167
156
  embedding
168
157
  };
169
- } catch (error) {
170
- Telemetry.logImageEmbedding(this.model, false, getErrorMessage(error));
171
- throw error;
172
158
  } finally {
173
159
  this.isGenerating = false;
174
160
  }
@@ -189,14 +175,13 @@ export class CactusLM {
189
175
  this.isInitialized = false;
190
176
  }
191
177
  async getModels() {
192
- const models = await Database.getModels();
193
- for (const model of models) {
194
- model.isDownloaded = await CactusFileSystem.modelExists(model.slug);
195
- }
196
- return models;
178
+ return Object.values(await getRegistry());
197
179
  }
198
180
  isModelPath(model) {
199
181
  return model.startsWith('file://') || model.startsWith('/');
200
182
  }
183
+ getModelName() {
184
+ return `${this.model}-${this.options.quantization}${this.options.pro ? '-pro' : ''}`;
185
+ }
201
186
  }
202
187
  //# sourceMappingURL=CactusLM.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Cactus","CactusFileSystem","Telemetry","CactusConfig","Database","getErrorMessage","RemoteLM","CactusLM","cactus","isDownloading","isInitialized","isGenerating","defaultModel","defaultContextSize","defaultCompleteOptions","maxTokens","defaultCompleteMode","defaultEmbedBufferSize","constructor","model","contextSize","corpusDir","init","telemetryToken","download","onProgress","isModelPath","Error","modelExists","getModel","downloadModel","downloadUrl","modelPath","replace","getModelPath","logInit","error","complete","messages","options","tools","onToken","mode","toolsInternal","map","tool","type","function","responseBufferSize","result","logCompletion","success","undefined","response","localError","remoteError","tokenize","text","tokens","scoreWindow","start","end","context","score","embed","normalize","embedding","logEmbedding","imageEmbed","imagePath","logImageEmbedding","stop","reset","destroy","getModels","models","isDownloaded","slug","startsWith"],"sourceRoot":"../../../src","sources":["classes/CactusLM.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Cactus","CactusFileSystem","getRegistry","CactusLM","cactus","isDownloading","isInitialized","isGenerating","defaultModel","defaultOptions","quantization","pro","quantizationExceptions","defaultCompleteOptions","maxTokens","defaultEmbedBufferSize","constructor","model","corpusDir","cacheIndex","options","download","onProgress","isModelPath","Error","modelExists","getModelName","console","log","registry","modelConfig","url","apple","downloadModel","init","modelPath","replace","JSON","stringify","getModelPath","cacheDir","getCactusDirectory","setTelemetryEnvironment","complete","messages","tools","onToken","toolsInternal","map","tool","type","function","responseBufferSize","tokenize","text","tokens","scoreWindow","start","end","context","score","embed","normalize","embedding","imageEmbed","imagePath","stop","reset","destroy","getModels","Object","values","startsWith"],"sourceRoot":"../../../src","sources":["classes/CactusLM.ts"],"mappings":"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","ignoreList":[]}
@@ -1,29 +1,32 @@
1
1
  "use strict";
2
2
 
3
3
  import { Cactus, CactusFileSystem } from "../native/index.js";
4
- import { Telemetry } from "../telemetry/Telemetry.js";
5
- import { CactusConfig } from "../config/CactusConfig.js";
6
- import { Database } from "../api/Database.js";
7
- import { getErrorMessage } from "../utils/error.js";
4
+ import { getRegistry } from "../modelRegistry.js";
8
5
  export class CactusSTT {
9
6
  cactus = new Cactus();
10
7
  isDownloading = false;
11
8
  isInitialized = false;
12
9
  isGenerating = false;
10
+ isStreamTranscribing = false;
13
11
  static defaultModel = 'whisper-small';
14
- static defaultContextSize = 2048;
12
+ static defaultOptions = {
13
+ quantization: 'int8',
14
+ pro: false
15
+ };
15
16
  static defaultPrompt = '<|startoftranscript|><|en|><|transcribe|><|notimestamps|>';
16
17
  static defaultTranscribeOptions = {
17
- maxTokens: 512
18
+ maxTokens: 384
18
19
  };
19
20
  static defaultEmbedBufferSize = 4096;
20
21
  constructor({
21
22
  model,
22
- contextSize
23
+ options
23
24
  } = {}) {
24
- Telemetry.init(CactusConfig.telemetryToken);
25
25
  this.model = model ?? CactusSTT.defaultModel;
26
- this.contextSize = contextSize ?? CactusSTT.defaultContextSize;
26
+ this.options = {
27
+ quantization: options?.quantization ?? CactusSTT.defaultOptions.quantization,
28
+ pro: options?.pro ?? CactusSTT.defaultOptions.pro
29
+ };
27
30
  }
28
31
  async download({
29
32
  onProgress
@@ -35,14 +38,20 @@ export class CactusSTT {
35
38
  if (this.isDownloading) {
36
39
  throw new Error('CactusSTT is already downloading');
37
40
  }
38
- if (await CactusFileSystem.modelExists(this.model)) {
41
+ if (await CactusFileSystem.modelExists(this.getModelName())) {
42
+ console.log('Model already exists', this.getModelName());
39
43
  onProgress?.(1.0);
40
44
  return;
41
45
  }
42
46
  this.isDownloading = true;
43
47
  try {
44
- const model = await Database.getSTTModel(this.model);
45
- await CactusFileSystem.downloadModel(this.model, model.downloadUrl, onProgress);
48
+ const registry = await getRegistry();
49
+ const modelConfig = registry[this.model]?.quantization[this.options.quantization];
50
+ const url = this.options.pro ? modelConfig?.pro?.apple : modelConfig?.url;
51
+ if (!url) {
52
+ throw new Error(`Model ${this.model} with specified options not found`);
53
+ }
54
+ await CactusFileSystem.downloadModel(this.getModelName(), url, onProgress);
46
55
  } finally {
47
56
  this.isDownloading = false;
48
57
  }
@@ -55,19 +64,16 @@ export class CactusSTT {
55
64
  if (this.isModelPath(this.model)) {
56
65
  modelPath = this.model.replace('file://', '');
57
66
  } else {
58
- if (!(await CactusFileSystem.modelExists(this.model))) {
59
- throw new Error(`Model "${this.model}" is not downloaded`);
67
+ if (!(await CactusFileSystem.modelExists(this.getModelName()))) {
68
+ console.log('Model does not exist', this.getModelName());
69
+ throw new Error(`Model "${this.model}" with options ${JSON.stringify(this.options)} is not downloaded`);
60
70
  }
61
- modelPath = await CactusFileSystem.getModelPath(this.model);
62
- }
63
- try {
64
- await this.cactus.init(modelPath, this.contextSize);
65
- Telemetry.logInit(this.model, true);
66
- this.isInitialized = true;
67
- } catch (error) {
68
- Telemetry.logInit(this.model, false, getErrorMessage(error));
69
- throw error;
71
+ modelPath = await CactusFileSystem.getModelPath(this.getModelName());
70
72
  }
73
+ const cacheDir = await CactusFileSystem.getCactusDirectory();
74
+ await this.cactus.setTelemetryEnvironment(cacheDir);
75
+ await this.cactus.init(modelPath);
76
+ this.isInitialized = true;
71
77
  }
72
78
  async transcribe({
73
79
  audio,
@@ -87,16 +93,37 @@ export class CactusSTT {
87
93
  const responseBufferSize = 8 * (options.maxTokens ?? CactusSTT.defaultTranscribeOptions.maxTokens) + 256;
88
94
  this.isGenerating = true;
89
95
  try {
90
- const result = await this.cactus.transcribe(audio, prompt, responseBufferSize, options, onToken);
91
- Telemetry.logTranscribe(this.model, result.success, result.success ? undefined : result.response, result);
92
- return result;
93
- } catch (error) {
94
- Telemetry.logTranscribe(this.model, false, getErrorMessage(error));
95
- throw error;
96
+ return await this.cactus.transcribe(audio, prompt, responseBufferSize, options, onToken);
96
97
  } finally {
97
98
  this.isGenerating = false;
98
99
  }
99
100
  }
101
+ async streamTranscribeStart(options) {
102
+ if (this.isStreamTranscribing) {
103
+ return;
104
+ }
105
+ await this.init();
106
+ await this.cactus.streamTranscribeStart(options);
107
+ this.isStreamTranscribing = true;
108
+ }
109
+ async streamTranscribeProcess({
110
+ audio
111
+ }) {
112
+ if (!this.isStreamTranscribing) {
113
+ throw new Error('CactusSTT stream transcribe is not started');
114
+ }
115
+ return this.cactus.streamTranscribeProcess(audio);
116
+ }
117
+ async streamTranscribeStop() {
118
+ if (!this.isStreamTranscribing) {
119
+ throw new Error('CactusSTT stream transcribe is not started');
120
+ }
121
+ try {
122
+ return await this.cactus.streamTranscribeStop();
123
+ } finally {
124
+ this.isStreamTranscribing = false;
125
+ }
126
+ }
100
127
  async audioEmbed({
101
128
  audioPath
102
129
  }) {
@@ -107,13 +134,9 @@ export class CactusSTT {
107
134
  this.isGenerating = true;
108
135
  try {
109
136
  const embedding = await this.cactus.audioEmbed(audioPath, CactusSTT.defaultEmbedBufferSize);
110
- Telemetry.logAudioEmbedding(this.model, true);
111
137
  return {
112
138
  embedding
113
139
  };
114
- } catch (error) {
115
- Telemetry.logAudioEmbedding(this.model, false, getErrorMessage(error));
116
- throw error;
117
140
  } finally {
118
141
  this.isGenerating = false;
119
142
  }
@@ -130,18 +153,21 @@ export class CactusSTT {
130
153
  return;
131
154
  }
132
155
  await this.stop();
156
+ if (this.isStreamTranscribing) {
157
+ await this.cactus.streamTranscribeStop().catch(() => {});
158
+ this.isStreamTranscribing = false;
159
+ }
133
160
  await this.cactus.destroy();
134
161
  this.isInitialized = false;
135
162
  }
136
163
  async getModels() {
137
- const models = await Database.getSTTModels();
138
- for (const model of models) {
139
- model.isDownloaded = await CactusFileSystem.modelExists(model.slug);
140
- }
141
- return models;
164
+ return Object.values(await getRegistry());
142
165
  }
143
166
  isModelPath(model) {
144
167
  return model.startsWith('file://') || model.startsWith('/');
145
168
  }
169
+ getModelName() {
170
+ return `${this.model}-${this.options.quantization}${this.options.pro ? '-pro' : ''}`;
171
+ }
146
172
  }
147
173
  //# sourceMappingURL=CactusSTT.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["Cactus","CactusFileSystem","Telemetry","CactusConfig","Database","getErrorMessage","CactusSTT","cactus","isDownloading","isInitialized","isGenerating","defaultModel","defaultContextSize","defaultPrompt","defaultTranscribeOptions","maxTokens","defaultEmbedBufferSize","constructor","model","contextSize","init","telemetryToken","download","onProgress","isModelPath","Error","modelExists","getSTTModel","downloadModel","downloadUrl","modelPath","replace","getModelPath","logInit","error","transcribe","audio","prompt","options","onToken","responseBufferSize","result","logTranscribe","success","undefined","response","audioEmbed","audioPath","embedding","logAudioEmbedding","stop","reset","destroy","getModels","models","getSTTModels","isDownloaded","slug","startsWith"],"sourceRoot":"../../../src","sources":["classes/CactusSTT.ts"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["Cactus","CactusFileSystem","getRegistry","CactusSTT","cactus","isDownloading","isInitialized","isGenerating","isStreamTranscribing","defaultModel","defaultOptions","quantization","pro","defaultPrompt","defaultTranscribeOptions","maxTokens","defaultEmbedBufferSize","constructor","model","options","download","onProgress","isModelPath","Error","modelExists","getModelName","console","log","registry","modelConfig","url","apple","downloadModel","init","modelPath","replace","JSON","stringify","getModelPath","cacheDir","getCactusDirectory","setTelemetryEnvironment","transcribe","audio","prompt","onToken","responseBufferSize","streamTranscribeStart","streamTranscribeProcess","streamTranscribeStop","audioEmbed","audioPath","embedding","stop","reset","destroy","catch","getModels","Object","values","startsWith"],"sourceRoot":"../../../src","sources":["classes/CactusSTT.ts"],"mappings":";;AAAA,SAASA,MAAM,EAAEC,gBAAgB,QAAQ,oBAAW;AAapD,SAASC,WAAW,QAAQ,qBAAkB;AAG9C,OAAO,MAAMC,SAAS,CAAC;EACJC,MAAM,GAAG,IAAIJ,MAAM,CAAC,CAAC;EAQ9BK,aAAa,GAAG,KAAK;EACrBC,aAAa,GAAG,KAAK;EACrBC,YAAY,GAAG,KAAK;EACpBC,oBAAoB,GAAG,KAAK;EAEpC,OAAwBC,YAAY,GAAG,eAAe;EACtD,OAAwBC,cAAc,GAAG;IACvCC,YAAY,EAAE,MAAe;IAC7BC,GAAG,EAAE;EACP,CAAC;EACD,OAAwBC,aAAa,GACnC,2DAA2D;EAC7D,OAAwBC,wBAAwB,GAAG;IACjDC,SAAS,EAAE;EACb,CAAC;EACD,OAAwBC,sBAAsB,GAAG,IAAI;EAErDC,WAAWA,CAAC;IAAEC,KAAK;IAAEC;EAAyB,CAAC,GAAG,CAAC,CAAC,EAAE;IACpD,IAAI,CAACD,KAAK,GAAGA,KAAK,IAAIf,SAAS,CAACM,YAAY;IAC5C,IAAI,CAACU,OAAO,GAAG;MACbR,YAAY,EACVQ,OAAO,EAAER,YAAY,IAAIR,SAAS,CAACO,cAAc,CAACC,YAAY;MAChEC,GAAG,EAAEO,OAAO,EAAEP,GAAG,IAAIT,SAAS,CAACO,cAAc,CAACE;IAChD,CAAC;EACH;EAEA,MAAaQ,QAAQA,CAAC;IACpBC;EACuB,CAAC,GAAG,CAAC,CAAC,EAAiB;IAC9C,IAAI,IAAI,CAACC,WAAW,CAAC,IAAI,CAACJ,KAAK,CAAC,EAAE;MAChCG,UAAU,GAAG,GAAG,CAAC;MACjB;IACF;IAEA,IAAI,IAAI,CAAChB,aAAa,EAAE;MACtB,MAAM,IAAIkB,KAAK,CAAC,kCAAkC,CAAC;IACrD;IAEA,IAAI,MAAMtB,gBAAgB,CAACuB,WAAW,CAAC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,EAAE;MAC3DC,OAAO,CAACC,GAAG,CAAC,sBAAsB,EAAE,IAAI,CAACF,YAAY,CAAC,CAAC,CAAC;MACxDJ,UAAU,GAAG,GAAG,CAAC;MACjB;IACF;IAEA,IAAI,CAAChB,aAAa,GAAG,IAAI;IACzB,IAAI;MACF,MAAMuB,QAAQ,GAAG,MAAM1B,WAAW,CAAC,CAAC;MACpC,MAAM2B,WAAW,GACfD,QAAQ,CAAC,IAAI,CAACV,KAAK,CAAC,EAAEP,YAAY,CAAC,IAAI,CAACQ,OAAO,CAACR,YAAY,CAAC;MAC/D,MAAMmB,GAAG,GAAG,IAAI,CAACX,OAAO,CAACP,GAAG,GAAGiB,WAAW,EAAEjB,GAAG,EAAEmB,KAAK,GAAGF,WAAW,EAAEC,GAAG;MAEzE,IAAI,CAACA,GAAG,EAAE;QACR,MAAM,IAAIP,KAAK,CAAC,SAAS,IAAI,CAACL,KAAK,mCAAmC,CAAC;MACzE;MAEA,MAAMjB,gBAAgB,CAAC+B,aAAa,CAClC,IAAI,CAACP,YAAY,CAAC,CAAC,EACnBK,GAAG,EACHT,UACF,CAAC;IACH,CAAC,SAAS;MACR,IAAI,CAAChB,aAAa,GAAG,KAAK;IAC5B;EACF;EAEA,MAAa4B,IAAIA,CAAA,EAAkB;IACjC,IAAI,IAAI,CAAC3B,aAAa,EAAE;MACtB;IACF;IAEA,IAAI4B,SAAiB;IACrB,IAAI,IAAI,CAACZ,WAAW,CAAC,IAAI,CAACJ,KAAK,CAAC,EAAE;MAChCgB,SAAS,GAAG,IAAI,CAAChB,KAAK,CAACiB,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC;IAC/C,CAAC,MAAM;MACL,IAAI,EAAE,MAAMlC,gBAAgB,CAACuB,WAAW,CAAC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE;QAC9DC,OAAO,CAACC,GAAG,CAAC,sBAAsB,EAAE,IAAI,CAACF,YAAY,CAAC,CAAC,CAAC;QACxD,MAAM,IAAIF,KAAK,CACb,UAAU,IAAI,CAACL,KAAK,kBAAkBkB,IAAI,CAACC,SAAS,CAAC,IAAI,CAAClB,OAAO,CAAC,oBACpE,CAAC;MACH;MACAe,SAAS,GAAG,MAAMjC,gBAAgB,CAACqC,YAAY,CAAC,IAAI,CAACb,YAAY,CAAC,CAAC,CAAC;IACtE;IAEA,MAAMc,QAAQ,GAAG,MAAMtC,gBAAgB,CAACuC,kBAAkB,CAAC,CAAC;IAC5D,MAAM,IAAI,CAACpC,MAAM,CAACqC,uBAAuB,CAACF,QAAQ,CAAC;IACnD,MAAM,IAAI,CAACnC,MAAM,CAAC6B,IAAI,CAACC,SAAS,CAAC;IACjC,IAAI,CAAC5B,aAAa,GAAG,IAAI;EAC3B;EAEA,MAAaoC,UAAUA,CAAC;IACtBC,KAAK;IACLC,MAAM;IACNzB,OAAO;IACP0B;EACyB,CAAC,EAAsC;IAChE,IAAI,IAAI,CAACtC,YAAY,EAAE;MACrB,MAAM,IAAIgB,KAAK,CAAC,iCAAiC,CAAC;IACpD;IAEA,MAAM,IAAI,CAACU,IAAI,CAAC,CAAC;IAEjBW,MAAM,GAAGA,MAAM,IAAIzC,SAAS,CAACU,aAAa;IAC1CM,OAAO,GAAG;MAAE,GAAGhB,SAAS,CAACW,wBAAwB;MAAE,GAAGK;IAAQ,CAAC;IAE/D,MAAM2B,kBAAkB,GACtB,CAAC,IAAI3B,OAAO,CAACJ,SAAS,IAAIZ,SAAS,CAACW,wBAAwB,CAACC,SAAS,CAAC,GACvE,GAAG;IAEL,IAAI,CAACR,YAAY,GAAG,IAAI;IACxB,IAAI;MACF,OAAO,MAAM,IAAI,CAACH,MAAM,CAACsC,UAAU,CACjCC,KAAK,EACLC,MAAM,EACNE,kBAAkB,EAClB3B,OAAO,EACP0B,OACF,CAAC;IACH,CAAC,SAAS;MACR,IAAI,CAACtC,YAAY,GAAG,KAAK;IAC3B;EACF;EAEA,MAAawC,qBAAqBA,CAChC5B,OAA+C,EAChC;IACf,IAAI,IAAI,CAACX,oBAAoB,EAAE;MAC7B;IACF;IAEA,MAAM,IAAI,CAACyB,IAAI,CAAC,CAAC;IACjB,MAAM,IAAI,CAAC7B,MAAM,CAAC2C,qBAAqB,CAAC5B,OAAO,CAAC;IAChD,IAAI,CAACX,oBAAoB,GAAG,IAAI;EAClC;EAEA,MAAawC,uBAAuBA,CAAC;IACnCL;EACsC,CAAC,EAAmD;IAC1F,IAAI,CAAC,IAAI,CAACnC,oBAAoB,EAAE;MAC9B,MAAM,IAAIe,KAAK,CAAC,4CAA4C,CAAC;IAC/D;IAEA,OAAO,IAAI,CAACnB,MAAM,CAAC4C,uBAAuB,CAACL,KAAK,CAAC;EACnD;EAEA,MAAaM,oBAAoBA,CAAA,EAAiD;IAChF,IAAI,CAAC,IAAI,CAACzC,oBAAoB,EAAE;MAC9B,MAAM,IAAIe,KAAK,CAAC,4CAA4C,CAAC;IAC/D;IAEA,IAAI;MACF,OAAO,MAAM,IAAI,CAACnB,MAAM,CAAC6C,oBAAoB,CAAC,CAAC;IACjD,CAAC,SAAS;MACR,IAAI,CAACzC,oBAAoB,GAAG,KAAK;IACnC;EACF;EAEA,MAAa0C,UAAUA,CAAC;IACtBC;EACyB,CAAC,EAAsC;IAChE,IAAI,IAAI,CAAC5C,YAAY,EAAE;MACrB,MAAM,IAAIgB,KAAK,CAAC,iCAAiC,CAAC;IACpD;IAEA,MAAM,IAAI,CAACU,IAAI,CAAC,CAAC;IAEjB,IAAI,CAAC1B,YAAY,GAAG,IAAI;IACxB,IAAI;MACF,MAAM6C,SAAS,GAAG,MAAM,IAAI,CAAChD,MAAM,CAAC8C,UAAU,CAC5CC,SAAS,EACThD,SAAS,CAACa,sBACZ,CAAC;MACD,OAAO;QAAEoC;MAAU,CAAC;IACtB,CAAC,SAAS;MACR,IAAI,CAAC7C,YAAY,GAAG,KAAK;IAC3B;EACF;EAEO8C,IAAIA,CAAA,EAAkB;IAC3B,OAAO,IAAI,CAACjD,MAAM,CAACiD,IAAI,CAAC,CAAC;EAC3B;EAEA,MAAaC,KAAKA,CAAA,EAAkB;IAClC,MAAM,IAAI,CAACD,IAAI,CAAC,CAAC;IACjB,OAAO,IAAI,CAACjD,MAAM,CAACkD,KAAK,CAAC,CAAC;EAC5B;EAEA,MAAaC,OAAOA,CAAA,EAAkB;IACpC,IAAI,CAAC,IAAI,CAACjD,aAAa,EAAE;MACvB;IACF;IAEA,MAAM,IAAI,CAAC+C,IAAI,CAAC,CAAC;IAEjB,IAAI,IAAI,CAAC7C,oBAAoB,EAAE;MAC7B,MAAM,IAAI,CAACJ,MAAM,CAAC6C,oBAAoB,CAAC,CAAC,CAACO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;MACxD,IAAI,CAAChD,oBAAoB,GAAG,KAAK;IACnC;IAEA,MAAM,IAAI,CAACJ,MAAM,CAACmD,OAAO,CAAC,CAAC;IAC3B,IAAI,CAACjD,aAAa,GAAG,KAAK;EAC5B;EAEA,MAAamD,SAASA,CAAA,EAA2B;IAC/C,OAAOC,MAAM,CAACC,MAAM,CAAC,MAAMzD,WAAW,CAAC,CAAC,CAAC;EAC3C;EAEQoB,WAAWA,CAACJ,KAAa,EAAW;IAC1C,OAAOA,KAAK,CAAC0C,UAAU,CAAC,SAAS,CAAC,IAAI1C,KAAK,CAAC0C,UAAU,CAAC,GAAG,CAAC;EAC7D;EAEOnC,YAAYA,CAAA,EAAW;IAC5B,OAAO,GAAG,IAAI,CAACP,KAAK,IAAI,IAAI,CAACC,OAAO,CAACR,YAAY,GAAG,IAAI,CAACQ,OAAO,CAACP,GAAG,GAAG,MAAM,GAAG,EAAE,EAAE;EACtF;AACF","ignoreList":[]}
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+
3
+ import { Cactus, CactusFileSystem } from "../native/index.js";
4
+ import { getRegistry } from "../modelRegistry.js";
5
+ export class CactusVAD {
6
+ cactus = new Cactus();
7
+ isDownloading = false;
8
+ isInitialized = false;
9
+ static defaultModel = 'silero-vad';
10
+ static defaultOptions = {
11
+ quantization: 'int8',
12
+ pro: false
13
+ };
14
+ constructor({
15
+ model,
16
+ options
17
+ } = {}) {
18
+ this.model = model ?? CactusVAD.defaultModel;
19
+ this.options = {
20
+ quantization: options?.quantization ?? CactusVAD.defaultOptions.quantization,
21
+ pro: options?.pro ?? CactusVAD.defaultOptions.pro
22
+ };
23
+ }
24
+ async download({
25
+ onProgress
26
+ } = {}) {
27
+ if (this.isModelPath(this.model)) {
28
+ onProgress?.(1.0);
29
+ return;
30
+ }
31
+ if (this.isDownloading) {
32
+ throw new Error('CactusVAD is already downloading');
33
+ }
34
+ if (await CactusFileSystem.modelExists(this.getModelName())) {
35
+ console.log('Model already exists', this.getModelName());
36
+ onProgress?.(1.0);
37
+ return;
38
+ }
39
+ this.isDownloading = true;
40
+ try {
41
+ const registry = await getRegistry();
42
+ const modelConfig = registry[this.model]?.quantization[this.options.quantization];
43
+ const url = this.options.pro ? modelConfig?.pro?.apple : modelConfig?.url;
44
+ if (!url) {
45
+ throw new Error(`Model ${this.model} with specified options not found`);
46
+ }
47
+ await CactusFileSystem.downloadModel(this.getModelName(), url, onProgress);
48
+ } finally {
49
+ this.isDownloading = false;
50
+ }
51
+ }
52
+ async init() {
53
+ if (this.isInitialized) {
54
+ return;
55
+ }
56
+ let modelPath;
57
+ if (this.isModelPath(this.model)) {
58
+ modelPath = this.model.replace('file://', '');
59
+ } else {
60
+ if (!(await CactusFileSystem.modelExists(this.getModelName()))) {
61
+ console.log('Model does not exist', this.getModelName());
62
+ throw new Error(`Model "${this.model}" with options ${JSON.stringify(this.options)} is not downloaded`);
63
+ }
64
+ modelPath = await CactusFileSystem.getModelPath(this.getModelName());
65
+ }
66
+ const cacheDir = await CactusFileSystem.getCactusDirectory();
67
+ await this.cactus.setTelemetryEnvironment(cacheDir);
68
+ await this.cactus.init(modelPath);
69
+ this.isInitialized = true;
70
+ }
71
+ async vad({
72
+ audio,
73
+ options
74
+ }) {
75
+ await this.init();
76
+ return this.cactus.vad(audio, options);
77
+ }
78
+ async destroy() {
79
+ if (!this.isInitialized) {
80
+ return;
81
+ }
82
+ await this.cactus.destroy();
83
+ this.isInitialized = false;
84
+ }
85
+ async getModels() {
86
+ return Object.values(await getRegistry());
87
+ }
88
+ isModelPath(model) {
89
+ return model.startsWith('file://') || model.startsWith('/');
90
+ }
91
+ getModelName() {
92
+ return `${this.model}-${this.options.quantization}${this.options.pro ? '-pro' : ''}`;
93
+ }
94
+ }
95
+ //# sourceMappingURL=CactusVAD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Cactus","CactusFileSystem","getRegistry","CactusVAD","cactus","isDownloading","isInitialized","defaultModel","defaultOptions","quantization","pro","constructor","model","options","download","onProgress","isModelPath","Error","modelExists","getModelName","console","log","registry","modelConfig","url","apple","downloadModel","init","modelPath","replace","JSON","stringify","getModelPath","cacheDir","getCactusDirectory","setTelemetryEnvironment","vad","audio","destroy","getModels","Object","values","startsWith"],"sourceRoot":"../../../src","sources":["classes/CactusVAD.ts"],"mappings":";;AAAA,SAASA,MAAM,EAAEC,gBAAgB,QAAQ,oBAAW;AAOpD,SAASC,WAAW,QAAQ,qBAAkB;AAG9C,OAAO,MAAMC,SAAS,CAAC;EACJC,MAAM,GAAG,IAAIJ,MAAM,CAAC,CAAC;EAQ9BK,aAAa,GAAG,KAAK;EACrBC,aAAa,GAAG,KAAK;EAE7B,OAAwBC,YAAY,GAAG,YAAY;EACnD,OAAwBC,cAAc,GAAG;IACvCC,YAAY,EAAE,MAAe;IAC7BC,GAAG,EAAE;EACP,CAAC;EAEDC,WAAWA,CAAC;IAAEC,KAAK;IAAEC;EAAyB,CAAC,GAAG,CAAC,CAAC,EAAE;IACpD,IAAI,CAACD,KAAK,GAAGA,KAAK,IAAIT,SAAS,CAACI,YAAY;IAC5C,IAAI,CAACM,OAAO,GAAG;MACbJ,YAAY,EACVI,OAAO,EAAEJ,YAAY,IAAIN,SAAS,CAACK,cAAc,CAACC,YAAY;MAChEC,GAAG,EAAEG,OAAO,EAAEH,GAAG,IAAIP,SAAS,CAACK,cAAc,CAACE;IAChD,CAAC;EACH;EAEA,MAAaI,QAAQA,CAAC;IACpBC;EACuB,CAAC,GAAG,CAAC,CAAC,EAAiB;IAC9C,IAAI,IAAI,CAACC,WAAW,CAAC,IAAI,CAACJ,KAAK,CAAC,EAAE;MAChCG,UAAU,GAAG,GAAG,CAAC;MACjB;IACF;IAEA,IAAI,IAAI,CAACV,aAAa,EAAE;MACtB,MAAM,IAAIY,KAAK,CAAC,kCAAkC,CAAC;IACrD;IAEA,IAAI,MAAMhB,gBAAgB,CAACiB,WAAW,CAAC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,EAAE;MAC3DC,OAAO,CAACC,GAAG,CAAC,sBAAsB,EAAE,IAAI,CAACF,YAAY,CAAC,CAAC,CAAC;MACxDJ,UAAU,GAAG,GAAG,CAAC;MACjB;IACF;IAEA,IAAI,CAACV,aAAa,GAAG,IAAI;IACzB,IAAI;MACF,MAAMiB,QAAQ,GAAG,MAAMpB,WAAW,CAAC,CAAC;MACpC,MAAMqB,WAAW,GACfD,QAAQ,CAAC,IAAI,CAACV,KAAK,CAAC,EAAEH,YAAY,CAAC,IAAI,CAACI,OAAO,CAACJ,YAAY,CAAC;MAC/D,MAAMe,GAAG,GAAG,IAAI,CAACX,OAAO,CAACH,GAAG,GAAGa,WAAW,EAAEb,GAAG,EAAEe,KAAK,GAAGF,WAAW,EAAEC,GAAG;MAEzE,IAAI,CAACA,GAAG,EAAE;QACR,MAAM,IAAIP,KAAK,CAAC,SAAS,IAAI,CAACL,KAAK,mCAAmC,CAAC;MACzE;MAEA,MAAMX,gBAAgB,CAACyB,aAAa,CAClC,IAAI,CAACP,YAAY,CAAC,CAAC,EACnBK,GAAG,EACHT,UACF,CAAC;IACH,CAAC,SAAS;MACR,IAAI,CAACV,aAAa,GAAG,KAAK;IAC5B;EACF;EAEA,MAAasB,IAAIA,CAAA,EAAkB;IACjC,IAAI,IAAI,CAACrB,aAAa,EAAE;MACtB;IACF;IAEA,IAAIsB,SAAiB;IACrB,IAAI,IAAI,CAACZ,WAAW,CAAC,IAAI,CAACJ,KAAK,CAAC,EAAE;MAChCgB,SAAS,GAAG,IAAI,CAAChB,KAAK,CAACiB,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC;IAC/C,CAAC,MAAM;MACL,IAAI,EAAE,MAAM5B,gBAAgB,CAACiB,WAAW,CAAC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE;QAC9DC,OAAO,CAACC,GAAG,CAAC,sBAAsB,EAAE,IAAI,CAACF,YAAY,CAAC,CAAC,CAAC;QACxD,MAAM,IAAIF,KAAK,CACb,UAAU,IAAI,CAACL,KAAK,kBAAkBkB,IAAI,CAACC,SAAS,CAAC,IAAI,CAAClB,OAAO,CAAC,oBACpE,CAAC;MACH;MACAe,SAAS,GAAG,MAAM3B,gBAAgB,CAAC+B,YAAY,CAAC,IAAI,CAACb,YAAY,CAAC,CAAC,CAAC;IACtE;IAEA,MAAMc,QAAQ,GAAG,MAAMhC,gBAAgB,CAACiC,kBAAkB,CAAC,CAAC;IAC5D,MAAM,IAAI,CAAC9B,MAAM,CAAC+B,uBAAuB,CAACF,QAAQ,CAAC;IACnD,MAAM,IAAI,CAAC7B,MAAM,CAACuB,IAAI,CAACC,SAAS,CAAC;IACjC,IAAI,CAACtB,aAAa,GAAG,IAAI;EAC3B;EAEA,MAAa8B,GAAGA,CAAC;IACfC,KAAK;IACLxB;EACkB,CAAC,EAA4B;IAC/C,MAAM,IAAI,CAACc,IAAI,CAAC,CAAC;IACjB,OAAO,IAAI,CAACvB,MAAM,CAACgC,GAAG,CAACC,KAAK,EAAExB,OAAO,CAAC;EACxC;EAEA,MAAayB,OAAOA,CAAA,EAAkB;IACpC,IAAI,CAAC,IAAI,CAAChC,aAAa,EAAE;MACvB;IACF;IAEA,MAAM,IAAI,CAACF,MAAM,CAACkC,OAAO,CAAC,CAAC;IAC3B,IAAI,CAAChC,aAAa,GAAG,KAAK;EAC5B;EAEA,MAAaiC,SAASA,CAAA,EAA2B;IAC/C,OAAOC,MAAM,CAACC,MAAM,CAAC,MAAMvC,WAAW,CAAC,CAAC,CAAC;EAC3C;EAEQc,WAAWA,CAACJ,KAAa,EAAW;IAC1C,OAAOA,KAAK,CAAC8B,UAAU,CAAC,SAAS,CAAC,IAAI9B,KAAK,CAAC8B,UAAU,CAAC,GAAG,CAAC;EAC7D;EAEOvB,YAAYA,CAAA,EAAW;IAC5B,OAAO,GAAG,IAAI,CAACP,KAAK,IAAI,IAAI,CAACC,OAAO,CAACJ,YAAY,GAAG,IAAI,CAACI,OAAO,CAACH,GAAG,GAAG,MAAM,GAAG,EAAE,EAAE;EACtF;AACF","ignoreList":[]}
@@ -5,14 +5,19 @@ import { CactusLM } from "../classes/CactusLM.js";
5
5
  import { CactusFileSystem } from "../native/index.js";
6
6
  import { getErrorMessage } from "../utils/error.js";
7
7
  export const useCactusLM = ({
8
- model = 'qwen3-0.6',
9
- contextSize = 2048,
10
- corpusDir = undefined
8
+ model = 'qwen3-0.6b',
9
+ corpusDir = undefined,
10
+ cacheIndex = false,
11
+ options: modelOptions = {
12
+ quantization: undefined,
13
+ pro: false
14
+ }
11
15
  } = {}) => {
12
16
  const [cactusLM, setCactusLM] = useState(() => new CactusLM({
13
17
  model,
14
- contextSize,
15
- corpusDir
18
+ corpusDir,
19
+ cacheIndex,
20
+ options: modelOptions
16
21
  }));
17
22
 
18
23
  // State
@@ -29,11 +34,16 @@ export const useCactusLM = ({
29
34
  currentModelRef.current = model;
30
35
  }, [model]);
31
36
  useEffect(() => {
32
- setCactusLM(new CactusLM({
37
+ const newInstance = new CactusLM({
33
38
  model,
34
- contextSize,
35
- corpusDir
36
- }));
39
+ corpusDir,
40
+ cacheIndex,
41
+ options: {
42
+ quantization: modelOptions.quantization,
43
+ pro: modelOptions.pro
44
+ }
45
+ });
46
+ setCactusLM(newInstance);
37
47
  setCompletion('');
38
48
  setIsGenerating(false);
39
49
  setIsInitializing(false);
@@ -42,7 +52,7 @@ export const useCactusLM = ({
42
52
  setDownloadProgress(0);
43
53
  setError(null);
44
54
  let mounted = true;
45
- CactusFileSystem.modelExists(model).then(exists => {
55
+ CactusFileSystem.modelExists(newInstance.getModelName()).then(exists => {
46
56
  if (!mounted) {
47
57
  return;
48
58
  }
@@ -57,7 +67,7 @@ export const useCactusLM = ({
57
67
  return () => {
58
68
  mounted = false;
59
69
  };
60
- }, [model, contextSize, corpusDir]);
70
+ }, [model, corpusDir, cacheIndex, modelOptions.quantization, modelOptions.pro]);
61
71
  useEffect(() => {
62
72
  return () => {
63
73
  cactusLM.destroy().catch(() => {});
@@ -128,8 +138,7 @@ export const useCactusLM = ({
128
138
  messages,
129
139
  options,
130
140
  tools,
131
- onToken,
132
- mode
141
+ onToken
133
142
  }) => {
134
143
  if (isGenerating) {
135
144
  const message = 'CactusLM is already generating';
@@ -147,8 +156,7 @@ export const useCactusLM = ({
147
156
  onToken: token => {
148
157
  setCompletion(prev => prev + token);
149
158
  onToken?.(token);
150
- },
151
- mode
159
+ }
152
160
  });
153
161
  } catch (e) {
154
162
  setError(getErrorMessage(e));