sampling_ext.cpp 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. // TODO: this is a temporary wrapper to allow calling C++ code from CGo
  2. #include "sampling.h"
  3. #include "sampling_ext.h"
  4. struct gpt_sampler *gpt_sampler_cinit(
  5. const struct llama_model *model, struct gpt_sampler_cparams *params)
  6. {
  7. try {
  8. gpt_sampler_params sparams;
  9. sparams.top_k = params->top_k;
  10. sparams.top_p = params->top_p;
  11. sparams.min_p = params->min_p;
  12. sparams.tfs_z = params->tfs_z;
  13. sparams.typ_p = params->typical_p;
  14. sparams.temp = params->temp;
  15. sparams.penalty_last_n = params->penalty_last_n;
  16. sparams.penalty_repeat = params->penalty_repeat;
  17. sparams.penalty_freq = params->penalty_freq;
  18. sparams.penalty_present = params->penalty_present;
  19. sparams.mirostat = params->mirostat;
  20. sparams.mirostat_tau = params->mirostat_tau;
  21. sparams.mirostat_eta = params->mirostat_eta;
  22. sparams.penalize_nl = params->penalize_nl;
  23. sparams.seed = params->seed;
  24. sparams.grammar = params->grammar;
  25. return gpt_sampler_init(model, sparams);
  26. } catch (const std::exception & err) {
  27. return nullptr;
  28. }
  29. }
  30. void gpt_sampler_cfree(struct gpt_sampler *sampler)
  31. {
  32. gpt_sampler_free(sampler);
  33. }
  34. void gpt_sampler_creset(struct gpt_sampler *sampler)
  35. {
  36. gpt_sampler_reset(sampler);
  37. }
  38. llama_token gpt_sampler_csample(
  39. struct gpt_sampler *sampler,
  40. struct llama_context *ctx_main,
  41. int idx)
  42. {
  43. return gpt_sampler_sample(sampler, ctx_main, idx);
  44. }
  45. void gpt_sampler_caccept(
  46. struct gpt_sampler *sampler,
  47. llama_token id,
  48. bool apply_grammar)
  49. {
  50. gpt_sampler_accept(sampler, id, apply_grammar);
  51. }