-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpybind.cpp
56 lines (50 loc) · 3.24 KB
/
pybind.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include "justlm.hpp"
#include "justlm_pool.hpp"
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>
#include <pybind11/functional.h>
namespace py = pybind11;
PYBIND11_MODULE(justlm_py, m) {
using namespace LM;
py::class_<Inference::Params>(m, "Params")
.def(py::init<>())
.def_readonly("seed", &Inference::Params::seed)
.def_readwrite("n_threads", &Inference::Params::n_threads)
.def_readwrite("n_ctx", &Inference::Params::n_ctx)
.def_readwrite("n_ctx_window_top_bar", &Inference::Params::n_ctx_window_top_bar)
.def_readwrite("n_batch", &Inference::Params::n_batch)
.def_readwrite("n_repeat_last", &Inference::Params::n_repeat_last)
.def_readwrite("repeat_penalty", &Inference::Params::repeat_penalty)
.def_readwrite("top_k", &Inference::Params::top_k)
.def_readwrite("top_p", &Inference::Params::top_p)
.def_readwrite("temp", &Inference::Params::temp)
.def_readwrite("repeat_penalty", &Inference::Params::repeat_penalty)
.def_readwrite("eos_ignores", &Inference::Params::n_eos_ignores)
.def_readwrite("use_mlock", &Inference::Params::use_mlock)
.def_readwrite("prefer_mirostat", &Inference::Params::prefer_mirostat)
.def_readwrite("mirostat_learning_rate", &Inference::Params::mirostat_learning_rate)
.def_readwrite("mirostat_target_entropy", &Inference::Params::mirostat_target_entropy);
py::class_<Inference>(m, "Inference")
.def_static("construct", &Inference::construct, py::arg("weights_path"), py::arg("params") = Inference::Params())
.def("append", &Inference::append, py::arg("prompt"), py::arg("on_tick") = nullptr)
.def("run", &Inference::run, py::arg("end") = "", py::arg("on_tick") = nullptr, py::arg("pre_tick") = nullptr)
.def("create_savestate", &Inference::create_savestate)
.def("restore_savestate", &Inference::restore_savestate)
.def("get_prompt", &Inference::get_prompt)
.def("get_context_size", &Inference::get_context_size)
.def("is_mirostat_available", &Inference::is_mirostat_available)
.def("is_grammar_available", &Inference::is_grammar_available)
.def("load_grammar", &Inference::load_grammar)
.def("unload_grammar", &Inference::unload_grammar)
.def_readwrite("params", &Inference::params);
py::class_<Inference::Savestate>(m, "Savestate")
.def(py::init<>());
py::class_<InferencePool>(m, "InferencePool")
.def(py::init<size_t, const std::string&, bool>(), py::arg("size"), py::arg("pool_name"), py::arg("clean_up") = true)
.def("create_inference", &InferencePool::create_inference, py::arg("id"), py::arg("weights_path"), py::arg("parameters"), py::return_value_policy::reference_internal)
.def("get_inference", &InferencePool::get_inference, py::arg("id"), py::return_value_policy::reference_internal)
.def("get_or_create_inference", &InferencePool::create_inference, py::arg("id"), py::arg("weights_path"), py::arg("parameters"), py::return_value_policy::reference_internal)
.def("delete_inference", &InferencePool::delete_inference, py::arg("id"))
.def("store_all", &InferencePool::store_all)
.def("get_active_slot_ids", &InferencePool::get_active_slot_ids);
}