2024-10-04 02:42:31 -06:00
|
|
|
//
|
|
|
|
// Created by mfuntowicz on 10/3/24.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include <string_view>
|
2024-10-22 16:09:10 -06:00
|
|
|
#include <fmt/color.h>
|
2024-10-04 02:42:31 -06:00
|
|
|
#include <fmt/format.h>
|
2024-10-22 07:22:56 -06:00
|
|
|
#include <fmt/std.h>
|
2024-10-22 16:09:10 -06:00
|
|
|
#include <fmt/ranges.h>
|
2024-10-04 02:42:31 -06:00
|
|
|
#include <spdlog/spdlog.h>
|
|
|
|
#include "../csrc/backend.hpp"
|
|
|
|
|
2024-10-24 08:42:50 -06:00
|
|
|
using namespace huggingface::tgi::backends::llamacpp;
|
|
|
|
|
2024-10-04 02:42:31 -06:00
|
|
|
int main(int argc, char** argv) {
|
2024-10-22 16:09:10 -06:00
|
|
|
if (argc < 2) {
|
2024-10-04 02:42:31 -06:00
|
|
|
fmt::print("No model folder provider");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
spdlog::set_level(spdlog::level::debug);
|
|
|
|
|
2024-10-22 16:09:10 -06:00
|
|
|
const auto prompt = "My name is Morgan";
|
|
|
|
|
2024-10-22 07:22:56 -06:00
|
|
|
const auto modelPath = absolute(std::filesystem::path(argv[1]));
|
2024-10-24 08:42:50 -06:00
|
|
|
if (auto maybeBackend = CreateLlamaCppBackend(modelPath); maybeBackend.has_value()) {
|
2024-10-22 16:09:10 -06:00
|
|
|
// Retrieve the backend
|
|
|
|
const auto& backend = *maybeBackend;
|
|
|
|
|
|
|
|
// Generate
|
|
|
|
const auto promptTokens = backend->Tokenize(prompt);
|
2024-10-23 06:12:52 -06:00
|
|
|
const auto out = backend->Generate(promptTokens, 30, 1.0, 2.0, 0.0, 32);
|
|
|
|
|
|
|
|
if(out.has_value())
|
|
|
|
fmt::print(FMT_STRING("Generated: {}"), *out);
|
|
|
|
else {
|
|
|
|
const auto err = out.error();
|
|
|
|
fmt::print(fmt::emphasis::bold | fg(fmt::color::red), "Got an error: {:d}", static_cast<uint8_t>(err));
|
|
|
|
}
|
|
|
|
|
2024-10-22 16:09:10 -06:00
|
|
|
} else {
|
|
|
|
switch (maybeBackend.error()) {
|
2024-10-24 08:42:50 -06:00
|
|
|
case TgiLlamaCppBackendError::MODEL_FILE_DOESNT_EXIST:
|
2024-10-22 16:09:10 -06:00
|
|
|
fmt::print(fmt::emphasis::bold | fg(fmt::color::red), "Specified file {} doesnt exist", modelPath);
|
|
|
|
return maybeBackend.error();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|