sampling_ext.cpp 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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 llama_sampling_context *llama_sampling_cinit(struct llama_sampling_cparams *params)
  5. {
  6. llama_sampling_params sparams;
  7. sparams.top_k = params->top_k;
  8. sparams.top_p = params->top_p;
  9. sparams.min_p = params->min_p;
  10. sparams.tfs_z = params->tfs_z;
  11. sparams.typical_p = params->typical_p;
  12. sparams.temp = params->temp;
  13. sparams.penalty_last_n = params->penalty_last_n;
  14. sparams.penalty_repeat = params->penalty_repeat;
  15. sparams.penalty_freq = params->penalty_freq;
  16. sparams.penalty_present = params->penalty_present;
  17. sparams.mirostat = params->mirostat;
  18. sparams.mirostat_tau = params->mirostat_tau;
  19. sparams.mirostat_eta = params->mirostat_eta;
  20. sparams.penalize_nl = params->penalize_nl;
  21. sparams.seed = params->seed;
  22. sparams.grammar = params->grammar;
  23. return llama_sampling_init(sparams);
  24. }
  25. void llama_sampling_cfree(struct llama_sampling_context *ctx)
  26. {
  27. llama_sampling_free(ctx);
  28. }
  29. void llama_sampling_creset(struct llama_sampling_context *ctx)
  30. {
  31. llama_sampling_reset(ctx);
  32. }
  33. llama_token llama_sampling_csample(
  34. struct llama_sampling_context *ctx_sampling,
  35. struct llama_context *ctx_main,
  36. struct llama_context *ctx_cfg,
  37. int idx)
  38. {
  39. return llama_sampling_sample(ctx_sampling, ctx_main, ctx_cfg, idx);
  40. }
  41. void llama_sampling_caccept(
  42. struct llama_sampling_context *ctx_sampling,
  43. struct llama_context *ctx_main,
  44. llama_token id,
  45. bool apply_grammar)
  46. {
  47. llama_sampling_accept(ctx_sampling, ctx_main, id, apply_grammar);
  48. }