mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-12 21:37:19 +01:00
llama : well-defined static initialization of complex objects (#927)
* Replaced static initialization of complex objects with a initialization on first use. This prevents an undefined behavior on program run, for example, crash in Release build, works in Debug build * replaced use of auto with exact type to avoid using -std=c++14 * Made the assessors functions for static maps be static const
This commit is contained in:
parent
eb17a026fd
commit
efd05648c8
38
llama.cpp
38
llama.cpp
@ -42,36 +42,52 @@ static const size_t MB = 1024*1024;
|
|||||||
// TODO: dynamically determine these sizes
|
// TODO: dynamically determine these sizes
|
||||||
// needs modifications in ggml
|
// needs modifications in ggml
|
||||||
|
|
||||||
static const std::map<e_model, size_t> MEM_REQ_SCRATCH0 = {
|
static const std::map<e_model, size_t> & MEM_REQ_SCRATCH0()
|
||||||
|
{
|
||||||
|
static std::map<e_model, size_t> _MEM_REQ_SCRATCH0 = {
|
||||||
{ MODEL_7B, 512ull * MB },
|
{ MODEL_7B, 512ull * MB },
|
||||||
{ MODEL_13B, 512ull * MB },
|
{ MODEL_13B, 512ull * MB },
|
||||||
{ MODEL_30B, 512ull * MB },
|
{ MODEL_30B, 512ull * MB },
|
||||||
{ MODEL_65B, 512ull * MB },
|
{ MODEL_65B, 512ull * MB },
|
||||||
};
|
};
|
||||||
|
return _MEM_REQ_SCRATCH0;
|
||||||
|
}
|
||||||
|
|
||||||
static const std::map<e_model, size_t> MEM_REQ_SCRATCH1 = {
|
static const std::map<e_model, size_t> & MEM_REQ_SCRATCH1()
|
||||||
|
{
|
||||||
|
static std::map<e_model, size_t> _MEM_REQ_SCRATCH1 = {
|
||||||
{ MODEL_7B, 512ull * MB },
|
{ MODEL_7B, 512ull * MB },
|
||||||
{ MODEL_13B, 512ull * MB },
|
{ MODEL_13B, 512ull * MB },
|
||||||
{ MODEL_30B, 512ull * MB },
|
{ MODEL_30B, 512ull * MB },
|
||||||
{ MODEL_65B, 512ull * MB },
|
{ MODEL_65B, 512ull * MB },
|
||||||
};
|
};
|
||||||
|
return _MEM_REQ_SCRATCH1;
|
||||||
|
};
|
||||||
|
|
||||||
// 2*n_embd*n_ctx*n_layer*sizeof(float16)
|
// 2*n_embd*n_ctx*n_layer*sizeof(float16)
|
||||||
static const std::map<e_model, size_t> MEM_REQ_KV_SELF = {
|
static const std::map<e_model, size_t> & MEM_REQ_KV_SELF()
|
||||||
|
{
|
||||||
|
static std::map<e_model, size_t> _MEM_REQ_KV_SELF = {
|
||||||
{ MODEL_7B, 1026ull * MB },
|
{ MODEL_7B, 1026ull * MB },
|
||||||
{ MODEL_13B, 1608ull * MB },
|
{ MODEL_13B, 1608ull * MB },
|
||||||
{ MODEL_30B, 3124ull * MB },
|
{ MODEL_30B, 3124ull * MB },
|
||||||
{ MODEL_65B, 5120ull * MB },
|
{ MODEL_65B, 5120ull * MB },
|
||||||
};
|
};
|
||||||
|
return _MEM_REQ_KV_SELF;
|
||||||
|
};
|
||||||
|
|
||||||
// this is mostly needed for temporary mul_mat buffers to dequantize the data
|
// this is mostly needed for temporary mul_mat buffers to dequantize the data
|
||||||
// not actually needed if BLAS is disabled
|
// not actually needed if BLAS is disabled
|
||||||
static const std::map<e_model, size_t> MEM_REQ_EVAL = {
|
static const std::map<e_model, size_t> & MEM_REQ_EVAL()
|
||||||
|
{
|
||||||
|
static std::map<e_model, size_t> _MEM_REQ_EVAL = {
|
||||||
{ MODEL_7B, 768ull * MB },
|
{ MODEL_7B, 768ull * MB },
|
||||||
{ MODEL_13B, 1024ull * MB },
|
{ MODEL_13B, 1024ull * MB },
|
||||||
{ MODEL_30B, 1280ull * MB },
|
{ MODEL_30B, 1280ull * MB },
|
||||||
{ MODEL_65B, 1536ull * MB },
|
{ MODEL_65B, 1536ull * MB },
|
||||||
};
|
};
|
||||||
|
return _MEM_REQ_EVAL;
|
||||||
|
};
|
||||||
|
|
||||||
// default hparams (LLaMA 7B)
|
// default hparams (LLaMA 7B)
|
||||||
struct llama_hparams {
|
struct llama_hparams {
|
||||||
@ -899,13 +915,13 @@ static void llama_model_load_internal(
|
|||||||
const size_t mem_required =
|
const size_t mem_required =
|
||||||
ctx_size +
|
ctx_size +
|
||||||
mmapped_size +
|
mmapped_size +
|
||||||
MEM_REQ_SCRATCH0.at(model.type) +
|
MEM_REQ_SCRATCH0().at(model.type) +
|
||||||
MEM_REQ_SCRATCH1.at(model.type) +
|
MEM_REQ_SCRATCH1().at(model.type) +
|
||||||
MEM_REQ_EVAL.at (model.type);
|
MEM_REQ_EVAL().at(model.type);
|
||||||
|
|
||||||
// this is the memory required by one llama_state
|
// this is the memory required by one llama_state
|
||||||
const size_t mem_required_state =
|
const size_t mem_required_state =
|
||||||
scale*MEM_REQ_KV_SELF.at(model.type);
|
scale*MEM_REQ_KV_SELF().at(model.type);
|
||||||
|
|
||||||
fprintf(stderr, "%s: mem required = %7.2f MB (+ %7.2f MB per state)\n", __func__,
|
fprintf(stderr, "%s: mem required = %7.2f MB (+ %7.2f MB per state)\n", __func__,
|
||||||
mem_required / 1024.0 / 1024.0, mem_required_state / 1024.0 / 1024.0);
|
mem_required / 1024.0 / 1024.0, mem_required_state / 1024.0 / 1024.0);
|
||||||
@ -1732,10 +1748,10 @@ struct llama_context * llama_init_from_file(
|
|||||||
ctx->embedding.resize(hparams.n_embd);
|
ctx->embedding.resize(hparams.n_embd);
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx->buf_compute.resize(MEM_REQ_EVAL.at(ctx->model.type));
|
ctx->buf_compute.resize(MEM_REQ_EVAL().at(ctx->model.type));
|
||||||
|
|
||||||
ctx->buf_scratch[0].resize(MEM_REQ_SCRATCH0.at(ctx->model.type));
|
ctx->buf_scratch[0].resize(MEM_REQ_SCRATCH0().at(ctx->model.type));
|
||||||
ctx->buf_scratch[1].resize(MEM_REQ_SCRATCH1.at(ctx->model.type));
|
ctx->buf_scratch[1].resize(MEM_REQ_SCRATCH1().at(ctx->model.type));
|
||||||
}
|
}
|
||||||
|
|
||||||
return ctx;
|
return ctx;
|
||||||
|
@ -5,7 +5,9 @@
|
|||||||
#include <map>
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
static const std::map<std::string, std::vector<llama_token>> k_tests = {
|
static const std::map<std::string, std::vector<llama_token>> & k_tests()
|
||||||
|
{
|
||||||
|
static std::map<std::string, std::vector<llama_token>> _k_tests = {
|
||||||
{ "Hello World", { 1, 10994, 2787, }, },
|
{ "Hello World", { 1, 10994, 2787, }, },
|
||||||
{ " Hello World", { 1, 15043, 2787, }, },
|
{ " Hello World", { 1, 15043, 2787, }, },
|
||||||
{ " Hello World!", { 1, 15043, 2787, 29991, }, },
|
{ " Hello World!", { 1, 15043, 2787, 29991, }, },
|
||||||
@ -13,6 +15,8 @@ static const std::map<std::string, std::vector<llama_token>> k_tests = {
|
|||||||
{ "w048 7tuijk dsdfhu", { 1, 29893, 29900, 29946, 29947, 29871, 29955, 9161, 13535, 18031, 2176, 6905, }, },
|
{ "w048 7tuijk dsdfhu", { 1, 29893, 29900, 29946, 29947, 29871, 29955, 9161, 13535, 18031, 2176, 6905, }, },
|
||||||
{ "нещо на Български", { 1, 821, 4851, 665, 1386, 29713, 1305, }, },
|
{ "нещо на Български", { 1, 821, 4851, 665, 1386, 29713, 1305, }, },
|
||||||
};
|
};
|
||||||
|
return _k_tests;
|
||||||
|
};
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
if (argc < 2) {
|
if (argc < 2) {
|
||||||
@ -47,7 +51,7 @@ int main(int argc, char **argv) {
|
|||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto & test_kv : k_tests) {
|
for (const auto & test_kv : k_tests()) {
|
||||||
std::vector<llama_token> res(test_kv.first.size());
|
std::vector<llama_token> res(test_kv.first.size());
|
||||||
const int n = llama_tokenize(ctx, test_kv.first.c_str(), res.data(), res.size(), true);
|
const int n = llama_tokenize(ctx, test_kv.first.c_str(), res.data(), res.size(), true);
|
||||||
res.resize(n);
|
res.resize(n);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user