cui-llama.rn 1.3.6 → 1.4.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 (101) hide show
  1. package/README.md +22 -1
  2. package/android/src/main/CMakeLists.txt +25 -26
  3. package/android/src/main/java/com/rnllama/LlamaContext.java +31 -9
  4. package/android/src/main/java/com/rnllama/RNLlama.java +98 -0
  5. package/android/src/main/jni-utils.h +94 -0
  6. package/android/src/main/jni.cpp +133 -63
  7. package/android/src/newarch/java/com/rnllama/RNLlamaModule.java +15 -0
  8. package/android/src/oldarch/java/com/rnllama/RNLlamaModule.java +15 -0
  9. package/cpp/common.cpp +2085 -1982
  10. package/cpp/common.h +696 -664
  11. package/cpp/ggml-alloc.c +1042 -1037
  12. package/cpp/ggml-backend-impl.h +255 -256
  13. package/cpp/ggml-backend-reg.cpp +582 -582
  14. package/cpp/ggml-backend.cpp +2002 -2002
  15. package/cpp/ggml-backend.h +354 -352
  16. package/cpp/ggml-common.h +1853 -1853
  17. package/cpp/ggml-cpp.h +39 -39
  18. package/cpp/ggml-cpu-aarch64.cpp +4247 -4247
  19. package/cpp/ggml-cpu-aarch64.h +8 -8
  20. package/cpp/ggml-cpu-impl.h +386 -386
  21. package/cpp/ggml-cpu-quants.c +10920 -10839
  22. package/cpp/ggml-cpu-traits.cpp +36 -36
  23. package/cpp/ggml-cpu-traits.h +38 -38
  24. package/cpp/ggml-cpu.c +14391 -14122
  25. package/cpp/ggml-cpu.cpp +635 -627
  26. package/cpp/ggml-cpu.h +135 -135
  27. package/cpp/ggml-impl.h +567 -567
  28. package/cpp/ggml-metal-impl.h +288 -0
  29. package/cpp/ggml-metal.m +4884 -4884
  30. package/cpp/ggml-opt.cpp +854 -0
  31. package/cpp/ggml-opt.h +216 -0
  32. package/cpp/ggml-quants.c +5238 -5238
  33. package/cpp/ggml-threading.h +14 -14
  34. package/cpp/ggml.c +6514 -6448
  35. package/cpp/ggml.h +2194 -2163
  36. package/cpp/gguf.cpp +1329 -1325
  37. package/cpp/gguf.h +202 -202
  38. package/cpp/json-schema-to-grammar.cpp +1045 -1045
  39. package/cpp/json-schema-to-grammar.h +8 -8
  40. package/cpp/json.hpp +24766 -24766
  41. package/cpp/llama-adapter.cpp +347 -346
  42. package/cpp/llama-adapter.h +74 -73
  43. package/cpp/llama-arch.cpp +1487 -1434
  44. package/cpp/llama-arch.h +400 -395
  45. package/cpp/llama-batch.cpp +368 -368
  46. package/cpp/llama-batch.h +88 -88
  47. package/cpp/llama-chat.cpp +578 -567
  48. package/cpp/llama-chat.h +52 -51
  49. package/cpp/llama-context.cpp +1775 -1771
  50. package/cpp/llama-context.h +128 -128
  51. package/cpp/llama-cparams.cpp +1 -1
  52. package/cpp/llama-cparams.h +37 -37
  53. package/cpp/llama-cpp.h +30 -30
  54. package/cpp/llama-grammar.cpp +1139 -1139
  55. package/cpp/llama-grammar.h +143 -143
  56. package/cpp/llama-hparams.cpp +71 -71
  57. package/cpp/llama-hparams.h +139 -140
  58. package/cpp/llama-impl.cpp +167 -167
  59. package/cpp/llama-impl.h +61 -61
  60. package/cpp/llama-kv-cache.cpp +718 -718
  61. package/cpp/llama-kv-cache.h +218 -218
  62. package/cpp/llama-mmap.cpp +590 -589
  63. package/cpp/llama-mmap.h +67 -67
  64. package/cpp/llama-model-loader.cpp +1124 -1011
  65. package/cpp/llama-model-loader.h +167 -158
  66. package/cpp/llama-model.cpp +3997 -2202
  67. package/cpp/llama-model.h +370 -391
  68. package/cpp/llama-sampling.cpp +2408 -2406
  69. package/cpp/llama-sampling.h +32 -48
  70. package/cpp/llama-vocab.cpp +3247 -1982
  71. package/cpp/llama-vocab.h +125 -182
  72. package/cpp/llama.cpp +10077 -12544
  73. package/cpp/llama.h +1323 -1285
  74. package/cpp/log.cpp +401 -401
  75. package/cpp/log.h +121 -121
  76. package/cpp/rn-llama.hpp +123 -116
  77. package/cpp/sampling.cpp +505 -500
  78. package/cpp/sgemm.cpp +2597 -2597
  79. package/cpp/sgemm.h +14 -14
  80. package/cpp/speculative.cpp +277 -274
  81. package/cpp/speculative.h +28 -28
  82. package/cpp/unicode.cpp +2 -3
  83. package/ios/RNLlama.mm +47 -0
  84. package/ios/RNLlamaContext.h +3 -1
  85. package/ios/RNLlamaContext.mm +71 -14
  86. package/jest/mock.js +15 -3
  87. package/lib/commonjs/NativeRNLlama.js.map +1 -1
  88. package/lib/commonjs/index.js +33 -37
  89. package/lib/commonjs/index.js.map +1 -1
  90. package/lib/module/NativeRNLlama.js.map +1 -1
  91. package/lib/module/index.js +31 -35
  92. package/lib/module/index.js.map +1 -1
  93. package/lib/typescript/NativeRNLlama.d.ts +26 -6
  94. package/lib/typescript/NativeRNLlama.d.ts.map +1 -1
  95. package/lib/typescript/index.d.ts +21 -36
  96. package/lib/typescript/index.d.ts.map +1 -1
  97. package/llama-rn.podspec +4 -18
  98. package/package.json +2 -3
  99. package/src/NativeRNLlama.ts +32 -13
  100. package/src/index.ts +52 -47
  101. package/cpp/llama.cpp.rej +0 -23
@@ -1,143 +1,143 @@
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
-
119
- //
120
- // internal API
121
- //
122
-
123
- // note: needed for tests (not great)
124
- struct llama_grammar * llama_grammar_init_impl(
125
- const struct llama_vocab * vocab,
126
- const llama_grammar_element ** rules,
127
- size_t n_rules,
128
- size_t start_rule_index);
129
-
130
- struct llama_grammar * llama_grammar_init_impl(const struct llama_vocab * vocab, const char * grammar_str, const char * grammar_root);
131
-
132
- void llama_grammar_free_impl(struct llama_grammar * grammar);
133
-
134
- struct llama_grammar * llama_grammar_clone_impl(const struct llama_grammar & grammar);
135
-
136
- // TODO: move the API below as member functions of llama_grammar
137
- void llama_grammar_apply_impl(
138
- const struct llama_grammar & grammar,
139
- llama_token_data_array * cur_p);
140
-
141
- void llama_grammar_accept_impl(
142
- struct llama_grammar & grammar,
143
- llama_token token);
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
+
119
+ //
120
+ // internal API
121
+ //
122
+
123
+ // note: needed for tests (not great)
124
+ struct llama_grammar * llama_grammar_init_impl(
125
+ const struct llama_vocab * vocab,
126
+ const llama_grammar_element ** rules,
127
+ size_t n_rules,
128
+ size_t start_rule_index);
129
+
130
+ struct llama_grammar * llama_grammar_init_impl(const struct llama_vocab * vocab, const char * grammar_str, const char * grammar_root);
131
+
132
+ void llama_grammar_free_impl(struct llama_grammar * grammar);
133
+
134
+ struct llama_grammar * llama_grammar_clone_impl(const struct llama_grammar & grammar);
135
+
136
+ // TODO: move the API below as member functions of llama_grammar
137
+ void llama_grammar_apply_impl(
138
+ const struct llama_grammar & grammar,
139
+ llama_token_data_array * cur_p);
140
+
141
+ void llama_grammar_accept_impl(
142
+ struct llama_grammar & grammar,
143
+ llama_token token);
@@ -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 2 * 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
+ }