Rate this Page

Program Listing for File ModelRunnerHandle.h#

Return to documentation for file (torch/csrc/api/include/torch/nativert/ModelRunnerHandle.h)

#pragma once

#include <memory>
#include <string>
#include <unordered_map>
#include <vector>

#include <ATen/core/ivalue.h>
#include <c10/macros/Export.h>

namespace torch::nativert {

// We don't want to forward declare in general but including ModelRunner will
// pollute the public API namespace too much. Therefore, we just use pimpl an
// incomplete ModelRunner here.
class ModelRunner;

class TORCH_API ModelRunnerHandle {
 public:
  ModelRunnerHandle(
      const std::string& packagePath,
      const std::string& modelName);

  ModelRunnerHandle(ModelRunnerHandle&&) = default;
  ModelRunnerHandle& operator=(ModelRunnerHandle&&) = default;
  ModelRunnerHandle(const ModelRunnerHandle&) = delete;
  ModelRunnerHandle& operator=(const ModelRunnerHandle&) = delete;
  ~ModelRunnerHandle();

  c10::IValue run(
      const std::vector<c10::IValue>& args,
      const std::unordered_map<std::string, c10::IValue>& kwargs);

  std::vector<c10::IValue> runWithFlatInputsAndOutputs(
      std::vector<c10::IValue> flatInputs);

 private:
  std::unique_ptr<ModelRunner> impl_;
};

} // namespace torch::nativert