cactus-react-native 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/README.md +230 -0
  2. package/android/build.gradle +104 -0
  3. package/android/gradle.properties +5 -0
  4. package/android/src/main/AndroidManifest.xml +4 -0
  5. package/android/src/main/CMakeLists.txt +104 -0
  6. package/android/src/main/java/com/cactus/Cactus.java +646 -0
  7. package/android/src/main/java/com/cactus/CactusPackage.java +48 -0
  8. package/android/src/main/java/com/cactus/LlamaContext.java +579 -0
  9. package/android/src/main/jni-utils.h +100 -0
  10. package/android/src/main/jni.cpp +1254 -0
  11. package/android/src/main/jniLibs/arm64-v8a/libcactus.so +0 -0
  12. package/android/src/main/jniLibs/arm64-v8a/libcactus_v8.so +0 -0
  13. package/android/src/main/jniLibs/arm64-v8a/libcactus_v8_2.so +0 -0
  14. package/android/src/main/jniLibs/arm64-v8a/libcactus_v8_2_dotprod.so +0 -0
  15. package/android/src/main/jniLibs/arm64-v8a/libcactus_v8_2_dotprod_i8mm.so +0 -0
  16. package/android/src/main/jniLibs/arm64-v8a/libcactus_v8_2_i8mm.so +0 -0
  17. package/android/src/main/jniLibs/x86_64/libcactus.so +0 -0
  18. package/android/src/main/jniLibs/x86_64/libcactus_x86_64.so +0 -0
  19. package/android/src/newarch/java/com/cactus/CactusModule.java +124 -0
  20. package/android/src/oldarch/java/com/cactus/CactusModule.java +125 -0
  21. package/cactus-react-native.podspec +45 -0
  22. package/ios/CMakeLists.txt +109 -0
  23. package/ios/Cactus.h +6 -0
  24. package/ios/Cactus.mm +405 -0
  25. package/ios/CactusContext.h +57 -0
  26. package/ios/CactusContext.mm +835 -0
  27. package/ios/cactus.xcframework/info.plist +74 -0
  28. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/cactus.h +133 -0
  29. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/chat.h +143 -0
  30. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/common.h +683 -0
  31. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-alloc.h +76 -0
  32. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-backend-impl.h +255 -0
  33. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-backend.h +354 -0
  34. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-common.h +1851 -0
  35. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpp.h +39 -0
  36. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpu-aarch64.h +8 -0
  37. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpu-impl.h +531 -0
  38. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpu-quants.h +63 -0
  39. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpu-traits.h +38 -0
  40. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-cpu.h +138 -0
  41. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-impl.h +567 -0
  42. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-metal-impl.h +530 -0
  43. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-metal.h +66 -0
  44. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-opt.h +216 -0
  45. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-quants.h +100 -0
  46. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml-threading.h +14 -0
  47. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/ggml.h +2221 -0
  48. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/gguf.h +202 -0
  49. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/json-schema-to-grammar.h +21 -0
  50. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/json.hpp +24766 -0
  51. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-adapter.h +76 -0
  52. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-arch.h +421 -0
  53. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-batch.h +88 -0
  54. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-chat.h +53 -0
  55. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-context.h +265 -0
  56. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-cparams.h +38 -0
  57. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-cpp.h +30 -0
  58. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-grammar.h +173 -0
  59. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-graph.h +574 -0
  60. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-hparams.h +148 -0
  61. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-impl.h +61 -0
  62. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-io.h +35 -0
  63. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-kv-cache.h +287 -0
  64. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-memory.h +21 -0
  65. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-mmap.h +68 -0
  66. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-model-loader.h +167 -0
  67. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-model.h +403 -0
  68. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-sampling.h +32 -0
  69. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama-vocab.h +125 -0
  70. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/llama.h +1416 -0
  71. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/log.h +103 -0
  72. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/minja/chat-template.hpp +529 -0
  73. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/minja/minja.hpp +2915 -0
  74. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/sampling.h +107 -0
  75. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/sgemm.h +14 -0
  76. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/unicode-data.h +20 -0
  77. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Headers/unicode.h +66 -0
  78. package/ios/cactus.xcframework/ios-arm64/cactus.framework/Info.plist +0 -0
  79. package/ios/cactus.xcframework/ios-arm64/cactus.framework/cactus +0 -0
  80. package/ios/cactus.xcframework/ios-arm64/cactus.framework/ggml-llama.metallib +0 -0
  81. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/cactus.h +133 -0
  82. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/chat.h +143 -0
  83. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/common.h +683 -0
  84. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-alloc.h +76 -0
  85. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-backend-impl.h +255 -0
  86. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-backend.h +354 -0
  87. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-common.h +1851 -0
  88. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpp.h +39 -0
  89. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-aarch64.h +8 -0
  90. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-impl.h +531 -0
  91. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-quants.h +63 -0
  92. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-traits.h +38 -0
  93. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu.h +138 -0
  94. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-impl.h +567 -0
  95. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-metal-impl.h +530 -0
  96. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-metal.h +66 -0
  97. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-opt.h +216 -0
  98. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-quants.h +100 -0
  99. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml-threading.h +14 -0
  100. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/ggml.h +2221 -0
  101. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/gguf.h +202 -0
  102. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/json-schema-to-grammar.h +21 -0
  103. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/json.hpp +24766 -0
  104. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-adapter.h +76 -0
  105. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-arch.h +421 -0
  106. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-batch.h +88 -0
  107. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-chat.h +53 -0
  108. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-context.h +265 -0
  109. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-cparams.h +38 -0
  110. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-cpp.h +30 -0
  111. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-grammar.h +173 -0
  112. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-graph.h +574 -0
  113. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-hparams.h +148 -0
  114. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-impl.h +61 -0
  115. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-io.h +35 -0
  116. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-kv-cache.h +287 -0
  117. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-memory.h +21 -0
  118. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-mmap.h +68 -0
  119. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-model-loader.h +167 -0
  120. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-model.h +403 -0
  121. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-sampling.h +32 -0
  122. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama-vocab.h +125 -0
  123. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/llama.h +1416 -0
  124. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/log.h +103 -0
  125. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/minja/chat-template.hpp +529 -0
  126. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/minja/minja.hpp +2915 -0
  127. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/sampling.h +107 -0
  128. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/sgemm.h +14 -0
  129. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/unicode-data.h +20 -0
  130. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Headers/unicode.h +66 -0
  131. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/Info.plist +0 -0
  132. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/_CodeSignature/CodeResources +101 -0
  133. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/cactus +0 -0
  134. package/ios/cactus.xcframework/ios-arm64_x86_64-simulator/cactus.framework/ggml-llama-sim.metallib +0 -0
  135. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/cactus.h +133 -0
  136. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/chat.h +143 -0
  137. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/common.h +683 -0
  138. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-alloc.h +76 -0
  139. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-backend-impl.h +255 -0
  140. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-backend.h +354 -0
  141. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-common.h +1851 -0
  142. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpp.h +39 -0
  143. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpu-aarch64.h +8 -0
  144. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpu-impl.h +531 -0
  145. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpu-quants.h +63 -0
  146. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpu-traits.h +38 -0
  147. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-cpu.h +138 -0
  148. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-impl.h +567 -0
  149. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-metal-impl.h +530 -0
  150. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-metal.h +66 -0
  151. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-opt.h +216 -0
  152. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-quants.h +100 -0
  153. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml-threading.h +14 -0
  154. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/ggml.h +2221 -0
  155. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/gguf.h +202 -0
  156. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/json-schema-to-grammar.h +21 -0
  157. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/json.hpp +24766 -0
  158. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-adapter.h +76 -0
  159. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-arch.h +421 -0
  160. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-batch.h +88 -0
  161. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-chat.h +53 -0
  162. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-context.h +265 -0
  163. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-cparams.h +38 -0
  164. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-cpp.h +30 -0
  165. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-grammar.h +173 -0
  166. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-graph.h +574 -0
  167. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-hparams.h +148 -0
  168. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-impl.h +61 -0
  169. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-io.h +35 -0
  170. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-kv-cache.h +287 -0
  171. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-memory.h +21 -0
  172. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-mmap.h +68 -0
  173. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-model-loader.h +167 -0
  174. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-model.h +403 -0
  175. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-sampling.h +32 -0
  176. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama-vocab.h +125 -0
  177. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/llama.h +1416 -0
  178. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/log.h +103 -0
  179. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/minja/chat-template.hpp +529 -0
  180. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/minja/minja.hpp +2915 -0
  181. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/sampling.h +107 -0
  182. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/sgemm.h +14 -0
  183. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/unicode-data.h +20 -0
  184. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Headers/unicode.h +66 -0
  185. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/Info.plist +0 -0
  186. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/cactus +0 -0
  187. package/ios/cactus.xcframework/tvos-arm64/cactus.framework/ggml-llama.metallib +0 -0
  188. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/cactus.h +133 -0
  189. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/chat.h +143 -0
  190. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/common.h +683 -0
  191. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-alloc.h +76 -0
  192. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-backend-impl.h +255 -0
  193. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-backend.h +354 -0
  194. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-common.h +1851 -0
  195. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpp.h +39 -0
  196. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-aarch64.h +8 -0
  197. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-impl.h +531 -0
  198. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-quants.h +63 -0
  199. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu-traits.h +38 -0
  200. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-cpu.h +138 -0
  201. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-impl.h +567 -0
  202. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-metal-impl.h +530 -0
  203. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-metal.h +66 -0
  204. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-opt.h +216 -0
  205. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-quants.h +100 -0
  206. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml-threading.h +14 -0
  207. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/ggml.h +2221 -0
  208. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/gguf.h +202 -0
  209. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/json-schema-to-grammar.h +21 -0
  210. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/json.hpp +24766 -0
  211. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-adapter.h +76 -0
  212. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-arch.h +421 -0
  213. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-batch.h +88 -0
  214. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-chat.h +53 -0
  215. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-context.h +265 -0
  216. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-cparams.h +38 -0
  217. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-cpp.h +30 -0
  218. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-grammar.h +173 -0
  219. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-graph.h +574 -0
  220. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-hparams.h +148 -0
  221. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-impl.h +61 -0
  222. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-io.h +35 -0
  223. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-kv-cache.h +287 -0
  224. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-memory.h +21 -0
  225. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-mmap.h +68 -0
  226. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-model-loader.h +167 -0
  227. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-model.h +403 -0
  228. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-sampling.h +32 -0
  229. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama-vocab.h +125 -0
  230. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/llama.h +1416 -0
  231. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/log.h +103 -0
  232. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/minja/chat-template.hpp +529 -0
  233. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/minja/minja.hpp +2915 -0
  234. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/sampling.h +107 -0
  235. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/sgemm.h +14 -0
  236. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/unicode-data.h +20 -0
  237. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Headers/unicode.h +66 -0
  238. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/Info.plist +0 -0
  239. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/_CodeSignature/CodeResources +101 -0
  240. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/cactus +0 -0
  241. package/ios/cactus.xcframework/tvos-arm64_x86_64-simulator/cactus.framework/ggml-llama-sim.metallib +0 -0
  242. package/lib/commonjs/NativeCactus.js +9 -0
  243. package/lib/commonjs/NativeCactus.js.map +1 -0
  244. package/lib/commonjs/chat.js +37 -0
  245. package/lib/commonjs/chat.js.map +1 -0
  246. package/lib/commonjs/grammar.js +560 -0
  247. package/lib/commonjs/grammar.js.map +1 -0
  248. package/lib/commonjs/index.js +300 -0
  249. package/lib/commonjs/index.js.map +1 -0
  250. package/lib/commonjs/package.json +1 -0
  251. package/lib/module/NativeCactus.js +5 -0
  252. package/lib/module/NativeCactus.js.map +1 -0
  253. package/lib/module/chat.js +33 -0
  254. package/lib/module/chat.js.map +1 -0
  255. package/lib/module/grammar.js +553 -0
  256. package/lib/module/grammar.js.map +1 -0
  257. package/lib/module/index.js +277 -0
  258. package/lib/module/index.js.map +1 -0
  259. package/lib/module/package.json +1 -0
  260. package/lib/typescript/NativeCactus.d.ts +357 -0
  261. package/lib/typescript/NativeCactus.d.ts.map +1 -0
  262. package/lib/typescript/chat.d.ts +10 -0
  263. package/lib/typescript/chat.d.ts.map +1 -0
  264. package/lib/typescript/grammar.d.ts +37 -0
  265. package/lib/typescript/grammar.d.ts.map +1 -0
  266. package/lib/typescript/index.d.ts +96 -0
  267. package/lib/typescript/index.d.ts.map +1 -0
  268. package/package.json +223 -0
  269. package/src/NativeCactus.ts +418 -0
  270. package/src/chat.ts +44 -0
  271. package/src/grammar.ts +854 -0
  272. package/src/index.ts +482 -0
package/ios/Cactus.mm ADDED
@@ -0,0 +1,405 @@
1
+ #import "Cactus.h"
2
+ #import "CactusContext.h"
3
+
4
+ #ifdef RCT_NEW_ARCH_ENABLED
5
+ #import "CactusSpec.h"
6
+ #endif
7
+
8
+ @implementation Cactus
9
+
10
+ NSMutableDictionary *llamaContexts;
11
+ double llamaContextLimit = -1;
12
+ dispatch_queue_t llamaDQueue;
13
+
14
+ RCT_EXPORT_MODULE()
15
+
16
+ RCT_EXPORT_METHOD(toggleNativeLog:(BOOL)enabled) {
17
+ void (^onEmitLog)(NSString *level, NSString *text) = nil;
18
+ if (enabled) {
19
+ onEmitLog = ^(NSString *level, NSString *text) {
20
+ [self sendEventWithName:@"@Cactus_onNativeLog" body:@{ @"level": level, @"text": text }];
21
+ };
22
+ }
23
+ [CactusContext toggleNativeLog:enabled onEmitLog:onEmitLog];
24
+ }
25
+
26
+ RCT_EXPORT_METHOD(setContextLimit:(double)limit
27
+ withResolver:(RCTPromiseResolveBlock)resolve
28
+ withRejecter:(RCTPromiseRejectBlock)reject)
29
+ {
30
+ llamaContextLimit = limit;
31
+ resolve(nil);
32
+ }
33
+
34
+ RCT_EXPORT_METHOD(modelInfo:(NSString *)path
35
+ withSkip:(NSArray *)skip
36
+ withResolver:(RCTPromiseResolveBlock)resolve
37
+ withRejecter:(RCTPromiseRejectBlock)reject)
38
+ {
39
+ resolve([CactusContext modelInfo:path skip:skip]);
40
+ }
41
+
42
+ RCT_EXPORT_METHOD(initContext:(double)contextId
43
+ withContextParams:(NSDictionary *)contextParams
44
+ withResolver:(RCTPromiseResolveBlock)resolve
45
+ withRejecter:(RCTPromiseRejectBlock)reject)
46
+ {
47
+ NSNumber *contextIdNumber = [NSNumber numberWithDouble:contextId];
48
+ if (llamaContexts[contextIdNumber] != nil) {
49
+ reject(@"llama_error", @"Context already exists", nil);
50
+ return;
51
+ }
52
+
53
+ if (llamaDQueue == nil) {
54
+ llamaDQueue = dispatch_queue_create("com.cactus", DISPATCH_QUEUE_SERIAL);
55
+ }
56
+
57
+ if (llamaContexts == nil) {
58
+ llamaContexts = [[NSMutableDictionary alloc] init];
59
+ }
60
+
61
+ if (llamaContextLimit > -1 && [llamaContexts count] >= llamaContextLimit) {
62
+ reject(@"llama_error", @"Context limit reached", nil);
63
+ return;
64
+ }
65
+
66
+ @try {
67
+ CactusContext *context = [CactusContext initWithParams:contextParams onProgress:^(unsigned int progress) {
68
+ dispatch_async(dispatch_get_main_queue(), ^{
69
+ [self sendEventWithName:@"@Cactus_onInitContextProgress" body:@{ @"contextId": @(contextId), @"progress": @(progress) }];
70
+ });
71
+ }];
72
+ if (![context isModelLoaded]) {
73
+ reject(@"llama_cpp_error", @"Failed to load the model", nil);
74
+ return;
75
+ }
76
+
77
+ [llamaContexts setObject:context forKey:contextIdNumber];
78
+
79
+ resolve(@{
80
+ @"gpu": @([context isMetalEnabled]),
81
+ @"reasonNoGPU": [context reasonNoMetal],
82
+ @"model": [context modelInfo],
83
+ });
84
+ } @catch (NSException *exception) {
85
+ reject(@"llama_cpp_error", exception.reason, nil);
86
+ }
87
+ }
88
+
89
+ RCT_EXPORT_METHOD(getFormattedChat:(double)contextId
90
+ withMessages:(NSString *)messages
91
+ withTemplate:(NSString *)chatTemplate
92
+ withParams:(NSDictionary *)params
93
+ withResolver:(RCTPromiseResolveBlock)resolve
94
+ withRejecter:(RCTPromiseRejectBlock)reject)
95
+ {
96
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
97
+ if (context == nil) {
98
+ reject(@"llama_error", @"Context not found", nil);
99
+ return;
100
+ }
101
+ try {
102
+ if ([params[@"jinja"] boolValue]) {
103
+ NSString *jsonSchema = params[@"json_schema"];
104
+ NSString *tools = params[@"tools"];
105
+ bool parallelToolCalls = [params[@"parallel_tool_calls"] boolValue];
106
+ NSString *toolChoice = params[@"tool_choice"];
107
+ resolve([context getFormattedChatWithJinja:messages withChatTemplate:chatTemplate withJsonSchema:jsonSchema withTools:tools withParallelToolCalls:parallelToolCalls withToolChoice:toolChoice]);
108
+ } else {
109
+ resolve([context getFormattedChat:messages withChatTemplate:chatTemplate]);
110
+ }
111
+ } catch (const std::exception& e) { // catch cpp exceptions
112
+ reject(@"llama_error", [NSString stringWithUTF8String:e.what()], nil);
113
+ }
114
+ }
115
+
116
+ RCT_EXPORT_METHOD(loadSession:(double)contextId
117
+ withFilePath:(NSString *)filePath
118
+ withResolver:(RCTPromiseResolveBlock)resolve
119
+ withRejecter:(RCTPromiseRejectBlock)reject)
120
+ {
121
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
122
+ if (context == nil) {
123
+ reject(@"llama_error", @"Context not found", nil);
124
+ return;
125
+ }
126
+ if ([context isPredicting]) {
127
+ reject(@"llama_error", @"Context is busy", nil);
128
+ return;
129
+ }
130
+ dispatch_async(llamaDQueue, ^{
131
+ @try {
132
+ @autoreleasepool {
133
+ resolve([context loadSession:filePath]);
134
+ }
135
+ } @catch (NSException *exception) {
136
+ reject(@"llama_cpp_error", exception.reason, nil);
137
+ }
138
+ });
139
+ }
140
+
141
+ RCT_EXPORT_METHOD(saveSession:(double)contextId
142
+ withFilePath:(NSString *)filePath
143
+ withSize:(double)size
144
+ withResolver:(RCTPromiseResolveBlock)resolve
145
+ withRejecter:(RCTPromiseRejectBlock)reject)
146
+ {
147
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
148
+ if (context == nil) {
149
+ reject(@"llama_error", @"Context not found", nil);
150
+ return;
151
+ }
152
+ if ([context isPredicting]) {
153
+ reject(@"llama_error", @"Context is busy", nil);
154
+ return;
155
+ }
156
+ dispatch_async(llamaDQueue, ^{
157
+ @try {
158
+ @autoreleasepool {
159
+ int count = [context saveSession:filePath size:(int)size];
160
+ resolve(@(count));
161
+ }
162
+ } @catch (NSException *exception) {
163
+ reject(@"llama_cpp_error", exception.reason, nil);
164
+ }
165
+ });
166
+ }
167
+
168
+ - (NSArray *)supportedEvents {
169
+ return@[
170
+ @"@Cactus_onInitContextProgress",
171
+ @"@Cactus_onToken",
172
+ @"@Cactus_onNativeLog",
173
+ ];
174
+ }
175
+
176
+ RCT_EXPORT_METHOD(completion:(double)contextId
177
+ withCompletionParams:(NSDictionary *)completionParams
178
+ withResolver:(RCTPromiseResolveBlock)resolve
179
+ withRejecter:(RCTPromiseRejectBlock)reject)
180
+ {
181
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
182
+ if (context == nil) {
183
+ reject(@"llama_error", @"Context not found", nil);
184
+ return;
185
+ }
186
+ if ([context isPredicting]) {
187
+ reject(@"llama_error", @"Context is busy", nil);
188
+ return;
189
+ }
190
+ dispatch_async(llamaDQueue, ^{
191
+ @try {
192
+ @autoreleasepool {
193
+ NSDictionary* completionResult = [context completion:completionParams
194
+ onToken:^(NSMutableDictionary *tokenResult) {
195
+ if (![completionParams[@"emit_partial_completion"] boolValue]) return;
196
+ dispatch_async(dispatch_get_main_queue(), ^{
197
+ [self sendEventWithName:@"@Cactus_onToken"
198
+ body:@{
199
+ @"contextId": [NSNumber numberWithDouble:contextId],
200
+ @"tokenResult": tokenResult
201
+ }
202
+ ];
203
+ [tokenResult release];
204
+ });
205
+ }
206
+ ];
207
+ resolve(completionResult);
208
+ }
209
+ } @catch (NSException *exception) {
210
+ reject(@"llama_cpp_error", exception.reason, nil);
211
+ [context stopCompletion];
212
+ }
213
+ });
214
+
215
+ }
216
+
217
+ RCT_EXPORT_METHOD(stopCompletion:(double)contextId
218
+ withResolver:(RCTPromiseResolveBlock)resolve
219
+ withRejecter:(RCTPromiseRejectBlock)reject)
220
+ {
221
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
222
+ if (context == nil) {
223
+ reject(@"llama_error", @"Context not found", nil);
224
+ return;
225
+ }
226
+ [context stopCompletion];
227
+ resolve(nil);
228
+ }
229
+
230
+ RCT_EXPORT_METHOD(tokenize:(double)contextId
231
+ text:(NSString *)text
232
+ withResolver:(RCTPromiseResolveBlock)resolve
233
+ withRejecter:(RCTPromiseRejectBlock)reject)
234
+ {
235
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
236
+ if (context == nil) {
237
+ reject(@"llama_error", @"Context not found", nil);
238
+ return;
239
+ }
240
+ NSMutableArray *tokens = [context tokenize:text];
241
+ resolve(@{ @"tokens": tokens });
242
+ [tokens release];
243
+ }
244
+
245
+ RCT_EXPORT_METHOD(detokenize:(double)contextId
246
+ tokens:(NSArray *)tokens
247
+ withResolver:(RCTPromiseResolveBlock)resolve
248
+ withRejecter:(RCTPromiseRejectBlock)reject)
249
+ {
250
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
251
+ if (context == nil) {
252
+ reject(@"llama_error", @"Context not found", nil);
253
+ return;
254
+ }
255
+ resolve([context detokenize:tokens]);
256
+ }
257
+
258
+ RCT_EXPORT_METHOD(embedding:(double)contextId
259
+ text:(NSString *)text
260
+ params:(NSDictionary *)params
261
+ withResolver:(RCTPromiseResolveBlock)resolve
262
+ withRejecter:(RCTPromiseRejectBlock)reject)
263
+ {
264
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
265
+ if (context == nil) {
266
+ reject(@"llama_error", @"Context not found", nil);
267
+ return;
268
+ }
269
+ @try {
270
+ NSDictionary *embedding = [context embedding:text params:params];
271
+ resolve(embedding);
272
+ } @catch (NSException *exception) {
273
+ reject(@"llama_cpp_error", exception.reason, nil);
274
+ }
275
+ }
276
+
277
+ RCT_EXPORT_METHOD(bench:(double)contextId
278
+ pp:(int)pp
279
+ tg:(int)tg
280
+ pl:(int)pl
281
+ nr:(int)nr
282
+ withResolver:(RCTPromiseResolveBlock)resolve
283
+ withRejecter:(RCTPromiseRejectBlock)reject)
284
+ {
285
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
286
+ if (context == nil) {
287
+ reject(@"llama_error", @"Context not found", nil);
288
+ return;
289
+ }
290
+ @try {
291
+ NSString *benchResults = [context bench:pp tg:tg pl:pl nr:nr];
292
+ resolve(benchResults);
293
+ } @catch (NSException *exception) {
294
+ reject(@"llama_cpp_error", exception.reason, nil);
295
+ }
296
+ }
297
+
298
+ RCT_EXPORT_METHOD(applyLoraAdapters:(double)contextId
299
+ withLoraAdapters:(NSArray *)loraAdapters
300
+ withResolver:(RCTPromiseResolveBlock)resolve
301
+ withRejecter:(RCTPromiseRejectBlock)reject)
302
+ {
303
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
304
+ if (context == nil) {
305
+ reject(@"llama_error", @"Context not found", nil);
306
+ return;
307
+ }
308
+ if ([context isPredicting]) {
309
+ reject(@"llama_error", @"Context is busy", nil);
310
+ return;
311
+ }
312
+ [context applyLoraAdapters:loraAdapters];
313
+ resolve(nil);
314
+ }
315
+
316
+ RCT_EXPORT_METHOD(removeLoraAdapters:(double)contextId
317
+ withResolver:(RCTPromiseResolveBlock)resolve
318
+ withRejecter:(RCTPromiseRejectBlock)reject)
319
+ {
320
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
321
+ if (context == nil) {
322
+ reject(@"llama_error", @"Context not found", nil);
323
+ return;
324
+ }
325
+ if ([context isPredicting]) {
326
+ reject(@"llama_error", @"Context is busy", nil);
327
+ return;
328
+ }
329
+ [context removeLoraAdapters];
330
+ resolve(nil);
331
+ }
332
+
333
+ RCT_EXPORT_METHOD(getLoadedLoraAdapters:(double)contextId
334
+ withResolver:(RCTPromiseResolveBlock)resolve
335
+ withRejecter:(RCTPromiseRejectBlock)reject)
336
+ {
337
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
338
+ if (context == nil) {
339
+ reject(@"llama_error", @"Context not found", nil);
340
+ return;
341
+ }
342
+ resolve([context getLoadedLoraAdapters]);
343
+ }
344
+
345
+ RCT_EXPORT_METHOD(releaseContext:(double)contextId
346
+ withResolver:(RCTPromiseResolveBlock)resolve
347
+ withRejecter:(RCTPromiseRejectBlock)reject)
348
+ {
349
+ CactusContext *context = llamaContexts[[NSNumber numberWithDouble:contextId]];
350
+ if (context == nil) {
351
+ reject(@"llama_error", @"Context not found", nil);
352
+ return;
353
+ }
354
+ if (![context isModelLoaded]) {
355
+ [context interruptLoad];
356
+ }
357
+ [context stopCompletion];
358
+ dispatch_barrier_sync(llamaDQueue, ^{});
359
+ [context invalidate];
360
+ [llamaContexts removeObjectForKey:[NSNumber numberWithDouble:contextId]];
361
+ resolve(nil);
362
+ }
363
+
364
+ RCT_EXPORT_METHOD(releaseAllContexts:(RCTPromiseResolveBlock)resolve
365
+ withRejecter:(RCTPromiseRejectBlock)reject)
366
+ {
367
+ [self invalidate];
368
+ resolve(nil);
369
+ }
370
+
371
+
372
+ - (void)invalidate {
373
+ if (llamaContexts == nil) {
374
+ return;
375
+ }
376
+
377
+ for (NSNumber *contextId in llamaContexts) {
378
+ CactusContext *context = llamaContexts[contextId];
379
+ [context stopCompletion];
380
+ dispatch_barrier_sync(llamaDQueue, ^{});
381
+ [context invalidate];
382
+ }
383
+
384
+ [llamaContexts removeAllObjects];
385
+ [llamaContexts release];
386
+ llamaContexts = nil;
387
+
388
+ if (llamaDQueue != nil) {
389
+ dispatch_release(llamaDQueue);
390
+ llamaDQueue = nil;
391
+ }
392
+
393
+ [super invalidate];
394
+ }
395
+
396
+ // Don't compile this code when we build for the old architecture.
397
+ #ifdef RCT_NEW_ARCH_ENABLED
398
+ - (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:
399
+ (const facebook::react::ObjCTurboModule::InitParams &)params
400
+ {
401
+ return std::make_shared<facebook::react::NativeCactusSpecJSI>(params);
402
+ }
403
+ #endif
404
+
405
+ @end
@@ -0,0 +1,57 @@
1
+ #ifdef __cplusplus
2
+ #if __has_include(<cactus/llama.h>)
3
+ #import <cactus/llama.h>
4
+ #import <cactus/llama-impl.h>
5
+ #import <cactus/ggml.h>
6
+ #import <cactus/cactus.h>
7
+ #import <cactus/json-schema-to-grammar.h>
8
+ #else
9
+ #import "llama.h"
10
+ #import "llama-impl.h"
11
+ #import "ggml.h"
12
+ #import "cactus.h"
13
+ #import "json-schema-to-grammar.h"
14
+ #endif
15
+ #endif
16
+
17
+
18
+ @interface CactusContext : NSObject {
19
+ bool is_metal_enabled;
20
+ bool is_model_loaded;
21
+ NSString * reason_no_metal;
22
+
23
+ void (^onProgress)(unsigned int progress);
24
+
25
+ cactus::cactus_context * llama;
26
+ }
27
+
28
+ + (void)toggleNativeLog:(BOOL)enabled onEmitLog:(void (^)(NSString *level, NSString *text))onEmitLog;
29
+ + (NSDictionary *)modelInfo:(NSString *)path skip:(NSArray *)skip;
30
+ + (instancetype)initWithParams:(NSDictionary *)params onProgress:(void (^)(unsigned int progress))onProgress;
31
+ - (void)interruptLoad;
32
+ - (bool)isMetalEnabled;
33
+ - (NSString *)reasonNoMetal;
34
+ - (NSDictionary *)modelInfo;
35
+ - (bool)isModelLoaded;
36
+ - (bool)isPredicting;
37
+ - (NSDictionary *)completion:(NSDictionary *)params onToken:(void (^)(NSMutableDictionary *tokenResult))onToken;
38
+ - (void)stopCompletion;
39
+ - (NSArray *)tokenize:(NSString *)text;
40
+ - (NSString *)detokenize:(NSArray *)tokens;
41
+ - (NSDictionary *)embedding:(NSString *)text params:(NSDictionary *)params;
42
+ - (NSDictionary *)getFormattedChatWithJinja:(NSString *)messages
43
+ withChatTemplate:(NSString *)chatTemplate
44
+ withJsonSchema:(NSString *)jsonSchema
45
+ withTools:(NSString *)tools
46
+ withParallelToolCalls:(BOOL)parallelToolCalls
47
+ withToolChoice:(NSString *)toolChoice;
48
+ - (NSString *)getFormattedChat:(NSString *)messages withChatTemplate:(NSString *)chatTemplate;
49
+ - (NSDictionary *)loadSession:(NSString *)path;
50
+ - (int)saveSession:(NSString *)path size:(int)size;
51
+ - (NSString *)bench:(int)pp tg:(int)tg pl:(int)pl nr:(int)nr;
52
+ - (void)applyLoraAdapters:(NSArray *)loraAdapters;
53
+ - (void)removeLoraAdapters;
54
+ - (NSArray *)getLoadedLoraAdapters;
55
+ - (void)invalidate;
56
+
57
+ @end