llama.cpp/ggml/src/ggml-openvino/decoder.h

63 lines
2.2 KiB
C++

#pragma once
#include <map>
#include <openvino/core/node.hpp>
#include <openvino/frontend/decoder.hpp>
namespace ov {
namespace frontend {
namespace ggml {
// TODO: Directly include from openvino
class GgmlDecoder : public DecoderBase {
public:
virtual ov::Any get_attribute(const std::string& name) const = 0;
virtual PartialShape get_input_shape(const std::string& name) const = 0;
virtual std::vector<size_t> get_input_stride(const std::string& name) const = 0;
virtual element::Type get_input_type(const std::string& name) const = 0;
virtual size_t get_input_size() const = 0;
virtual void get_input_node(size_t input_port_idx,
std::string& producer_name,
std::string& producer_output_port_name,
size_t& producer_output_port_index) const = 0;
virtual std::string& get_input_name(size_t index) const = 0;
virtual std::vector<std::string> get_input_names() const = 0;
virtual PartialShape get_output_shape(const std::string& name) const = 0;
virtual std::vector<size_t> get_output_stride(const std::string& name) const = 0;
virtual element::Type get_output_type(const std::string& name) const = 0;
virtual int32_t* get_input_op_params(const std::string& name) const = 0;
virtual int32_t* get_output_op_params(const std::string& name) const = 0;
virtual std::string& get_output_name(size_t index) const = 0;
virtual std::vector<std::string> get_output_names() const = 0;
virtual const std::string& get_op_type() const = 0;
virtual const std::string& get_op_name() const = 0;
virtual void visit_subgraph(std::function<void(std::shared_ptr<GgmlDecoder>)> node_visitor) const = 0;
virtual bool check_if_continuous() const = 0;
virtual const std::map<std::string, std::shared_ptr<ov::Node>>& get_model_inputs() const = 0;
virtual const std::map<std::string, std::shared_ptr<ov::Node>>& get_model_extra_inputs() const = 0;
virtual const std::map<std::string, std::shared_ptr<ov::Node>>& get_model_weights() const = 0;
virtual const std::vector<std::string>& get_model_output_names() const = 0;
};
} // namespace ggml
} // namespace frontend
} // namespace ov