cui-llama.rn 1.4.4 → 1.4.6

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 (197) hide show
  1. package/android/src/main/CMakeLists.txt +2 -2
  2. package/android/src/main/jni.cpp +12 -10
  3. package/android/src/main/jniLibs/arm64-v8a/librnllama.so +0 -0
  4. package/android/src/main/jniLibs/arm64-v8a/librnllama_v8.so +0 -0
  5. package/android/src/main/jniLibs/arm64-v8a/librnllama_v8_2.so +0 -0
  6. package/android/src/main/jniLibs/arm64-v8a/librnllama_v8_2_dotprod.so +0 -0
  7. package/android/src/main/jniLibs/arm64-v8a/librnllama_v8_2_dotprod_i8mm.so +0 -0
  8. package/android/src/main/jniLibs/arm64-v8a/librnllama_v8_2_i8mm.so +0 -0
  9. package/android/src/main/jniLibs/x86_64/librnllama.so +0 -0
  10. package/android/src/main/jniLibs/x86_64/librnllama_x86_64.so +0 -0
  11. package/cpp/chat-template.hpp +529 -529
  12. package/cpp/chat.cpp +959 -265
  13. package/cpp/chat.h +135 -0
  14. package/cpp/common.cpp +2064 -1996
  15. package/cpp/common.h +700 -744
  16. package/cpp/ggml-alloc.c +1039 -1030
  17. package/cpp/ggml-alloc.h +1 -1
  18. package/cpp/ggml-backend-impl.h +255 -255
  19. package/cpp/ggml-backend-reg.cpp +586 -582
  20. package/cpp/ggml-backend.cpp +2004 -2002
  21. package/cpp/ggml-backend.h +354 -354
  22. package/cpp/ggml-common.h +1851 -1851
  23. package/cpp/ggml-cpp.h +39 -39
  24. package/cpp/ggml-cpu-aarch64.cpp +4248 -4247
  25. package/cpp/ggml-cpu-aarch64.h +8 -8
  26. package/cpp/ggml-cpu-impl.h +531 -380
  27. package/cpp/ggml-cpu-quants.c +12527 -11517
  28. package/cpp/ggml-cpu-traits.cpp +36 -36
  29. package/cpp/ggml-cpu-traits.h +38 -38
  30. package/cpp/ggml-cpu.c +15766 -14485
  31. package/cpp/ggml-cpu.cpp +655 -633
  32. package/cpp/ggml-cpu.h +138 -135
  33. package/cpp/ggml-impl.h +567 -567
  34. package/cpp/ggml-metal-impl.h +235 -0
  35. package/cpp/ggml-metal.h +66 -66
  36. package/cpp/ggml-metal.m +5146 -5002
  37. package/cpp/ggml-opt.cpp +854 -854
  38. package/cpp/ggml-opt.h +216 -216
  39. package/cpp/ggml-quants.c +5238 -5238
  40. package/cpp/ggml-threading.h +14 -14
  41. package/cpp/ggml.c +6529 -6524
  42. package/cpp/ggml.h +2198 -2194
  43. package/cpp/gguf.cpp +1329 -1329
  44. package/cpp/gguf.h +202 -202
  45. package/cpp/json-schema-to-grammar.cpp +1024 -1025
  46. package/cpp/json-schema-to-grammar.h +21 -22
  47. package/cpp/json.hpp +24766 -24766
  48. package/cpp/llama-adapter.cpp +347 -347
  49. package/cpp/llama-adapter.h +74 -74
  50. package/cpp/llama-arch.cpp +1513 -1492
  51. package/cpp/llama-arch.h +403 -402
  52. package/cpp/llama-batch.cpp +368 -368
  53. package/cpp/llama-batch.h +88 -88
  54. package/cpp/llama-chat.cpp +588 -587
  55. package/cpp/llama-chat.h +53 -53
  56. package/cpp/llama-context.cpp +1775 -1775
  57. package/cpp/llama-context.h +128 -128
  58. package/cpp/llama-cparams.cpp +1 -1
  59. package/cpp/llama-cparams.h +37 -37
  60. package/cpp/llama-cpp.h +30 -30
  61. package/cpp/llama-grammar.cpp +1219 -1219
  62. package/cpp/llama-grammar.h +173 -164
  63. package/cpp/llama-hparams.cpp +71 -71
  64. package/cpp/llama-hparams.h +139 -139
  65. package/cpp/llama-impl.cpp +167 -167
  66. package/cpp/llama-impl.h +61 -61
  67. package/cpp/llama-kv-cache.cpp +718 -718
  68. package/cpp/llama-kv-cache.h +219 -218
  69. package/cpp/llama-mmap.cpp +600 -590
  70. package/cpp/llama-mmap.h +68 -68
  71. package/cpp/llama-model-loader.cpp +1124 -1124
  72. package/cpp/llama-model-loader.h +167 -167
  73. package/cpp/llama-model.cpp +4087 -4023
  74. package/cpp/llama-model.h +370 -370
  75. package/cpp/llama-sampling.cpp +2558 -2525
  76. package/cpp/llama-sampling.h +32 -32
  77. package/cpp/llama-vocab.cpp +3264 -3252
  78. package/cpp/llama-vocab.h +125 -125
  79. package/cpp/llama.cpp +10284 -10137
  80. package/cpp/llama.h +1354 -1340
  81. package/cpp/log.cpp +393 -423
  82. package/cpp/log.h +132 -132
  83. package/cpp/minja/chat-template.hpp +529 -0
  84. package/cpp/minja/minja.hpp +2915 -0
  85. package/cpp/minja.hpp +2915 -2883
  86. package/cpp/rn-llama.cpp +20 -37
  87. package/cpp/rn-llama.h +12 -2
  88. package/cpp/sampling.cpp +570 -532
  89. package/cpp/sgemm.cpp +2598 -2598
  90. package/cpp/sgemm.h +14 -14
  91. package/cpp/speculative.cpp +278 -277
  92. package/cpp/speculative.h +28 -28
  93. package/package.json +1 -1
  94. package/android/src/main/build-arm64/CMakeCache.txt +0 -429
  95. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CMakeCCompiler.cmake +0 -81
  96. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CMakeCXXCompiler.cmake +0 -101
  97. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CMakeDetermineCompilerABI_C.bin +0 -0
  98. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CMakeDetermineCompilerABI_CXX.bin +0 -0
  99. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CMakeSystem.cmake +0 -15
  100. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CompilerIdC/CMakeCCompilerId.c +0 -904
  101. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CompilerIdC/CMakeCCompilerId.o +0 -0
  102. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CompilerIdCXX/CMakeCXXCompilerId.cpp +0 -919
  103. package/android/src/main/build-arm64/CMakeFiles/3.31.4/CompilerIdCXX/CMakeCXXCompilerId.o +0 -0
  104. package/android/src/main/build-arm64/CMakeFiles/CMakeConfigureLog.yaml +0 -431
  105. package/android/src/main/build-arm64/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  106. package/android/src/main/build-arm64/CMakeFiles/Makefile.cmake +0 -165
  107. package/android/src/main/build-arm64/CMakeFiles/Makefile2 +0 -297
  108. package/android/src/main/build-arm64/CMakeFiles/Progress/1 +0 -1
  109. package/android/src/main/build-arm64/CMakeFiles/Progress/2 +0 -1
  110. package/android/src/main/build-arm64/CMakeFiles/Progress/3 +0 -1
  111. package/android/src/main/build-arm64/CMakeFiles/Progress/4 +0 -1
  112. package/android/src/main/build-arm64/CMakeFiles/Progress/5 +0 -1
  113. package/android/src/main/build-arm64/CMakeFiles/Progress/6 +0 -1
  114. package/android/src/main/build-arm64/CMakeFiles/Progress/count.txt +0 -1
  115. package/android/src/main/build-arm64/CMakeFiles/TargetDirectories.txt +0 -8
  116. package/android/src/main/build-arm64/CMakeFiles/cmake.check_cache +0 -1
  117. package/android/src/main/build-arm64/CMakeFiles/progress.marks +0 -1
  118. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-alloc.c.o +0 -0
  119. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-alloc.c.o.d +0 -58
  120. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-backend-reg.cpp.o +0 -0
  121. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-backend-reg.cpp.o.d +0 -756
  122. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-backend.cpp.o +0 -0
  123. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-backend.cpp.o.d +0 -709
  124. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-aarch64.cpp.o +0 -0
  125. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-aarch64.cpp.o.d +0 -714
  126. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-quants.c.o +0 -0
  127. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-quants.c.o.d +0 -62
  128. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-traits.cpp.o +0 -0
  129. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu-traits.cpp.o.d +0 -708
  130. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu.c.o +0 -0
  131. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu.c.o.d +0 -113
  132. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu.cpp.o +0 -0
  133. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-cpu.cpp.o.d +0 -713
  134. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-opt.cpp.o +0 -0
  135. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-opt.cpp.o.d +0 -763
  136. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-quants.c.o +0 -0
  137. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-quants.c.o.d +0 -61
  138. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-threading.cpp.o +0 -0
  139. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml-threading.cpp.o.d +0 -707
  140. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml.c.o +0 -0
  141. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/ggml.c.o.d +0 -104
  142. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/gguf.cpp.o +0 -0
  143. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/gguf.cpp.o.d +0 -714
  144. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/log.cpp.o +0 -0
  145. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/D_/dev/react-native/cui-llama.rn/cpp/log.cpp.o.d +0 -723
  146. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/DependInfo.cmake +0 -62
  147. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/build.make +0 -722
  148. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/cmake_clean.cmake +0 -89
  149. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/compiler_depend.make +0 -2
  150. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/compiler_depend.ts +0 -2
  151. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/depend.make +0 -2
  152. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/flags.make +0 -17
  153. package/android/src/main/build-arm64/CMakeFiles/rnllama.dir/progress.make +0 -41
  154. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/DependInfo.cmake +0 -62
  155. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/build.make +0 -722
  156. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/cmake_clean.cmake +0 -89
  157. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/compiler_depend.make +0 -2
  158. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/compiler_depend.ts +0 -2
  159. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/depend.make +0 -2
  160. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/flags.make +0 -17
  161. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8.dir/progress.make +0 -41
  162. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/DependInfo.cmake +0 -62
  163. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/build.make +0 -722
  164. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/cmake_clean.cmake +0 -89
  165. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/compiler_depend.make +0 -2
  166. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/compiler_depend.ts +0 -2
  167. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/depend.make +0 -2
  168. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/flags.make +0 -17
  169. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2.dir/progress.make +0 -41
  170. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/DependInfo.cmake +0 -62
  171. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/build.make +0 -722
  172. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/cmake_clean.cmake +0 -89
  173. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/compiler_depend.make +0 -2
  174. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/compiler_depend.ts +0 -2
  175. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/depend.make +0 -2
  176. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/flags.make +0 -17
  177. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod.dir/progress.make +0 -41
  178. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/DependInfo.cmake +0 -62
  179. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/build.make +0 -722
  180. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/cmake_clean.cmake +0 -89
  181. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/compiler_depend.make +0 -2
  182. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/compiler_depend.ts +0 -2
  183. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/depend.make +0 -2
  184. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/flags.make +0 -17
  185. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_dotprod_i8mm.dir/progress.make +0 -41
  186. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/DependInfo.cmake +0 -62
  187. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/build.make +0 -722
  188. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/cmake_clean.cmake +0 -89
  189. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/compiler_depend.make +0 -2
  190. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/compiler_depend.ts +0 -2
  191. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/depend.make +0 -2
  192. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/flags.make +0 -17
  193. package/android/src/main/build-arm64/CMakeFiles/rnllama_v8_2_i8mm.dir/progress.make +0 -41
  194. package/android/src/main/build-arm64/Makefile +0 -1862
  195. package/android/src/main/build-arm64/cmake_install.cmake +0 -66
  196. package/cpp/chat.hpp +0 -55
  197. package/cpp/rn-llama.hpp +0 -913
@@ -1,164 +1,173 @@
1
- #pragma once
2
-
3
- #include "llama.h"
4
-
5
- #include <map>
6
- #include <string>
7
- #include <vector>
8
-
9
- struct llama_vocab;
10
-
11
- // grammar element type
12
- enum llama_gretype {
13
- // end of rule definition
14
- LLAMA_GRETYPE_END = 0,
15
-
16
- // start of alternate definition for rule
17
- LLAMA_GRETYPE_ALT = 1,
18
-
19
- // non-terminal element: reference to rule
20
- LLAMA_GRETYPE_RULE_REF = 2,
21
-
22
- // terminal element: character (code point)
23
- LLAMA_GRETYPE_CHAR = 3,
24
-
25
- // inverse char(s) ([^a], [^a-b] [^abc])
26
- LLAMA_GRETYPE_CHAR_NOT = 4,
27
-
28
- // modifies a preceding LLAMA_GRETYPE_CHAR or LLAMA_GRETYPE_CHAR_ALT to
29
- // be an inclusive range ([a-z])
30
- LLAMA_GRETYPE_CHAR_RNG_UPPER = 5,
31
-
32
- // modifies a preceding LLAMA_GRETYPE_CHAR or
33
- // LLAMA_GRETYPE_CHAR_RNG_UPPER to add an alternate char to match ([ab], [a-zA])
34
- LLAMA_GRETYPE_CHAR_ALT = 6,
35
-
36
- // any character (.)
37
- LLAMA_GRETYPE_CHAR_ANY = 7,
38
- };
39
-
40
- typedef struct llama_grammar_element {
41
- enum llama_gretype type;
42
- uint32_t value; // Unicode code point or rule ID
43
- } llama_grammar_element;
44
-
45
- struct llama_partial_utf8 {
46
- uint32_t value; // bit value so far (unshifted)
47
- int n_remain; // num bytes remaining; -1 indicates invalid sequence
48
- };
49
-
50
- struct llama_grammar_candidate {
51
- size_t index;
52
- const uint32_t * code_points;
53
- llama_partial_utf8 partial_utf8;
54
- };
55
-
56
- using llama_grammar_rule = std::vector< llama_grammar_element>;
57
- using llama_grammar_stack = std::vector<const llama_grammar_element *>;
58
-
59
- using llama_grammar_rules = std::vector<llama_grammar_rule>;
60
- using llama_grammar_stacks = std::vector<llama_grammar_stack>;
61
- using llama_grammar_candidates = std::vector<llama_grammar_candidate>;
62
-
63
- // TODO: remove, needed for tests atm
64
- const llama_grammar_rules & llama_grammar_get_rules (const struct llama_grammar * grammar);
65
- llama_grammar_stacks & llama_grammar_get_stacks( struct llama_grammar * grammar);
66
-
67
- // takes a set of possible pushdown stacks on a grammar, which are required to
68
- // be positioned at a character range (see `llama_grammar_advance_stack`), and
69
- // produces the N possible stacks if the given char is accepted at those
70
- // positions
71
- void llama_grammar_accept(struct llama_grammar * grammar, uint32_t chr);
72
-
73
- std::vector<llama_grammar_candidate> llama_grammar_reject_candidates_for_stack(
74
- const llama_grammar_rules & rules,
75
- const llama_grammar_stack & stack,
76
- const llama_grammar_candidates & candidates);
77
-
78
- struct llama_grammar_parser {
79
- std::map<std::string, uint32_t> symbol_ids;
80
-
81
- llama_grammar_rules rules;
82
-
83
- llama_grammar_stack c_rules() const;
84
-
85
- uint32_t get_symbol_id(const char * src, size_t len);
86
- uint32_t generate_symbol_id(const std::string & base_name);
87
-
88
- void add_rule(uint32_t rule_id, const llama_grammar_rule & rule);
89
-
90
- const char * parse_alternates(
91
- const char * src,
92
- const std::string & rule_name,
93
- uint32_t rule_id,
94
- bool is_nested);
95
-
96
- const char * parse_sequence(
97
- const char * src,
98
- const std::string & rule_name,
99
- llama_grammar_rule & rule,
100
- bool is_nested);
101
-
102
- const char * parse_rule(const char * src);
103
-
104
- bool parse(const char * src);
105
- void print(FILE * file);
106
- };
107
-
108
- struct llama_grammar {
109
- // note: allow null vocab for testing (not great)
110
- const llama_vocab * vocab;
111
-
112
- const llama_grammar_rules rules; // TODO: shared ptr
113
- llama_grammar_stacks stacks;
114
-
115
- // buffer for partially generated UTF-8 sequence from accepted tokens
116
- llama_partial_utf8 partial_utf8;
117
-
118
- // lazy grammars wait for trigger words or tokens before constraining the sampling.
119
- // we still have trigger_tokens for non-lazy grammars to force printing of special trigger tokens.
120
- // (useful e.g. for tool_choice=required)
121
- bool lazy = false;
122
- bool awaiting_trigger = false; // Initialized to true for lazy grammars only
123
- std::string trigger_buffer; // Output buffered by lazy grammar. Will be cleared once trigger is found.
124
- std::vector<llama_token> trigger_tokens; // Tokens that trigger a lazy grammar, or tokens to force printing of (even if special).
125
- std::vector<std::string> trigger_words;
126
- };
127
-
128
- //
129
- // internal API
130
- //
131
-
132
- // note: needed for tests (not great)
133
- struct llama_grammar * llama_grammar_init_impl(
134
- const struct llama_vocab * vocab,
135
- const llama_grammar_element ** rules,
136
- size_t n_rules,
137
- size_t start_rule_index);
138
-
139
- struct llama_grammar * llama_grammar_init_impl(
140
- const struct llama_vocab * vocab,
141
- const char * grammar_str,
142
- const char * grammar_root,
143
- bool lazy,
144
- const char ** trigger_words,
145
- size_t num_trigger_words,
146
- const llama_token * trigger_tokens,
147
- size_t num_trigger_tokens);
148
-
149
- void llama_grammar_free_impl(struct llama_grammar * grammar);
150
-
151
- struct llama_grammar * llama_grammar_clone_impl(const struct llama_grammar & grammar);
152
-
153
- // TODO: move the API below as member functions of llama_grammar
154
- void llama_grammar_apply_impl(
155
- const struct llama_grammar & grammar,
156
- llama_token_data_array * cur_p);
157
-
158
- void llama_grammar_accept_impl(
159
- struct llama_grammar & grammar,
160
- llama_token token);
161
-
162
- void llama_grammar_accept_str(
163
- struct llama_grammar & grammar,
164
- const std::string & piece);
1
+ #pragma once
2
+
3
+ #include "llama.h"
4
+
5
+ #include <map>
6
+ #include <regex>
7
+ #include <string>
8
+ #include <vector>
9
+
10
+ struct llama_vocab;
11
+
12
+ // grammar element type
13
+ enum llama_gretype {
14
+ // end of rule definition
15
+ LLAMA_GRETYPE_END = 0,
16
+
17
+ // start of alternate definition for rule
18
+ LLAMA_GRETYPE_ALT = 1,
19
+
20
+ // non-terminal element: reference to rule
21
+ LLAMA_GRETYPE_RULE_REF = 2,
22
+
23
+ // terminal element: character (code point)
24
+ LLAMA_GRETYPE_CHAR = 3,
25
+
26
+ // inverse char(s) ([^a], [^a-b] [^abc])
27
+ LLAMA_GRETYPE_CHAR_NOT = 4,
28
+
29
+ // modifies a preceding LLAMA_GRETYPE_CHAR or LLAMA_GRETYPE_CHAR_ALT to
30
+ // be an inclusive range ([a-z])
31
+ LLAMA_GRETYPE_CHAR_RNG_UPPER = 5,
32
+
33
+ // modifies a preceding LLAMA_GRETYPE_CHAR or
34
+ // LLAMA_GRETYPE_CHAR_RNG_UPPER to add an alternate char to match ([ab], [a-zA])
35
+ LLAMA_GRETYPE_CHAR_ALT = 6,
36
+
37
+ // any character (.)
38
+ LLAMA_GRETYPE_CHAR_ANY = 7,
39
+ };
40
+
41
+ typedef struct llama_grammar_element {
42
+ enum llama_gretype type;
43
+ uint32_t value; // Unicode code point or rule ID
44
+ } llama_grammar_element;
45
+
46
+ struct llama_partial_utf8 {
47
+ uint32_t value; // bit value so far (unshifted)
48
+ int n_remain; // num bytes remaining; -1 indicates invalid sequence
49
+ };
50
+
51
+ struct llama_grammar_candidate {
52
+ size_t index;
53
+ const uint32_t * code_points;
54
+ llama_partial_utf8 partial_utf8;
55
+ };
56
+
57
+ using llama_grammar_rule = std::vector< llama_grammar_element>;
58
+ using llama_grammar_stack = std::vector<const llama_grammar_element *>;
59
+
60
+ using llama_grammar_rules = std::vector<llama_grammar_rule>;
61
+ using llama_grammar_stacks = std::vector<llama_grammar_stack>;
62
+ using llama_grammar_candidates = std::vector<llama_grammar_candidate>;
63
+
64
+ // TODO: remove, needed for tests atm
65
+ const llama_grammar_rules & llama_grammar_get_rules (const struct llama_grammar * grammar);
66
+ llama_grammar_stacks & llama_grammar_get_stacks( struct llama_grammar * grammar);
67
+
68
+ // takes a set of possible pushdown stacks on a grammar, which are required to
69
+ // be positioned at a character range (see `llama_grammar_advance_stack`), and
70
+ // produces the N possible stacks if the given char is accepted at those
71
+ // positions
72
+ void llama_grammar_accept(struct llama_grammar * grammar, uint32_t chr);
73
+
74
+ std::vector<llama_grammar_candidate> llama_grammar_reject_candidates_for_stack(
75
+ const llama_grammar_rules & rules,
76
+ const llama_grammar_stack & stack,
77
+ const llama_grammar_candidates & candidates);
78
+
79
+ struct llama_grammar_parser {
80
+ std::map<std::string, uint32_t> symbol_ids;
81
+
82
+ llama_grammar_rules rules;
83
+
84
+ llama_grammar_stack c_rules() const;
85
+
86
+ uint32_t get_symbol_id(const char * src, size_t len);
87
+ uint32_t generate_symbol_id(const std::string & base_name);
88
+
89
+ void add_rule(uint32_t rule_id, const llama_grammar_rule & rule);
90
+
91
+ const char * parse_alternates(
92
+ const char * src,
93
+ const std::string & rule_name,
94
+ uint32_t rule_id,
95
+ bool is_nested);
96
+
97
+ const char * parse_sequence(
98
+ const char * src,
99
+ const std::string & rule_name,
100
+ llama_grammar_rule & rule,
101
+ bool is_nested);
102
+
103
+ const char * parse_rule(const char * src);
104
+
105
+ bool parse(const char * src);
106
+ void print(FILE * file);
107
+ };
108
+
109
+ struct llama_grammar_trigger_pattern {
110
+ std::string pattern;
111
+ std::regex regex;
112
+ };
113
+
114
+ struct llama_grammar {
115
+ // note: allow null vocab for testing (not great)
116
+ const llama_vocab * vocab;
117
+
118
+ const llama_grammar_rules rules; // TODO: shared ptr
119
+ llama_grammar_stacks stacks;
120
+
121
+ // buffer for partially generated UTF-8 sequence from accepted tokens
122
+ llama_partial_utf8 partial_utf8;
123
+
124
+ // lazy grammars wait for trigger words or tokens before constraining the sampling.
125
+ // we still have trigger_tokens for non-lazy grammars to force printing of special trigger tokens.
126
+ // (useful e.g. for tool_choice=required)
127
+ bool lazy = false;
128
+ bool awaiting_trigger = false; // Initialized to true for lazy grammars only
129
+ std::string trigger_buffer; // Output buffered by lazy grammar. Will be cleared once trigger is found.
130
+ std::vector<llama_token> trigger_tokens; // Tokens that trigger a lazy grammar, or tokens to force printing of (even if special).
131
+ std::vector<llama_grammar_trigger_pattern>
132
+ trigger_patterns; // Regular expressions that trigger a lazy grammar. Must be a full match of the entire generated
133
+ // string, and the grammar will be given the string from the first match group onwards.
134
+
135
+ };
136
+
137
+ //
138
+ // internal API
139
+ //
140
+
141
+ // note: needed for tests (not great)
142
+ struct llama_grammar * llama_grammar_init_impl(
143
+ const struct llama_vocab * vocab,
144
+ const llama_grammar_element ** rules,
145
+ size_t n_rules,
146
+ size_t start_rule_index);
147
+
148
+ struct llama_grammar * llama_grammar_init_impl(
149
+ const struct llama_vocab * vocab,
150
+ const char * grammar_str,
151
+ const char * grammar_root,
152
+ bool lazy,
153
+ const char ** trigger_patterns,
154
+ size_t num_trigger_patterns,
155
+ const llama_token * trigger_tokens,
156
+ size_t num_trigger_tokens);
157
+
158
+ void llama_grammar_free_impl(struct llama_grammar * grammar);
159
+
160
+ struct llama_grammar * llama_grammar_clone_impl(const struct llama_grammar & grammar);
161
+
162
+ // TODO: move the API below as member functions of llama_grammar
163
+ void llama_grammar_apply_impl(
164
+ const struct llama_grammar & grammar,
165
+ llama_token_data_array * cur_p);
166
+
167
+ void llama_grammar_accept_impl(
168
+ struct llama_grammar & grammar,
169
+ llama_token token);
170
+
171
+ void llama_grammar_accept_str(
172
+ struct llama_grammar & grammar,
173
+ const std::string & piece);
@@ -1,71 +1,71 @@
1
- #include "llama-hparams.h"
2
-
3
- #include "ggml.h"
4
-
5
- uint32_t llama_hparams::n_head(uint32_t il) const {
6
- if (il < n_layer) {
7
- return n_head_arr[il];
8
- }
9
-
10
- LM_GGML_ABORT("fatal error");
11
- }
12
-
13
- uint32_t llama_hparams::n_head_kv(uint32_t il) const {
14
- if (il < n_layer) {
15
- return n_head_kv_arr[il];
16
- }
17
-
18
- LM_GGML_ABORT("fatal error");
19
- }
20
-
21
- uint32_t llama_hparams::n_ff(uint32_t il) const {
22
- if (il < n_layer) {
23
- return n_ff_arr[il];
24
- }
25
-
26
- LM_GGML_ABORT("fatal error");
27
- }
28
-
29
- uint32_t llama_hparams::n_gqa(uint32_t il) const {
30
- const uint32_t n_head = this->n_head(il);
31
- const uint32_t n_head_kv = this->n_head_kv(il);
32
-
33
- if (n_head_kv == 0) {
34
- return 0;
35
- }
36
-
37
- return n_head/n_head_kv;
38
- }
39
-
40
- uint32_t llama_hparams::n_embd_k_gqa(uint32_t il) const {
41
- const uint32_t n_head_kv = this->n_head_kv(il);
42
-
43
- return n_embd_head_k * n_head_kv;
44
- }
45
-
46
- uint32_t llama_hparams::n_embd_v_gqa(uint32_t il) const {
47
- const uint32_t n_head_kv = this->n_head_kv(il);
48
-
49
- return n_embd_head_v * n_head_kv;
50
- }
51
-
52
- uint32_t llama_hparams::n_embd_k_s() const {
53
- if (wkv_head_size != 0) {
54
- // for RWKV models
55
- return token_shift_count * n_embd;
56
- }
57
-
58
- // TODO: maybe support other convolution strides than 1
59
- // NOTE: since the first column of the conv_state is shifted out each time, it's not actually needed
60
- return (ssm_d_conv > 0 ? ssm_d_conv - 1 : 0) * ssm_d_inner;
61
- }
62
-
63
- uint32_t llama_hparams::n_embd_v_s() const {
64
- if (wkv_head_size != 0) {
65
- // corresponds to RWKV's wkv_states size
66
- return n_embd * wkv_head_size;
67
- }
68
-
69
- // corresponds to Mamba's ssm_states size
70
- return ssm_d_state * ssm_d_inner;
71
- }
1
+ #include "llama-hparams.h"
2
+
3
+ #include "ggml.h"
4
+
5
+ uint32_t llama_hparams::n_head(uint32_t il) const {
6
+ if (il < n_layer) {
7
+ return n_head_arr[il];
8
+ }
9
+
10
+ LM_GGML_ABORT("fatal error");
11
+ }
12
+
13
+ uint32_t llama_hparams::n_head_kv(uint32_t il) const {
14
+ if (il < n_layer) {
15
+ return n_head_kv_arr[il];
16
+ }
17
+
18
+ LM_GGML_ABORT("fatal error");
19
+ }
20
+
21
+ uint32_t llama_hparams::n_ff(uint32_t il) const {
22
+ if (il < n_layer) {
23
+ return n_ff_arr[il];
24
+ }
25
+
26
+ LM_GGML_ABORT("fatal error");
27
+ }
28
+
29
+ uint32_t llama_hparams::n_gqa(uint32_t il) const {
30
+ const uint32_t n_head = this->n_head(il);
31
+ const uint32_t n_head_kv = this->n_head_kv(il);
32
+
33
+ if (n_head_kv == 0) {
34
+ return 0;
35
+ }
36
+
37
+ return n_head/n_head_kv;
38
+ }
39
+
40
+ uint32_t llama_hparams::n_embd_k_gqa(uint32_t il) const {
41
+ const uint32_t n_head_kv = this->n_head_kv(il);
42
+
43
+ return n_embd_head_k * n_head_kv;
44
+ }
45
+
46
+ uint32_t llama_hparams::n_embd_v_gqa(uint32_t il) const {
47
+ const uint32_t n_head_kv = this->n_head_kv(il);
48
+
49
+ return n_embd_head_v * n_head_kv;
50
+ }
51
+
52
+ uint32_t llama_hparams::n_embd_k_s() const {
53
+ if (wkv_head_size != 0) {
54
+ // for RWKV models
55
+ return token_shift_count * n_embd;
56
+ }
57
+
58
+ // TODO: maybe support other convolution strides than 1
59
+ // NOTE: since the first column of the conv_state is shifted out each time, it's not actually needed
60
+ return (ssm_d_conv > 0 ? ssm_d_conv - 1 : 0) * ssm_d_inner;
61
+ }
62
+
63
+ uint32_t llama_hparams::n_embd_v_s() const {
64
+ if (wkv_head_size != 0) {
65
+ // corresponds to RWKV's wkv_states size
66
+ return n_embd * wkv_head_size;
67
+ }
68
+
69
+ // corresponds to Mamba's ssm_states size
70
+ return ssm_d_state * ssm_d_inner;
71
+ }