|
@@ -1,268 +1,9 @@
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
-/**
|
|
|
|
- * llama.cpp - git d5c938cd7716b9a2ace49a43a469dfbffcff4d28
|
|
|
|
- *
|
|
|
|
- * MIT License
|
|
|
|
- *
|
|
|
|
- * Copyright (c) 2023-2024 The ggml authors
|
|
|
|
- *
|
|
|
|
- * Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
- * of this software and associated documentation files (the "Software"), to deal
|
|
|
|
- * in the Software without restriction, including without limitation the rights
|
|
|
|
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
- * copies of the Software, and to permit persons to whom the Software is
|
|
|
|
- * furnished to do so, subject to the following conditions:
|
|
|
|
- *
|
|
|
|
- * The above copyright notice and this permission notice shall be included in all
|
|
|
|
- * copies or substantial portions of the Software.
|
|
|
|
- *
|
|
|
|
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
- * SOFTWARE.
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
// TODO: this is a temporary wrapper to allow calling C++ code from CGo
|
|
// TODO: this is a temporary wrapper to allow calling C++ code from CGo
|
|
#include "sampling.h"
|
|
#include "sampling.h"
|
|
#include "sampling_ext.h"
|
|
#include "sampling_ext.h"
|
|
|
|
|
|
-struct llama_sampling_context* llama_sampling_cinit(struct llama_sampling_cparams *params) {
|
|
|
|
|
|
+struct llama_sampling_context *llama_sampling_cinit(struct llama_sampling_cparams *params)
|
|
|
|
+{
|
|
llama_sampling_params sparams;
|
|
llama_sampling_params sparams;
|
|
sparams.top_k = params->top_k;
|
|
sparams.top_k = params->top_k;
|
|
sparams.top_p = params->top_p;
|
|
sparams.top_p = params->top_p;
|
|
@@ -281,26 +22,30 @@ struct llama_sampling_context* llama_sampling_cinit(struct llama_sampling_cparam
|
|
return llama_sampling_init(sparams);
|
|
return llama_sampling_init(sparams);
|
|
}
|
|
}
|
|
|
|
|
|
-void llama_sampling_cfree(struct llama_sampling_context * ctx){
|
|
|
|
|
|
+void llama_sampling_cfree(struct llama_sampling_context *ctx)
|
|
|
|
+{
|
|
llama_sampling_free(ctx);
|
|
llama_sampling_free(ctx);
|
|
}
|
|
}
|
|
|
|
|
|
-void llama_sampling_creset(struct llama_sampling_context * ctx){
|
|
|
|
|
|
+void llama_sampling_creset(struct llama_sampling_context *ctx)
|
|
|
|
+{
|
|
llama_sampling_reset(ctx);
|
|
llama_sampling_reset(ctx);
|
|
}
|
|
}
|
|
|
|
|
|
llama_token llama_sampling_csample(
|
|
llama_token llama_sampling_csample(
|
|
- struct llama_sampling_context * ctx_sampling,
|
|
|
|
- struct llama_context * ctx_main,
|
|
|
|
- struct llama_context * ctx_cfg,
|
|
|
|
- int idx) {
|
|
|
|
|
|
+ struct llama_sampling_context *ctx_sampling,
|
|
|
|
+ struct llama_context *ctx_main,
|
|
|
|
+ struct llama_context *ctx_cfg,
|
|
|
|
+ int idx)
|
|
|
|
+{
|
|
return llama_sampling_sample(ctx_sampling, ctx_main, ctx_cfg, idx);
|
|
return llama_sampling_sample(ctx_sampling, ctx_main, ctx_cfg, idx);
|
|
}
|
|
}
|
|
|
|
|
|
void llama_sampling_caccept(
|
|
void llama_sampling_caccept(
|
|
- struct llama_sampling_context * ctx_sampling,
|
|
|
|
- struct llama_context * ctx_main,
|
|
|
|
- llama_token id,
|
|
|
|
- bool apply_grammar) {
|
|
|
|
|
|
+ struct llama_sampling_context *ctx_sampling,
|
|
|
|
+ struct llama_context *ctx_main,
|
|
|
|
+ llama_token id,
|
|
|
|
+ bool apply_grammar)
|
|
|
|
+{
|
|
llama_sampling_accept(ctx_sampling, ctx_main, id, apply_grammar);
|
|
llama_sampling_accept(ctx_sampling, ctx_main, id, apply_grammar);
|
|
}
|
|
}
|