2024-09-09 23:36:09 +02:00
|
|
|
#include "arg.h"
|
2023-03-25 19:26:40 +01:00
|
|
|
#include "common.h"
|
2023-08-04 17:20:12 +02:00
|
|
|
#include "console.h"
|
2024-09-15 19:46:12 +02:00
|
|
|
#include "log.h"
|
2024-09-09 23:36:09 +02:00
|
|
|
#include "sampling.h"
|
2023-03-22 06:32:36 +01:00
|
|
|
#include "llama.h"
|
2023-03-10 19:40:58 +01:00
|
|
|
|
|
|
|
#include <cstdio>
|
|
|
|
#include <cstring>
|
2023-04-16 12:13:00 +02:00
|
|
|
#include <ctime>
|
2023-03-10 19:40:58 +01:00
|
|
|
#include <fstream>
|
2023-03-19 20:44:30 +01:00
|
|
|
#include <iostream>
|
2023-08-28 17:59:39 +02:00
|
|
|
#include <sstream>
|
2023-03-10 19:40:58 +01:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2023-03-13 04:08:01 +01:00
|
|
|
#if defined (__unix__) || (defined (__APPLE__) && defined (__MACH__))
|
2023-03-12 22:13:28 +01:00
|
|
|
#include <signal.h>
|
|
|
|
#include <unistd.h>
|
2023-03-15 20:56:24 +01:00
|
|
|
#elif defined (_WIN32)
|
2023-05-03 03:01:57 +02:00
|
|
|
#define WIN32_LEAN_AND_MEAN
|
2023-06-16 20:25:01 +02:00
|
|
|
#ifndef NOMINMAX
|
2023-05-03 03:01:57 +02:00
|
|
|
#define NOMINMAX
|
2023-06-16 20:25:01 +02:00
|
|
|
#endif
|
2023-05-03 03:01:57 +02:00
|
|
|
#include <windows.h>
|
2023-03-15 20:56:24 +01:00
|
|
|
#include <signal.h>
|
2023-03-13 04:08:01 +01:00
|
|
|
#endif
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2023-06-16 20:23:53 +02:00
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#pragma warning(disable: 4244 4267) // possible loss of data
|
|
|
|
#endif
|
|
|
|
|
2023-08-28 17:59:39 +02:00
|
|
|
static llama_context ** g_ctx;
|
|
|
|
static llama_model ** g_model;
|
2024-10-10 22:57:42 +02:00
|
|
|
static common_sampler ** g_smpl;
|
|
|
|
static common_params * g_params;
|
2023-08-28 17:59:39 +02:00
|
|
|
static std::vector<llama_token> * g_input_tokens;
|
|
|
|
static std::ostringstream * g_output_ss;
|
|
|
|
static std::vector<llama_token> * g_output_tokens;
|
2024-07-04 20:55:03 +02:00
|
|
|
static bool is_interacting = false;
|
|
|
|
static bool need_insert_eot = false;
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
static void print_usage(int argc, char ** argv) {
|
|
|
|
(void) argc;
|
|
|
|
|
|
|
|
LOG("\nexample usage:\n");
|
|
|
|
LOG("\n text generation: %s -m your_model.gguf -p \"I believe the meaning of life is\" -n 128\n", argv[0]);
|
|
|
|
LOG("\n chat (conversation): %s -m your_model.gguf -p \"You are a helpful assistant\" -cnv\n", argv[0]);
|
|
|
|
LOG("\n");
|
2024-09-07 20:43:51 +02:00
|
|
|
}
|
|
|
|
|
2024-06-25 13:56:49 +02:00
|
|
|
static bool file_exists(const std::string & path) {
|
2024-01-30 10:18:02 +01:00
|
|
|
std::ifstream f(path.c_str());
|
|
|
|
return f.good();
|
|
|
|
}
|
|
|
|
|
2024-06-25 13:56:49 +02:00
|
|
|
static bool file_is_empty(const std::string & path) {
|
2024-01-30 10:18:02 +01:00
|
|
|
std::ifstream f;
|
|
|
|
f.exceptions(std::ifstream::failbit | std::ifstream::badbit);
|
|
|
|
f.open(path.c_str(), std::ios::in | std::ios::binary | std::ios::ate);
|
|
|
|
return f.tellg() == 0;
|
|
|
|
}
|
2023-09-15 21:38:27 +02:00
|
|
|
|
2023-03-15 20:56:24 +01:00
|
|
|
#if defined (__unix__) || (defined (__APPLE__) && defined (__MACH__)) || defined (_WIN32)
|
2023-09-15 21:38:27 +02:00
|
|
|
static void sigint_handler(int signo) {
|
2023-03-12 22:13:28 +01:00
|
|
|
if (signo == SIGINT) {
|
2024-02-11 14:35:50 +01:00
|
|
|
if (!is_interacting && g_params->interactive) {
|
2024-07-04 20:55:03 +02:00
|
|
|
is_interacting = true;
|
|
|
|
need_insert_eot = true;
|
2023-03-12 22:13:28 +01:00
|
|
|
} else {
|
2023-08-04 17:20:12 +02:00
|
|
|
console::cleanup();
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("\n");
|
2024-10-10 22:57:42 +02:00
|
|
|
common_perf_print(*g_ctx, *g_smpl);
|
2024-09-20 10:46:56 +02:00
|
|
|
|
|
|
|
// make sure all logs are flushed
|
|
|
|
LOG("Interrupted by user\n");
|
2024-10-10 22:57:42 +02:00
|
|
|
common_log_pause(common_log_main());
|
2024-09-20 10:46:56 +02:00
|
|
|
|
2023-03-12 22:13:28 +01:00
|
|
|
_exit(130);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-03-13 04:08:01 +01:00
|
|
|
#endif
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
static std::string chat_add_and_format(struct llama_model * model, std::vector<common_chat_msg> & chat_msgs, const std::string & role, const std::string & content) {
|
|
|
|
common_chat_msg new_msg{role, content};
|
|
|
|
auto formatted = common_chat_format_single(model, g_params->chat_template, chat_msgs, new_msg, role == "user");
|
2024-06-25 13:56:49 +02:00
|
|
|
chat_msgs.push_back({role, content});
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("formatted: '%s'\n", formatted.c_str());
|
2024-06-25 13:56:49 +02:00
|
|
|
return formatted;
|
|
|
|
}
|
|
|
|
|
2023-03-10 19:40:58 +01:00
|
|
|
int main(int argc, char ** argv) {
|
2024-10-10 22:57:42 +02:00
|
|
|
common_params params;
|
2023-08-28 17:59:39 +02:00
|
|
|
g_params = ¶ms;
|
2024-10-10 22:57:42 +02:00
|
|
|
if (!common_params_parse(argc, argv, params, LLAMA_EXAMPLE_MAIN, print_usage)) {
|
2023-03-10 19:40:58 +01:00
|
|
|
return 1;
|
|
|
|
}
|
2024-06-04 20:23:39 +02:00
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
common_init();
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-11-25 08:58:41 +01:00
|
|
|
auto & sparams = params.sampling;
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-03-25 21:29:22 +01:00
|
|
|
// save choice to use color for later
|
|
|
|
// (note for later: this is a slightly awkward choice)
|
2023-08-04 17:20:12 +02:00
|
|
|
console::init(params.simple_io, params.use_color);
|
|
|
|
atexit([]() { console::cleanup(); });
|
2023-03-25 21:29:22 +01:00
|
|
|
|
2023-09-28 18:04:36 +02:00
|
|
|
if (params.logits_all) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("************\n");
|
|
|
|
LOG_ERR("%s: please use the 'perplexity' tool for perplexity calculations\n", __func__);
|
|
|
|
LOG_ERR("************\n\n");
|
2023-03-25 19:26:40 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2023-03-25 20:36:22 +01:00
|
|
|
if (params.embedding) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("************\n");
|
|
|
|
LOG_ERR("%s: please use the 'embedding' tool for embedding calculations\n", __func__);
|
|
|
|
LOG_ERR("************\n\n");
|
2023-03-25 20:36:22 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2023-09-28 21:42:38 +02:00
|
|
|
if (params.n_ctx != 0 && params.n_ctx < 8) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("%s: warning: minimum context size is 8, using minimum size.\n", __func__);
|
2023-09-28 21:42:38 +02:00
|
|
|
params.n_ctx = 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (params.rope_freq_base != 0.0) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("%s: warning: changing RoPE frequency base to %g.\n", __func__, params.rope_freq_base);
|
llama : add custom RoPE (#2054)
* Implement customizable RoPE
The original RoPE has pre-defined parameters
theta_i = 10000^(−2(i−1)/d), for i in [1, 2, ..., d/2]
Our customizable RoPE, ggml_rope_custom_inplace, uses
theta_i = scale * base^(−2(i−1)/d), for i in [1, 2, ..., d/2]
with the default matches the original
scale = 1.0
base = 10000
The new command line arguments
--rope-freq-base
--rope-freq-scale
set the two new RoPE parameter.
Recent researches show changing these two parameters extends the context limit with minimal loss.
1. Extending Context to 8K
kaiokendev
https://kaiokendev.github.io/til#extending-context-to-8k
2. Extending Context Window of Large Language Models via Positional Interpolation
Shouyuan Chen, Sherman Wong, Liangjian Chen, Yuandong Tian
https://arxiv.org/abs/2306.15595
3. NTK-Aware Scaled RoPE allows LLaMA models to have extended (8k+) context size without any fine-tuning and minimal perplexity degradation.
https://www.reddit.com/user/bloc97
https://www.reddit.com/r/LocalLLaMA/comments/14lz7j5/ntkaware_scaled_rope_allows_llama_models_to_have/
For the bold, try adding the following command line parameters to your favorite model:
-c 16384 --rope-freq-base 80000 --rope-freq-scale 0.5
* ggml-metal: fix custom rope
* common: fix argument names in help
* llama: increase MEM_REQ_EVAL for MODEL_3B
It avoids crashing for quantized weights on CPU.
Better ways to calculate the required buffer size would be better.
* llama: make MEM_REQ_EVAL depend on n_ctx
* server: use proper Content-Type in curl examples
Without the header Content-Type: application/json, curl will POST with
Content-Type: application/x-www-form-urlencoded
Though our simple server doesn't care, the httplib.h used has a limit
with CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH 8192
With Content-Type: application/json, we can send large json data.
* style : minor fixes, mostly indentations
* ggml : fix asserts
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-07-15 12:34:16 +02:00
|
|
|
}
|
|
|
|
|
2023-09-28 21:42:38 +02:00
|
|
|
if (params.rope_freq_scale != 0.0) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("%s: warning: scaling RoPE frequency by %g.\n", __func__, params.rope_freq_scale);
|
llama : add custom RoPE (#2054)
* Implement customizable RoPE
The original RoPE has pre-defined parameters
theta_i = 10000^(−2(i−1)/d), for i in [1, 2, ..., d/2]
Our customizable RoPE, ggml_rope_custom_inplace, uses
theta_i = scale * base^(−2(i−1)/d), for i in [1, 2, ..., d/2]
with the default matches the original
scale = 1.0
base = 10000
The new command line arguments
--rope-freq-base
--rope-freq-scale
set the two new RoPE parameter.
Recent researches show changing these two parameters extends the context limit with minimal loss.
1. Extending Context to 8K
kaiokendev
https://kaiokendev.github.io/til#extending-context-to-8k
2. Extending Context Window of Large Language Models via Positional Interpolation
Shouyuan Chen, Sherman Wong, Liangjian Chen, Yuandong Tian
https://arxiv.org/abs/2306.15595
3. NTK-Aware Scaled RoPE allows LLaMA models to have extended (8k+) context size without any fine-tuning and minimal perplexity degradation.
https://www.reddit.com/user/bloc97
https://www.reddit.com/r/LocalLLaMA/comments/14lz7j5/ntkaware_scaled_rope_allows_llama_models_to_have/
For the bold, try adding the following command line parameters to your favorite model:
-c 16384 --rope-freq-base 80000 --rope-freq-scale 0.5
* ggml-metal: fix custom rope
* common: fix argument names in help
* llama: increase MEM_REQ_EVAL for MODEL_3B
It avoids crashing for quantized weights on CPU.
Better ways to calculate the required buffer size would be better.
* llama: make MEM_REQ_EVAL depend on n_ctx
* server: use proper Content-Type in curl examples
Without the header Content-Type: application/json, curl will POST with
Content-Type: application/x-www-form-urlencoded
Though our simple server doesn't care, the httplib.h used has a limit
with CPPHTTPLIB_FORM_URL_ENCODED_PAYLOAD_MAX_LENGTH 8192
With Content-Type: application/json, we can send large json data.
* style : minor fixes, mostly indentations
* ggml : fix asserts
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-07-15 12:34:16 +02:00
|
|
|
}
|
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: llama backend init\n", __func__);
|
2023-05-01 18:23:47 +02:00
|
|
|
|
2024-02-16 10:31:07 +01:00
|
|
|
llama_backend_init();
|
|
|
|
llama_numa_init(params.numa);
|
2023-04-22 12:54:13 +02:00
|
|
|
|
2024-09-07 14:16:19 +02:00
|
|
|
llama_model * model = nullptr;
|
|
|
|
llama_context * ctx = nullptr;
|
2024-10-10 22:57:42 +02:00
|
|
|
common_sampler * smpl = nullptr;
|
2024-09-07 14:16:19 +02:00
|
|
|
|
2023-08-28 17:59:39 +02:00
|
|
|
g_model = &model;
|
2023-04-22 10:56:35 +02:00
|
|
|
g_ctx = &ctx;
|
2024-09-07 14:16:19 +02:00
|
|
|
g_smpl = &smpl;
|
2023-03-10 19:40:58 +01:00
|
|
|
|
2025-01-03 09:18:53 +01:00
|
|
|
std::vector<common_chat_msg> chat_msgs;
|
|
|
|
|
2023-05-02 22:39:51 +02:00
|
|
|
// load the model and apply lora adapter, if any
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: load the model and apply lora adapter, if any\n", __func__);
|
2024-10-10 22:57:42 +02:00
|
|
|
common_init_result llama_init = common_init_from_params(params);
|
2024-08-05 18:14:10 +02:00
|
|
|
|
2025-01-03 09:18:53 +01:00
|
|
|
model = llama_init.model.get();
|
|
|
|
ctx = llama_init.context.get();
|
2023-07-11 18:18:43 +02:00
|
|
|
|
2023-06-24 10:47:58 +02:00
|
|
|
if (model == NULL) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: error: unable to load model\n", __func__);
|
2023-05-02 22:39:51 +02:00
|
|
|
return 1;
|
2023-04-17 17:28:55 +02:00
|
|
|
}
|
|
|
|
|
2025-01-12 10:32:42 +01:00
|
|
|
const llama_vocab * vocab = llama_model_get_vocab(model);
|
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: llama threadpool init, n_threads = %d\n", __func__, (int) params.cpuparams.n_threads);
|
|
|
|
|
2024-11-25 15:13:39 +01:00
|
|
|
auto * reg = ggml_backend_dev_backend_reg(ggml_backend_dev_by_type(GGML_BACKEND_DEVICE_TYPE_CPU));
|
|
|
|
auto * ggml_threadpool_new_fn = (decltype(ggml_threadpool_new) *) ggml_backend_reg_get_proc_address(reg, "ggml_threadpool_new");
|
|
|
|
auto * ggml_threadpool_free_fn = (decltype(ggml_threadpool_free) *) ggml_backend_reg_get_proc_address(reg, "ggml_threadpool_free");
|
|
|
|
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
struct ggml_threadpool_params tpp_batch =
|
|
|
|
ggml_threadpool_params_from_cpu_params(params.cpuparams_batch);
|
|
|
|
struct ggml_threadpool_params tpp =
|
|
|
|
ggml_threadpool_params_from_cpu_params(params.cpuparams);
|
|
|
|
|
|
|
|
set_process_priority(params.cpuparams.priority);
|
|
|
|
|
|
|
|
struct ggml_threadpool * threadpool_batch = NULL;
|
|
|
|
if (!ggml_threadpool_params_match(&tpp, &tpp_batch)) {
|
2024-11-25 15:13:39 +01:00
|
|
|
threadpool_batch = ggml_threadpool_new_fn(&tpp_batch);
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
if (!threadpool_batch) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: batch threadpool create failed : n_threads %d\n", __func__, tpp_batch.n_threads);
|
|
|
|
return 1;
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Start the non-batch threadpool in the paused state
|
|
|
|
tpp.paused = true;
|
|
|
|
}
|
|
|
|
|
2024-11-25 15:13:39 +01:00
|
|
|
struct ggml_threadpool * threadpool = ggml_threadpool_new_fn(&tpp);
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
if (!threadpool) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: threadpool create failed : n_threads %d\n", __func__, tpp.n_threads);
|
|
|
|
return 1;
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
llama_attach_threadpool(ctx, threadpool, threadpool_batch);
|
|
|
|
|
2025-01-12 10:32:42 +01:00
|
|
|
const int n_ctx_train = llama_model_n_ctx_train(model);
|
2023-09-28 21:42:38 +02:00
|
|
|
const int n_ctx = llama_n_ctx(ctx);
|
|
|
|
|
|
|
|
if (n_ctx > n_ctx_train) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("%s: model was trained on only %d context tokens (%d specified)\n", __func__, n_ctx_train, n_ctx);
|
2023-09-04 21:26:24 +02:00
|
|
|
}
|
|
|
|
|
2024-07-04 20:55:03 +02:00
|
|
|
// print chat template example in conversation mode
|
|
|
|
if (params.conversation) {
|
|
|
|
if (params.enable_chat_template) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%s: chat template example:\n%s\n", __func__, common_chat_format_example(model, params.chat_template).c_str());
|
2024-07-04 20:55:03 +02:00
|
|
|
} else {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: in-suffix/prefix is specified, chat template will be disabled\n", __func__);
|
2024-07-04 20:55:03 +02:00
|
|
|
}
|
|
|
|
}
|
2024-06-25 13:56:49 +02:00
|
|
|
|
2023-03-13 18:15:08 +01:00
|
|
|
// print system information
|
|
|
|
{
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("\n");
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%s\n", common_params_get_system_info(params).c_str());
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("\n");
|
2023-03-13 18:15:08 +01:00
|
|
|
}
|
|
|
|
|
2023-05-10 17:37:14 +02:00
|
|
|
std::string path_session = params.path_prompt_cache;
|
2023-04-28 17:59:37 +02:00
|
|
|
std::vector<llama_token> session_tokens;
|
|
|
|
|
|
|
|
if (!path_session.empty()) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: attempting to load saved session from '%s'\n", __func__, path_session.c_str());
|
2024-01-30 10:18:02 +01:00
|
|
|
if (!file_exists(path_session)) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: session file does not exist, will create.\n", __func__);
|
2024-01-30 10:18:02 +01:00
|
|
|
} else if (file_is_empty(path_session)) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: The session file is empty. A new session will be initialized.\n", __func__);
|
2024-01-30 10:18:02 +01:00
|
|
|
} else {
|
|
|
|
// The file exists and is not empty
|
2023-09-28 21:42:38 +02:00
|
|
|
session_tokens.resize(n_ctx);
|
2023-04-28 17:59:37 +02:00
|
|
|
size_t n_token_count_out = 0;
|
2024-04-08 14:43:30 +02:00
|
|
|
if (!llama_state_load_file(ctx, path_session.c_str(), session_tokens.data(), session_tokens.capacity(), &n_token_count_out)) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: failed to load session file '%s'\n", __func__, path_session.c_str());
|
2023-05-01 13:54:59 +02:00
|
|
|
return 1;
|
|
|
|
}
|
2023-04-28 17:59:37 +02:00
|
|
|
session_tokens.resize(n_token_count_out);
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: loaded a session with prompt size of %d tokens\n", __func__, (int)session_tokens.size());
|
2023-04-28 17:59:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-01-12 10:32:42 +01:00
|
|
|
const bool add_bos = llama_vocab_get_add_bos(vocab);
|
2024-07-04 15:46:11 +02:00
|
|
|
if (!llama_model_has_encoder(model)) {
|
2025-01-12 10:32:42 +01:00
|
|
|
GGML_ASSERT(!llama_vocab_get_add_eos(vocab));
|
2024-07-04 15:46:11 +02:00
|
|
|
}
|
2024-09-15 19:46:12 +02:00
|
|
|
|
|
|
|
LOG_DBG("n_ctx: %d, add_bos: %d\n", n_ctx, add_bos);
|
2023-08-23 22:08:04 +02:00
|
|
|
|
2023-05-26 04:18:01 +02:00
|
|
|
std::vector<llama_token> embd_inp;
|
2023-08-26 13:45:53 +02:00
|
|
|
|
2024-06-25 13:56:49 +02:00
|
|
|
{
|
2024-07-04 20:55:03 +02:00
|
|
|
auto prompt = (params.conversation && params.enable_chat_template && !params.prompt.empty())
|
2024-06-25 13:56:49 +02:00
|
|
|
? chat_add_and_format(model, chat_msgs, "system", params.prompt) // format the system prompt in conversation mode
|
|
|
|
: params.prompt;
|
|
|
|
if (params.interactive_first || !params.prompt.empty() || session_tokens.empty()) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("tokenize the prompt\n");
|
2024-10-10 22:57:42 +02:00
|
|
|
embd_inp = common_tokenize(ctx, prompt, true, true);
|
2024-06-25 13:56:49 +02:00
|
|
|
} else {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("use session tokens\n");
|
2024-06-25 13:56:49 +02:00
|
|
|
embd_inp = session_tokens;
|
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("prompt: \"%s\"\n", prompt.c_str());
|
|
|
|
LOG_DBG("tokens: %s\n", string_from(ctx, embd_inp).c_str());
|
2024-06-25 13:56:49 +02:00
|
|
|
}
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-08-23 16:46:03 +02:00
|
|
|
// Should not run without any tokens
|
|
|
|
if (embd_inp.empty()) {
|
2024-07-12 13:48:04 +02:00
|
|
|
if (add_bos) {
|
2025-01-12 10:32:42 +01:00
|
|
|
embd_inp.push_back(llama_vocab_bos(vocab));
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("embd_inp was considered empty and bos was added: %s\n", string_from(ctx, embd_inp).c_str());
|
2024-07-12 13:48:04 +02:00
|
|
|
} else {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("input is empty\n");
|
2024-07-12 13:48:04 +02:00
|
|
|
return -1;
|
|
|
|
}
|
2023-08-23 16:46:03 +02:00
|
|
|
}
|
|
|
|
|
2023-07-11 18:18:43 +02:00
|
|
|
// Tokenize negative prompt
|
2023-03-25 20:36:22 +01:00
|
|
|
if ((int) embd_inp.size() > n_ctx - 4) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: prompt is too long (%d tokens, max %d)\n", __func__, (int) embd_inp.size(), n_ctx - 4);
|
2023-03-25 20:36:22 +01:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2023-04-28 17:59:37 +02:00
|
|
|
// debug message about similarity of saved session, if applicable
|
|
|
|
size_t n_matching_session_tokens = 0;
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!session_tokens.empty()) {
|
2023-04-28 17:59:37 +02:00
|
|
|
for (llama_token id : session_tokens) {
|
|
|
|
if (n_matching_session_tokens >= embd_inp.size() || id != embd_inp[n_matching_session_tokens]) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
n_matching_session_tokens++;
|
|
|
|
}
|
2023-05-26 04:18:01 +02:00
|
|
|
if (params.prompt.empty() && n_matching_session_tokens == embd_inp.size()) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: using full prompt from session file\n", __func__);
|
2023-05-26 04:18:01 +02:00
|
|
|
} else if (n_matching_session_tokens >= embd_inp.size()) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: session file has exact match for prompt!\n", __func__);
|
2023-04-28 17:59:37 +02:00
|
|
|
} else if (n_matching_session_tokens < (embd_inp.size() / 2)) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("%s: session file has low similarity to prompt (%zu / %zu tokens); will mostly be reevaluated\n",
|
|
|
|
__func__, n_matching_session_tokens, embd_inp.size());
|
2023-04-28 17:59:37 +02:00
|
|
|
} else {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: session file matches %zu / %zu tokens of prompt\n",
|
|
|
|
__func__, n_matching_session_tokens, embd_inp.size());
|
2023-04-28 17:59:37 +02:00
|
|
|
}
|
2023-10-11 22:55:08 +02:00
|
|
|
|
|
|
|
// remove any "future" tokens that we might have inherited from the previous session
|
2023-10-29 18:31:40 +01:00
|
|
|
llama_kv_cache_seq_rm(ctx, -1, n_matching_session_tokens, -1);
|
2023-04-28 17:59:37 +02:00
|
|
|
}
|
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("recalculate the cached logits (check): embd_inp.size() %zu, n_matching_session_tokens %zu, embd_inp.size() %zu, session_tokens.size() %zu\n",
|
|
|
|
embd_inp.size(), n_matching_session_tokens, embd_inp.size(), session_tokens.size());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-06-03 13:28:45 +02:00
|
|
|
// if we will use the cache for the full prompt without reaching the end of the cache, force
|
2024-04-29 19:56:59 +02:00
|
|
|
// reevaluation of the last token to recalculate the cached logits
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
if (!embd_inp.empty() && n_matching_session_tokens == embd_inp.size() && session_tokens.size() > embd_inp.size()) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("recalculate the cached logits (do): session_tokens.resize( %zu )\n", embd_inp.size() - 1);
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-06-03 13:28:45 +02:00
|
|
|
session_tokens.resize(embd_inp.size() - 1);
|
|
|
|
}
|
|
|
|
|
2023-03-28 16:09:55 +02:00
|
|
|
// number of tokens to keep when resetting context
|
2024-06-04 20:23:39 +02:00
|
|
|
if (params.n_keep < 0 || params.n_keep > (int) embd_inp.size()) {
|
2023-03-28 16:09:55 +02:00
|
|
|
params.n_keep = (int)embd_inp.size();
|
2024-02-21 16:33:54 +01:00
|
|
|
} else {
|
|
|
|
params.n_keep += add_bos; // always keep the BOS token
|
2023-03-28 16:09:55 +02:00
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
|
2024-06-04 20:23:39 +02:00
|
|
|
if (params.conversation) {
|
2024-05-08 16:32:32 +02:00
|
|
|
params.interactive_first = true;
|
|
|
|
}
|
2023-03-19 17:37:02 +01:00
|
|
|
|
2023-05-19 19:24:59 +02:00
|
|
|
// enable interactive mode if interactive start is specified
|
|
|
|
if (params.interactive_first) {
|
2023-03-22 18:16:35 +01:00
|
|
|
params.interactive = true;
|
|
|
|
}
|
|
|
|
|
2023-03-25 16:16:50 +01:00
|
|
|
if (params.verbose_prompt) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: prompt: '%s'\n", __func__, params.prompt.c_str());
|
|
|
|
LOG_INF("%s: number of tokens in prompt = %zu\n", __func__, embd_inp.size());
|
2023-03-25 16:16:50 +01:00
|
|
|
for (int i = 0; i < (int) embd_inp.size(); i++) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%6d -> '%s'\n", embd_inp[i], common_token_to_piece(ctx, embd_inp[i]).c_str());
|
2023-03-25 16:16:50 +01:00
|
|
|
}
|
2023-07-11 18:18:43 +02:00
|
|
|
|
2024-02-21 16:33:54 +01:00
|
|
|
if (params.n_keep > add_bos) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("%s: static prompt based on n_keep: '", __func__);
|
2023-03-25 20:36:22 +01:00
|
|
|
for (int i = 0; i < params.n_keep; i++) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_CNT("%s", common_token_to_piece(ctx, embd_inp[i]).c_str());
|
2023-03-25 20:36:22 +01:00
|
|
|
}
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_CNT("'\n");
|
2023-03-25 20:36:22 +01:00
|
|
|
}
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("\n");
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
2023-03-25 16:16:50 +01:00
|
|
|
|
2024-02-11 14:35:50 +01:00
|
|
|
// ctrl+C handling
|
|
|
|
{
|
2023-03-13 04:08:01 +01:00
|
|
|
#if defined (__unix__) || (defined (__APPLE__) && defined (__MACH__))
|
2023-03-12 22:13:28 +01:00
|
|
|
struct sigaction sigint_action;
|
|
|
|
sigint_action.sa_handler = sigint_handler;
|
|
|
|
sigemptyset (&sigint_action.sa_mask);
|
2023-03-13 18:15:08 +01:00
|
|
|
sigint_action.sa_flags = 0;
|
2023-03-12 22:13:28 +01:00
|
|
|
sigaction(SIGINT, &sigint_action, NULL);
|
2023-03-15 20:56:24 +01:00
|
|
|
#elif defined (_WIN32)
|
2023-05-18 19:30:40 +02:00
|
|
|
auto console_ctrl_handler = +[](DWORD ctrl_type) -> BOOL {
|
2023-05-03 03:01:57 +02:00
|
|
|
return (ctrl_type == CTRL_C_EVENT) ? (sigint_handler(SIGINT), true) : false;
|
|
|
|
};
|
2023-08-21 22:07:43 +02:00
|
|
|
SetConsoleCtrlHandler(reinterpret_cast<PHANDLER_ROUTINE>(console_ctrl_handler), true);
|
2023-03-13 04:08:01 +01:00
|
|
|
#endif
|
2024-02-11 14:35:50 +01:00
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2024-02-11 14:35:50 +01:00
|
|
|
if (params.interactive) {
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("%s: interactive mode on.\n", __func__);
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!params.antiprompt.empty()) {
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
for (const auto & antiprompt : params.antiprompt) {
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("Reverse prompt: '%s'\n", antiprompt.c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
if (params.verbose_prompt) {
|
2024-10-10 22:57:42 +02:00
|
|
|
auto tmp = common_tokenize(ctx, antiprompt, false, true);
|
2023-10-17 17:11:01 +02:00
|
|
|
for (int i = 0; i < (int) tmp.size(); i++) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%6d -> '%s'\n", tmp[i], common_token_to_piece(ctx, tmp[i]).c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
}
|
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
|
|
|
}
|
2023-03-25 13:03:19 +01:00
|
|
|
|
2023-07-25 14:19:11 +02:00
|
|
|
if (params.input_prefix_bos) {
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("Input prefix with BOS\n");
|
2023-07-25 14:19:11 +02:00
|
|
|
}
|
|
|
|
|
2023-03-25 13:03:19 +01:00
|
|
|
if (!params.input_prefix.empty()) {
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("Input prefix: '%s'\n", params.input_prefix.c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
if (params.verbose_prompt) {
|
2024-10-10 22:57:42 +02:00
|
|
|
auto tmp = common_tokenize(ctx, params.input_prefix, true, true);
|
2023-10-17 17:11:01 +02:00
|
|
|
for (int i = 0; i < (int) tmp.size(); i++) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%6d -> '%s'\n", tmp[i], common_token_to_piece(ctx, tmp[i]).c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
}
|
|
|
|
}
|
2023-03-25 13:03:19 +01:00
|
|
|
}
|
2023-05-04 17:41:12 +02:00
|
|
|
|
|
|
|
if (!params.input_suffix.empty()) {
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("Input suffix: '%s'\n", params.input_suffix.c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
if (params.verbose_prompt) {
|
2024-10-10 22:57:42 +02:00
|
|
|
auto tmp = common_tokenize(ctx, params.input_suffix, false, true);
|
2023-10-17 17:11:01 +02:00
|
|
|
for (int i = 0; i < (int) tmp.size(); i++) {
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("%6d -> '%s'\n", tmp[i], common_token_to_piece(ctx, tmp[i]).c_str());
|
2023-10-17 17:11:01 +02:00
|
|
|
}
|
|
|
|
}
|
2023-05-04 17:41:12 +02:00
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
2024-09-07 14:16:19 +02:00
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
smpl = common_sampler_init(model, sparams);
|
2024-09-07 14:16:19 +02:00
|
|
|
if (!smpl) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s: failed to initialize sampling subsystem\n", __func__);
|
|
|
|
return 1;
|
2024-09-07 14:16:19 +02:00
|
|
|
}
|
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("sampler seed: %u\n", common_sampler_get_seed(smpl));
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("sampler params: \n%s\n", sparams.print().c_str());
|
2024-10-10 22:57:42 +02:00
|
|
|
LOG_INF("sampler chain: %s\n", common_sampler_print(smpl).c_str());
|
2024-09-10 18:04:25 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("generate: n_ctx = %d, n_batch = %d, n_predict = %d, n_keep = %d\n", n_ctx, params.n_batch, params.n_predict, params.n_keep);
|
2024-01-08 10:18:32 +01:00
|
|
|
|
|
|
|
// group-attention state
|
|
|
|
// number of grouped KV tokens so far (used only if params.grp_attn_n > 1)
|
|
|
|
int ga_i = 0;
|
|
|
|
|
|
|
|
const int ga_n = params.grp_attn_n;
|
|
|
|
const int ga_w = params.grp_attn_w;
|
|
|
|
|
|
|
|
if (ga_n != 1) {
|
|
|
|
GGML_ASSERT(ga_n > 0 && "grp_attn_n must be positive"); // NOLINT
|
|
|
|
GGML_ASSERT(ga_w % ga_n == 0 && "grp_attn_w must be a multiple of grp_attn_n"); // NOLINT
|
|
|
|
//GGML_ASSERT(n_ctx_train % ga_w == 0 && "n_ctx_train must be a multiple of grp_attn_w"); // NOLINT
|
|
|
|
//GGML_ASSERT(n_ctx >= n_ctx_train * ga_n && "n_ctx must be at least n_ctx_train * grp_attn_n"); // NOLINT
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_INF("self-extend: n_ctx_train = %d, grp_attn_n = %d, grp_attn_w = %d\n", n_ctx_train, ga_n, ga_w);
|
2024-01-08 10:18:32 +01:00
|
|
|
}
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("\n");
|
2023-03-10 19:40:58 +01:00
|
|
|
|
2023-03-12 22:13:28 +01:00
|
|
|
if (params.interactive) {
|
2024-05-23 08:43:24 +02:00
|
|
|
const char * control_message;
|
2023-08-04 17:20:12 +02:00
|
|
|
if (params.multiline_input) {
|
2024-05-23 08:43:24 +02:00
|
|
|
control_message = " - To return control to the AI, end your input with '\\'.\n"
|
2023-05-09 04:45:48 +02:00
|
|
|
" - To return control without starting a new line, end your input with '/'.\n";
|
|
|
|
} else {
|
2024-05-23 08:43:24 +02:00
|
|
|
control_message = " - Press Return to return control to the AI.\n"
|
2023-05-09 04:45:48 +02:00
|
|
|
" - To return control without starting a new line, end your input with '/'.\n"
|
|
|
|
" - If you want to submit another line, end your input with '\\'.\n";
|
|
|
|
}
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF("== Running in interactive mode. ==\n");
|
2023-03-15 20:56:24 +01:00
|
|
|
#if defined (__unix__) || (defined (__APPLE__) && defined (__MACH__)) || defined (_WIN32)
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF( " - Press Ctrl+C to interject at any time.\n");
|
2023-03-13 04:08:01 +01:00
|
|
|
#endif
|
2024-09-24 09:15:35 +02:00
|
|
|
LOG_INF( "%s\n", control_message);
|
2023-05-09 04:45:48 +02:00
|
|
|
|
2023-04-24 17:45:32 +02:00
|
|
|
is_interacting = params.interactive_first;
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
|
|
|
|
2023-05-10 17:37:14 +02:00
|
|
|
bool is_antiprompt = false;
|
|
|
|
bool input_echo = true;
|
2024-01-13 17:09:08 +01:00
|
|
|
bool display = true;
|
2023-05-10 17:37:14 +02:00
|
|
|
bool need_to_save_session = !path_session.empty() && n_matching_session_tokens < embd_inp.size();
|
2023-04-28 17:59:37 +02:00
|
|
|
|
2023-05-02 19:53:52 +02:00
|
|
|
int n_past = 0;
|
|
|
|
int n_remain = params.n_predict;
|
|
|
|
int n_consumed = 0;
|
2023-04-28 17:59:37 +02:00
|
|
|
int n_session_consumed = 0;
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2023-08-28 17:59:39 +02:00
|
|
|
std::vector<int> input_tokens; g_input_tokens = &input_tokens;
|
|
|
|
std::vector<int> output_tokens; g_output_tokens = &output_tokens;
|
|
|
|
std::ostringstream output_ss; g_output_ss = &output_ss;
|
2024-06-25 13:56:49 +02:00
|
|
|
std::ostringstream assistant_ss; // for storing current assistant message, used in conversation mode
|
2023-08-28 17:59:39 +02:00
|
|
|
|
2023-03-21 18:11:01 +01:00
|
|
|
// the first thing we will do is to output the prompt, so set color accordingly
|
2023-08-04 17:20:12 +02:00
|
|
|
console::set_display(console::prompt);
|
2024-01-13 17:09:08 +01:00
|
|
|
display = params.display_prompt;
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2023-03-25 20:36:22 +01:00
|
|
|
std::vector<llama_token> embd;
|
|
|
|
|
2024-03-04 08:57:20 +01:00
|
|
|
// tokenized antiprompts
|
|
|
|
std::vector<std::vector<llama_token>> antiprompt_ids;
|
|
|
|
|
|
|
|
antiprompt_ids.reserve(params.antiprompt.size());
|
|
|
|
for (const std::string & antiprompt : params.antiprompt) {
|
2024-10-10 22:57:42 +02:00
|
|
|
antiprompt_ids.emplace_back(::common_tokenize(ctx, antiprompt, false, true));
|
2024-03-04 08:57:20 +01:00
|
|
|
}
|
|
|
|
|
2024-07-04 15:46:11 +02:00
|
|
|
if (llama_model_has_encoder(model)) {
|
|
|
|
int enc_input_size = embd_inp.size();
|
|
|
|
llama_token * enc_input_buf = embd_inp.data();
|
|
|
|
|
2024-10-18 23:18:01 +02:00
|
|
|
if (llama_encode(ctx, llama_batch_get_one(enc_input_buf, enc_input_size))) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s : failed to eval\n", __func__);
|
2024-07-04 15:46:11 +02:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
llama_token decoder_start_token_id = llama_model_decoder_start_token(model);
|
2025-01-06 09:52:15 +01:00
|
|
|
if (decoder_start_token_id == LLAMA_TOKEN_NULL) {
|
2025-01-12 10:32:42 +01:00
|
|
|
decoder_start_token_id = llama_vocab_bos(vocab);
|
2024-07-04 15:46:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
embd_inp.clear();
|
|
|
|
embd_inp.push_back(decoder_start_token_id);
|
|
|
|
}
|
|
|
|
|
2023-05-19 19:24:59 +02:00
|
|
|
while ((n_remain != 0 && !is_antiprompt) || params.interactive) {
|
2023-03-10 19:40:58 +01:00
|
|
|
// predict
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!embd.empty()) {
|
2024-01-11 17:14:52 +01:00
|
|
|
// Note: (n_ctx - 4) here is to match the logic for commandline prompt handling via
|
2023-06-11 16:19:17 +02:00
|
|
|
// --prompt or --file which uses the same value.
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
int max_embd_size = n_ctx - 4;
|
|
|
|
|
2023-06-11 16:19:17 +02:00
|
|
|
// Ensure the input doesn't exceed the context size by truncating embd if necessary.
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
if ((int) embd.size() > max_embd_size) {
|
|
|
|
const int skipped_tokens = (int) embd.size() - max_embd_size;
|
|
|
|
embd.resize(max_embd_size);
|
|
|
|
|
2023-08-04 17:20:12 +02:00
|
|
|
console::set_display(console::error);
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_WRN("<<input too long: skipped %d token%s>>", skipped_tokens, skipped_tokens != 1 ? "s" : "");
|
2023-08-04 17:20:12 +02:00
|
|
|
console::set_display(console::reset);
|
2023-06-11 16:19:17 +02:00
|
|
|
}
|
|
|
|
|
2024-01-08 10:18:32 +01:00
|
|
|
if (ga_n == 1) {
|
|
|
|
// infinite text generation via context shifting
|
|
|
|
// if we run out of context:
|
|
|
|
// - take the n_keep first tokens from the original prompt (via n_past)
|
|
|
|
// - take half of the last (n_ctx - n_keep) tokens and recompute the logits in batches
|
2024-09-16 08:20:01 +02:00
|
|
|
|
2024-09-07 14:16:19 +02:00
|
|
|
if (n_past + (int) embd.size() >= n_ctx) {
|
2024-09-16 08:20:01 +02:00
|
|
|
if (!params.ctx_shift){
|
|
|
|
LOG_DBG("\n\n%s: context full and context shift is disabled => stopping\n", __func__);
|
2024-01-08 10:18:32 +01:00
|
|
|
break;
|
2024-10-15 15:35:33 +02:00
|
|
|
}
|
2023-03-25 20:36:22 +01:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
if (params.n_predict == -2) {
|
|
|
|
LOG_DBG("\n\n%s: context full and n_predict == -%d => stopping\n", __func__, params.n_predict);
|
|
|
|
break;
|
|
|
|
}
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
const int n_left = n_past - params.n_keep;
|
|
|
|
const int n_discard = n_left/2;
|
2023-03-25 20:36:22 +01:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
LOG_DBG("context full, swapping: n_past = %d, n_left = %d, n_ctx = %d, n_keep = %d, n_discard = %d\n",
|
|
|
|
n_past, n_left, n_ctx, params.n_keep, n_discard);
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
llama_kv_cache_seq_rm (ctx, 0, params.n_keep , params.n_keep + n_discard);
|
|
|
|
llama_kv_cache_seq_add(ctx, 0, params.n_keep + n_discard, n_past, -n_discard);
|
2023-09-28 18:04:36 +02:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
n_past -= n_discard;
|
2024-01-08 10:18:32 +01:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
LOG_DBG("after swap: n_past = %d\n", n_past);
|
2024-01-08 10:18:32 +01:00
|
|
|
|
2024-10-15 15:35:33 +02:00
|
|
|
LOG_DBG("embd: %s\n", string_from(ctx, embd).c_str());
|
|
|
|
|
|
|
|
LOG_DBG("clear session path\n");
|
|
|
|
path_session.clear();
|
2023-09-28 18:04:36 +02:00
|
|
|
}
|
2024-01-08 10:18:32 +01:00
|
|
|
} else {
|
|
|
|
// context extension via Self-Extend
|
|
|
|
while (n_past >= ga_i + ga_w) {
|
|
|
|
const int ib = (ga_n*ga_i)/ga_w;
|
|
|
|
const int bd = (ga_w/ga_n)*(ga_n - 1);
|
|
|
|
const int dd = (ga_w/ga_n) - ib*bd - ga_w;
|
2023-09-28 18:04:36 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("\n");
|
|
|
|
LOG_DBG("shift: [%6d, %6d] + %6d -> [%6d, %6d]\n", ga_i, n_past, ib*bd, ga_i + ib*bd, n_past + ib*bd);
|
|
|
|
LOG_DBG("div: [%6d, %6d] / %6d -> [%6d, %6d]\n", ga_i + ib*bd, ga_i + ib*bd + ga_w, ga_n, (ga_i + ib*bd)/ga_n, (ga_i + ib*bd + ga_w)/ga_n);
|
|
|
|
LOG_DBG("shift: [%6d, %6d] + %6d -> [%6d, %6d]\n", ga_i + ib*bd + ga_w, n_past + ib*bd, dd, ga_i + ib*bd + ga_w + dd, n_past + ib*bd + dd);
|
2023-03-25 20:36:22 +01:00
|
|
|
|
2024-02-25 21:12:24 +01:00
|
|
|
llama_kv_cache_seq_add(ctx, 0, ga_i, n_past, ib*bd);
|
|
|
|
llama_kv_cache_seq_div(ctx, 0, ga_i + ib*bd, ga_i + ib*bd + ga_w, ga_n);
|
|
|
|
llama_kv_cache_seq_add(ctx, 0, ga_i + ib*bd + ga_w, n_past + ib*bd, dd);
|
2023-04-28 17:59:37 +02:00
|
|
|
|
2024-01-08 10:18:32 +01:00
|
|
|
n_past -= bd;
|
|
|
|
|
|
|
|
ga_i += ga_w/ga_n;
|
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("\nn_past_old = %d, n_past = %d, ga_i = %d\n\n", n_past + bd, n_past, ga_i);
|
2024-01-08 10:18:32 +01:00
|
|
|
}
|
2023-03-25 20:36:22 +01:00
|
|
|
}
|
|
|
|
|
2023-04-28 17:59:37 +02:00
|
|
|
// try to reuse a matching prefix from the loaded session instead of re-eval (via n_past)
|
|
|
|
if (n_session_consumed < (int) session_tokens.size()) {
|
|
|
|
size_t i = 0;
|
|
|
|
for ( ; i < embd.size(); i++) {
|
|
|
|
if (embd[i] != session_tokens[n_session_consumed]) {
|
|
|
|
session_tokens.resize(n_session_consumed);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
n_past++;
|
|
|
|
n_session_consumed++;
|
|
|
|
|
|
|
|
if (n_session_consumed >= (int) session_tokens.size()) {
|
2023-05-01 13:54:59 +02:00
|
|
|
++i;
|
2023-04-28 17:59:37 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (i > 0) {
|
|
|
|
embd.erase(embd.begin(), embd.begin() + i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-21 20:18:09 +02:00
|
|
|
for (int i = 0; i < (int) embd.size(); i += params.n_batch) {
|
|
|
|
int n_eval = (int) embd.size() - i;
|
|
|
|
if (n_eval > params.n_batch) {
|
|
|
|
n_eval = params.n_batch;
|
|
|
|
}
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("eval: %s\n", string_from(ctx, embd).c_str());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-10-18 23:18:01 +02:00
|
|
|
if (llama_decode(ctx, llama_batch_get_one(&embd[i], n_eval))) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_ERR("%s : failed to eval\n", __func__);
|
2023-04-21 20:18:09 +02:00
|
|
|
return 1;
|
|
|
|
}
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-04-21 20:18:09 +02:00
|
|
|
n_past += n_eval;
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("n_past = %d\n", n_past);
|
2024-01-11 17:14:52 +01:00
|
|
|
// Display total tokens alongside total time
|
2024-01-11 21:46:26 +01:00
|
|
|
if (params.n_print > 0 && n_past % params.n_print == 0) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("\n\033[31mTokens consumed so far = %d / %d \033[0m\n", n_past, n_ctx);
|
2024-01-11 17:14:52 +01:00
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
2023-04-28 17:59:37 +02:00
|
|
|
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!embd.empty() && !path_session.empty()) {
|
2023-04-28 17:59:37 +02:00
|
|
|
session_tokens.insert(session_tokens.end(), embd.begin(), embd.end());
|
|
|
|
n_session_consumed = session_tokens.size();
|
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
embd.clear();
|
|
|
|
|
2023-03-25 20:36:22 +01:00
|
|
|
if ((int) embd_inp.size() <= n_consumed && !is_interacting) {
|
2023-04-28 17:59:37 +02:00
|
|
|
// optionally save the session on first sample (for faster prompt loading next time)
|
2023-06-07 04:10:17 +02:00
|
|
|
if (!path_session.empty() && need_to_save_session && !params.prompt_cache_ro) {
|
2023-04-28 17:59:37 +02:00
|
|
|
need_to_save_session = false;
|
2024-04-08 14:43:30 +02:00
|
|
|
llama_state_save_file(ctx, path_session.c_str(), session_tokens.data(), session_tokens.size());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("saved session to %s\n", path_session.c_str());
|
2023-04-28 17:59:37 +02:00
|
|
|
}
|
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
const llama_token id = common_sampler_sample(smpl, ctx, -1);
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
common_sampler_accept(smpl, id, /* accept_grammar= */ true);
|
2023-03-12 10:27:42 +01:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
// LOG_DBG("last: %s\n", string_from(ctx, smpl->prev.to_vector()).c_str());
|
2023-03-10 19:40:58 +01:00
|
|
|
|
|
|
|
embd.push_back(id);
|
2023-03-12 22:13:28 +01:00
|
|
|
|
|
|
|
// echo this to console
|
2023-05-02 18:13:26 +02:00
|
|
|
input_echo = true;
|
2023-03-12 22:13:28 +01:00
|
|
|
|
|
|
|
// decrement remaining sampling budget
|
2023-03-25 20:36:22 +01:00
|
|
|
--n_remain;
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("n_remain: %d\n", n_remain);
|
2023-03-10 19:40:58 +01:00
|
|
|
} else {
|
2023-03-12 23:07:34 +01:00
|
|
|
// some user input remains from prompt or interaction, forward it to processing
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("embd_inp.size(): %d, n_consumed: %d\n", (int) embd_inp.size(), n_consumed);
|
2023-03-25 20:36:22 +01:00
|
|
|
while ((int) embd_inp.size() > n_consumed) {
|
|
|
|
embd.push_back(embd_inp[n_consumed]);
|
2023-10-18 15:21:57 +02:00
|
|
|
|
2023-10-20 20:07:23 +02:00
|
|
|
// push the prompt in the sampling context in order to apply repetition penalties later
|
|
|
|
// for the prompt, we don't apply grammar rules
|
2024-10-10 22:57:42 +02:00
|
|
|
common_sampler_accept(smpl, embd_inp[n_consumed], /* accept_grammar= */ false);
|
2023-10-18 15:21:57 +02:00
|
|
|
|
2023-03-25 20:36:22 +01:00
|
|
|
++n_consumed;
|
2023-03-19 18:46:32 +01:00
|
|
|
if ((int) embd.size() >= params.n_batch) {
|
2023-03-10 19:40:58 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// display text
|
2024-01-13 17:09:08 +01:00
|
|
|
if (input_echo && display) {
|
2023-03-12 22:13:28 +01:00
|
|
|
for (auto id : embd) {
|
2024-10-10 22:57:42 +02:00
|
|
|
const std::string token_str = common_token_to_piece(ctx, id, params.special);
|
2024-05-25 11:04:03 +02:00
|
|
|
|
|
|
|
// Console/Stream Output
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("%s", token_str.c_str());
|
2023-08-28 17:59:39 +02:00
|
|
|
|
2024-05-25 11:04:03 +02:00
|
|
|
// Record Displayed Tokens To Log
|
|
|
|
// Note: Generated tokens are created one by one hence this check
|
2023-08-28 17:59:39 +02:00
|
|
|
if (embd.size() > 1) {
|
2024-05-25 11:04:03 +02:00
|
|
|
// Incoming Requested Tokens
|
2023-08-28 17:59:39 +02:00
|
|
|
input_tokens.push_back(id);
|
|
|
|
} else {
|
2024-05-25 11:04:03 +02:00
|
|
|
// Outgoing Generated Tokens
|
2023-08-28 17:59:39 +02:00
|
|
|
output_tokens.push_back(id);
|
|
|
|
output_ss << token_str;
|
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
|
|
|
}
|
2024-05-25 11:04:03 +02:00
|
|
|
|
2023-10-03 20:16:15 +02:00
|
|
|
// reset color to default if there is no pending user input
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
if (input_echo && (int) embd_inp.size() == n_consumed) {
|
2023-08-04 17:20:12 +02:00
|
|
|
console::set_display(console::reset);
|
2024-01-13 17:09:08 +01:00
|
|
|
display = true;
|
2023-03-19 20:44:30 +01:00
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2023-05-19 19:24:59 +02:00
|
|
|
// if not currently processing queued inputs;
|
|
|
|
if ((int) embd_inp.size() <= n_consumed) {
|
2023-10-20 20:07:23 +02:00
|
|
|
// check for reverse prompt in the last n_prev tokens
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!params.antiprompt.empty()) {
|
2023-10-20 20:07:23 +02:00
|
|
|
const int n_prev = 32;
|
2024-10-10 22:57:42 +02:00
|
|
|
const std::string last_output = common_sampler_prev_str(smpl, ctx, n_prev);
|
2023-03-21 17:04:43 +01:00
|
|
|
|
2023-04-14 21:58:43 +02:00
|
|
|
is_antiprompt = false;
|
2023-03-28 16:09:55 +02:00
|
|
|
// Check if each of the reverse prompts appears at the end of the output.
|
2023-05-19 19:24:59 +02:00
|
|
|
// If we're not running interactively, the reverse prompt might be tokenized with some following characters
|
|
|
|
// so we'll compensate for that by widening the search window a bit.
|
2023-04-14 21:58:43 +02:00
|
|
|
for (std::string & antiprompt : params.antiprompt) {
|
2023-05-19 19:24:59 +02:00
|
|
|
size_t extra_padding = params.interactive ? 0 : 2;
|
|
|
|
size_t search_start_pos = last_output.length() > static_cast<size_t>(antiprompt.length() + extra_padding)
|
|
|
|
? last_output.length() - static_cast<size_t>(antiprompt.length() + extra_padding)
|
|
|
|
: 0;
|
|
|
|
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
if (last_output.find(antiprompt, search_start_pos) != std::string::npos) {
|
2023-05-19 19:24:59 +02:00
|
|
|
if (params.interactive) {
|
|
|
|
is_interacting = true;
|
|
|
|
}
|
2023-04-14 21:58:43 +02:00
|
|
|
is_antiprompt = true;
|
2023-03-28 16:09:55 +02:00
|
|
|
break;
|
|
|
|
}
|
2023-03-19 20:33:06 +01:00
|
|
|
}
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-03-04 08:57:20 +01:00
|
|
|
// check for reverse prompt using special tokens
|
2024-10-10 22:57:42 +02:00
|
|
|
llama_token last_token = common_sampler_last(smpl);
|
2024-03-04 08:57:20 +01:00
|
|
|
for (std::vector<llama_token> ids : antiprompt_ids) {
|
|
|
|
if (ids.size() == 1 && last_token == ids[0]) {
|
|
|
|
if (params.interactive) {
|
|
|
|
is_interacting = true;
|
|
|
|
}
|
|
|
|
is_antiprompt = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
if (is_antiprompt) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("found antiprompt: %s\n", last_output.c_str());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
2023-03-24 22:17:58 +01:00
|
|
|
|
2024-04-21 13:50:41 +02:00
|
|
|
// deal with end of generation tokens in interactive mode
|
2025-01-12 10:32:42 +01:00
|
|
|
if (llama_vocab_is_eog(vocab, common_sampler_last(smpl))) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("found an EOG token\n");
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-07-25 14:19:11 +02:00
|
|
|
if (params.interactive) {
|
2023-09-07 19:22:29 +02:00
|
|
|
if (!params.antiprompt.empty()) {
|
2023-07-25 14:19:11 +02:00
|
|
|
// tokenize and inject first reverse prompt
|
2024-10-10 22:57:42 +02:00
|
|
|
const auto first_antiprompt = common_tokenize(ctx, params.antiprompt.front(), false, true);
|
2023-07-25 14:19:11 +02:00
|
|
|
embd_inp.insert(embd_inp.end(), first_antiprompt.begin(), first_antiprompt.end());
|
|
|
|
is_antiprompt = true;
|
|
|
|
}
|
|
|
|
|
2024-06-30 20:27:13 +02:00
|
|
|
if (params.enable_chat_template) {
|
|
|
|
chat_add_and_format(model, chat_msgs, "assistant", assistant_ss.str());
|
|
|
|
}
|
2023-07-25 14:19:11 +02:00
|
|
|
is_interacting = true;
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("\n");
|
2023-07-25 14:19:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-25 13:56:49 +02:00
|
|
|
// if current token is not EOG, we add it to current assistant message
|
|
|
|
if (params.conversation) {
|
2024-10-10 22:57:42 +02:00
|
|
|
const auto id = common_sampler_last(smpl);
|
|
|
|
assistant_ss << common_token_to_piece(ctx, id, false);
|
2024-06-25 13:56:49 +02:00
|
|
|
}
|
|
|
|
|
2023-04-14 21:58:43 +02:00
|
|
|
if (n_past > 0 && is_interacting) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("waiting for user input\n");
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-06-04 20:23:39 +02:00
|
|
|
if (params.conversation) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("\n> ");
|
2023-03-19 17:37:02 +01:00
|
|
|
}
|
|
|
|
|
2023-07-25 14:19:11 +02:00
|
|
|
if (params.input_prefix_bos) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("adding input prefix BOS token\n");
|
2025-01-12 10:32:42 +01:00
|
|
|
embd_inp.push_back(llama_vocab_bos(vocab));
|
2023-07-25 14:19:11 +02:00
|
|
|
}
|
|
|
|
|
2023-04-14 21:58:43 +02:00
|
|
|
std::string buffer;
|
2024-05-08 16:32:32 +02:00
|
|
|
if (!params.input_prefix.empty() && !params.conversation) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("appending input prefix: '%s'\n", params.input_prefix.c_str());
|
|
|
|
LOG("%s", params.input_prefix.c_str());
|
2023-03-25 13:03:19 +01:00
|
|
|
}
|
|
|
|
|
2023-10-03 20:16:15 +02:00
|
|
|
// color user input only
|
|
|
|
console::set_display(console::user_input);
|
2024-01-13 17:09:08 +01:00
|
|
|
display = params.display_prompt;
|
2023-10-03 20:16:15 +02:00
|
|
|
|
2023-04-14 21:58:43 +02:00
|
|
|
std::string line;
|
|
|
|
bool another_line = true;
|
|
|
|
do {
|
2023-08-04 17:20:12 +02:00
|
|
|
another_line = console::readline(line, params.multiline_input);
|
2023-05-09 04:45:48 +02:00
|
|
|
buffer += line;
|
2023-04-14 21:58:43 +02:00
|
|
|
} while (another_line);
|
2023-03-21 18:11:01 +01:00
|
|
|
|
|
|
|
// done taking input, reset color
|
2023-08-04 17:20:12 +02:00
|
|
|
console::set_display(console::reset);
|
2024-01-13 17:09:08 +01:00
|
|
|
display = true;
|
2023-03-19 17:37:02 +01:00
|
|
|
|
2023-03-28 16:09:55 +02:00
|
|
|
// Add tokens to embd only if the input buffer is non-empty
|
|
|
|
// Entering a empty line lets the user pass control back
|
|
|
|
if (buffer.length() > 1) {
|
2023-05-04 17:41:12 +02:00
|
|
|
// append input suffix if any
|
2024-05-08 16:32:32 +02:00
|
|
|
if (!params.input_suffix.empty() && !params.conversation) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("appending input suffix: '%s'\n", params.input_suffix.c_str());
|
|
|
|
LOG("%s", params.input_suffix.c_str());
|
2023-05-04 17:41:12 +02:00
|
|
|
}
|
2023-03-13 00:35:51 +01:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("buffer: '%s'\n", buffer.c_str());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2023-08-28 17:59:39 +02:00
|
|
|
const size_t original_size = embd_inp.size();
|
|
|
|
|
2023-10-22 20:09:51 +02:00
|
|
|
if (params.escape) {
|
2024-05-22 19:04:20 +02:00
|
|
|
string_process_escapes(buffer);
|
2023-10-22 20:09:51 +02:00
|
|
|
}
|
2023-03-12 22:13:28 +01:00
|
|
|
|
2024-06-30 20:27:13 +02:00
|
|
|
bool format_chat = params.conversation && params.enable_chat_template;
|
|
|
|
std::string user_inp = format_chat
|
2024-06-25 13:56:49 +02:00
|
|
|
? chat_add_and_format(model, chat_msgs, "user", std::move(buffer))
|
|
|
|
: std::move(buffer);
|
|
|
|
// TODO: one inconvenient of current chat template implementation is that we can't distinguish between user input and special tokens (prefix/postfix)
|
2024-10-10 22:57:42 +02:00
|
|
|
const auto line_pfx = common_tokenize(ctx, params.input_prefix, false, true);
|
|
|
|
const auto line_inp = common_tokenize(ctx, user_inp, false, format_chat);
|
|
|
|
const auto line_sfx = common_tokenize(ctx, params.input_suffix, false, true);
|
2024-03-11 16:49:47 +01:00
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("input tokens: %s\n", string_from(ctx, line_inp).c_str());
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
|
2024-07-04 20:55:03 +02:00
|
|
|
// if user stop generation mid-way, we must add EOT to finish model's last response
|
|
|
|
if (need_insert_eot && format_chat) {
|
2025-01-12 10:32:42 +01:00
|
|
|
llama_token eot = llama_vocab_eot(vocab);
|
|
|
|
embd_inp.push_back(eot == LLAMA_TOKEN_NULL ? llama_vocab_eos(vocab) : eot);
|
2024-07-04 20:55:03 +02:00
|
|
|
need_insert_eot = false;
|
|
|
|
}
|
|
|
|
|
2023-10-17 17:11:01 +02:00
|
|
|
embd_inp.insert(embd_inp.end(), line_pfx.begin(), line_pfx.end());
|
2023-03-28 16:09:55 +02:00
|
|
|
embd_inp.insert(embd_inp.end(), line_inp.begin(), line_inp.end());
|
2023-10-17 17:11:01 +02:00
|
|
|
embd_inp.insert(embd_inp.end(), line_sfx.begin(), line_sfx.end());
|
2023-03-28 16:09:55 +02:00
|
|
|
|
2023-08-28 17:59:39 +02:00
|
|
|
for (size_t i = original_size; i < embd_inp.size(); ++i) {
|
|
|
|
const llama_token token = embd_inp[i];
|
|
|
|
output_tokens.push_back(token);
|
2024-10-10 22:57:42 +02:00
|
|
|
output_ss << common_token_to_piece(ctx, token);
|
2023-08-28 17:59:39 +02:00
|
|
|
}
|
|
|
|
|
2024-06-25 13:56:49 +02:00
|
|
|
// reset assistant message
|
|
|
|
assistant_ss.str("");
|
|
|
|
|
2023-03-28 16:09:55 +02:00
|
|
|
n_remain -= line_inp.size();
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("n_remain: %d\n", n_remain);
|
main : log file (#2748)
* initial, base LOG macro
* add *.log to .gitignore
* added basic log file handler
* reverted log auto endline to better mimic printf
* remove atomics and add dynamic log target
* log_enable/disable, LOG_TEE, basic usage doc
* update .gitignore
* mv include to common, params, help msg
* log tostring helpers, token vectors pretty prints
* main: replaced fprintf/LOG_TEE, some trace logging
* LOG_DISABLE_LOGS compile flag, wrapped f in macros
* fix LOG_TEELN and configchecker
* stub LOG_DUMP_CMDLINE for WIN32 for now
* fix msvc
* cleanup main.cpp:273
* fix stray whitespace after master sync
* log : fix compile warnings
- do not use C++20 stuff
- use PRIu64 to print uint64_t
- avoid string copies by using const ref
- fix ", ##__VA_ARGS__" warnings
- compare strings with == and !=
* log : do not append to existing log + disable file line func by default
* log : try to fix Windows build
* main : wip logs
* main : add trace log
* review: macro f lowercase, str append to sstream
* review: simplify ifs and str comparisons
* fix MSVC, formatting, FMT/VAL placeholders
* review: if/else cleanup
* review: if/else cleanup (2)
* replace _ prefix with _impl suffix
---------
Co-authored-by: Georgi Gerganov <ggerganov@gmail.com>
2023-08-30 08:29:32 +02:00
|
|
|
} else {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG_DBG("empty line, passing control back\n");
|
2023-03-28 16:09:55 +02:00
|
|
|
}
|
2023-03-19 20:44:30 +01:00
|
|
|
|
2023-05-02 18:13:26 +02:00
|
|
|
input_echo = false; // do not echo this again
|
2023-03-12 22:13:28 +01:00
|
|
|
}
|
2023-03-24 22:17:58 +01:00
|
|
|
|
|
|
|
if (n_past > 0) {
|
2023-07-24 05:58:10 +02:00
|
|
|
if (is_interacting) {
|
2024-10-10 22:57:42 +02:00
|
|
|
common_sampler_reset(smpl);
|
2023-07-24 05:58:10 +02:00
|
|
|
}
|
2023-03-24 22:17:58 +01:00
|
|
|
is_interacting = false;
|
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
|
|
|
|
2024-04-21 13:50:41 +02:00
|
|
|
// end of generation
|
2025-01-12 10:32:42 +01:00
|
|
|
if (!embd.empty() && llama_vocab_is_eog(vocab, embd.back()) && !(params.interactive)) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG(" [end of text]\n");
|
2023-07-25 14:19:11 +02:00
|
|
|
break;
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
2023-03-19 19:31:17 +01:00
|
|
|
|
|
|
|
// In interactive mode, respect the maximum number of tokens and drop back to user input when reached.
|
2023-08-24 18:11:13 +02:00
|
|
|
// We skip this logic when n_predict == -1 (infinite) or -2 (stop at context size).
|
|
|
|
if (params.interactive && n_remain <= 0 && params.n_predict >= 0) {
|
2023-03-25 20:36:22 +01:00
|
|
|
n_remain = params.n_predict;
|
2023-03-19 19:31:17 +01:00
|
|
|
is_interacting = true;
|
|
|
|
}
|
2023-03-10 19:40:58 +01:00
|
|
|
}
|
|
|
|
|
2023-06-07 04:10:17 +02:00
|
|
|
if (!path_session.empty() && params.prompt_cache_all && !params.prompt_cache_ro) {
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("\n%s: saving final output to session file '%s'\n", __func__, path_session.c_str());
|
2024-04-08 14:43:30 +02:00
|
|
|
llama_state_save_file(ctx, path_session.c_str(), session_tokens.data(), session_tokens.size());
|
2023-05-10 17:37:14 +02:00
|
|
|
}
|
|
|
|
|
2024-09-15 19:46:12 +02:00
|
|
|
LOG("\n\n");
|
2024-10-10 22:57:42 +02:00
|
|
|
common_perf_print(ctx, smpl);
|
2023-08-28 17:59:39 +02:00
|
|
|
|
2024-10-10 22:57:42 +02:00
|
|
|
common_sampler_free(smpl);
|
2024-09-07 14:16:19 +02:00
|
|
|
|
2023-07-10 17:49:56 +02:00
|
|
|
llama_backend_free();
|
|
|
|
|
2024-11-25 15:13:39 +01:00
|
|
|
ggml_threadpool_free_fn(threadpool);
|
|
|
|
ggml_threadpool_free_fn(threadpool_batch);
|
Threadpool: take 2 (#8672)
* Introduce ggml_compute_threadpool
- OpenMP functional: check
- Vanilla ggml functional: Check
- ggml w/threadpool functional: Check
- OpenMP no regression: No glaring problems
- Vanilla ggml no regression: No glaring problems
- ggml w/threadpool no regression: No glaring problems
* Minor fixes
* fixed use after release bug
* fixed a harmless race condition
* Fix Android bulid issue
* fix more race conditions
* fix deadlock for cases where cgraph.n_nodes == 1
and fix --poll case
* threadpool: use cpu_get_num_math to set the default number of threadpool threads
This way we avoid using E-Cores and Hyperthreaded siblings.
* bench: create fresh threadpool for each test
For benchmarking it's better to start a fresh pool for each test with the exact number of threads
needed for that test. Having larger pools is suboptimal (causes more load, etc).
* atomics: always use stdatomics with clang and use relaxed memory order when polling in ggml_barrier
This also removes sched_yield() calls from ggml_barrier() to match OpenMP behavior.
* threadpool: make polling the default to match openmp behavior
All command line args now allow for setting poll to 0 (false).
* threadpool: do not wakeup threads in already paused threadpool
* fix potential race condition in check_for_work
* threadpool: do not create two threadpools if their params are identical
* threadpool: reduce pause/resume/wakeup overhead in common cases
We now start threadpool in paused state only if we have two.
The resume is now implicit (ie new work) which allows for reduced locking and context-switch overhead.
* threadpool: add support for hybrid polling
poll params (--poll, ...) now specify "polling level", i.e. how aggresively we poll before waiting on cond.var.
poll=0 means no polling, 1 means poll for 128K rounds then wait, 2 for 256K rounds, ...
The default value of 50 (ie 50x128K rounds) seems like a decent default across modern platforms.
We can tune this further as things evolve.
* threadpool: reduce the number of barrier required
New work is now indicated with an atomic counter that is incremented for
each new graph that needs to be computed.
This removes the need for extra barrier for clearing the "new_work" and
removes the special case for trivial graphs.
* threadpool: remove special-casing for disposable threadpools
With the efficient hybrid polling there is no need to make disposable pools any different.
This simplifies the overall logic and reduces branching.
Include n_threads in debug print for disposable threadpool.
Declare pause and stop flags as atomic_bool
This doesn't actually generate any memory barriers and simply informs
the thread sanitizer that these flags can be written & read by different
threads without locking.
* threadpool: do not clear barrier counters between graphs computes (fixes race with small graphs)
This fixes the race condition with very small graphs where the main thread happens to
start a new graph while the workers are just about to exit from barriers.
* threadpool: use relaxed order for chunk sync
Full memory barrier is an overkill for this since each thread works on different chunk
* threadpool: remove abort_callback from threadpool state
* threadpool: better naming for thread/cpumask releated functions
* threadpool: consistent use of int type for n_threads params
* threadpool: add support for ggml_threadpool_params_default/init
Also removes the need for explicit mask_specified param.
all-zero cpumask means use default (usually inherited) cpu affinity mask.
* threadpool: move typedef into ggml.h
* threadpool: fix apply_priority() function name
* threadpool: fix swift wrapper errors due to n_threads int type cleanup
* threadpool: enable --cpu-mask and other threadpool related options only if threadpool is enabled
* threadpool: replace checks for compute_thread ret code with proper status check
* threadpool: simplify threadpool init logic and fix main thread affinity application
Most of the init code is now exactly the same between threadpool and openmp.
* threadpool: update threadpool resume/pause function names
* threadpool: enable openmp by default for now
* threadpool: don't forget to free workers state when omp is enabled
* threadpool: avoid updating process priority on the platforms that do not require it
On Windows we need to change overall process priority class in order to set thread priorities,
but on Linux, Mac, etc we do not need to touch the overall process settings.
* threadpool: update calling thread prio and affinity only at start/resume
This avoids extra syscalls for each graph_compute()
* llama-bench: turn threadpool params into vectors, add output headers, etc
* llama-bench: add support for cool off between tests --delay
This helps for long running tests on platforms that are thermally limited (phones, laptops, etc).
--delay (disabled by default) introduces the sleep for N seconds before starting each test.
* threadpool: move process priority setting into the apps (bench and cli)
This avoids changing the overall process priority on Windows for the apps
that use ggml/llama.cpp directy.
* threadpool: move all pause/resume logic into ggml
* threadpool: futher api cleanup and prep for future refactoring
All threadpool related functions and structs use ggml_threadpool prefix.
* threadpool: minor indent fixes
* threadpool: improve setprioty error message
* Update examples/llama-bench/llama-bench.cpp
Co-authored-by: slaren <slarengh@gmail.com>
* threadpool: fix indent in set_threadpool call
* use int32_t for n_thread type in public llama.cpp API
* threadpool: use _new and _free instead of _create and _release
* fix two more public APIs to use int32_t for n_threads
* build: set _GNU_SOURCE for Adroid
---------
Co-authored-by: Max Krasnyansky <quic_maxk@quicinc.com>
Co-authored-by: fmz <quic_fzaghlou@quic.com>
Co-authored-by: Max Krasnyansky <max.krasnyansky@gmail.com>
Co-authored-by: slaren <slarengh@gmail.com>
2024-08-30 01:20:53 +02:00
|
|
|
|
2023-03-10 19:40:58 +01:00
|
|
|
return 0;
|
|
|
|
}
|