mirror of
https://github.com/zebrajr/pytorch.git
synced 2025-12-07 12:21:27 +01:00
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/61600 This diff changes the module.h constructor, and removes metadata_. It refactors all the constructors caller side, and creates a getter & setting for metadata_. MOBILE_MODULE_STATS reads the metadata from mobile::Module, and pass it into logger. Test Plan: Since 3D Photo is disabled for current FB app, testings are only performed on CC scanner. # Test On CC Scanner **Test content with LOG(WARNING)** {P428930572} **Scuba Logger Output** {F631761194} Reviewed By: xcheng16 Differential Revision: D29673184 fbshipit-source-id: 962e0d7b06a07caaa0c695a4ac58b885fd1505ea
125 lines
3.9 KiB
C++
125 lines
3.9 KiB
C++
#pragma once
|
|
#include <ATen/core/jit_type.h>
|
|
#include <torch/csrc/jit/mobile/debug_info.h>
|
|
#include <torch/csrc/jit/mobile/function.h>
|
|
#include <torch/csrc/jit/mobile/method.h>
|
|
|
|
namespace torch {
|
|
namespace jit {
|
|
namespace mobile {
|
|
using Stack = std::vector<c10::IValue>;
|
|
|
|
// A CompilationUnit object is the one that gets executed by the lite
|
|
// interpreter.
|
|
//
|
|
// A CompilationUnit object contains a list of Method Objects. These are methods
|
|
// that appear in the original PyTorch Model. These method correspond to Python
|
|
// member functions of the Model class.
|
|
//
|
|
// Methods in turn contain a Function, and a back-pointer to the Module that
|
|
// owns this Method instance.
|
|
//
|
|
// A Function contains a Code Object (code_) which is defined in interpreter.h
|
|
//
|
|
// A Code object contains the following:
|
|
//
|
|
// std::vector<Instruction> instructions_;
|
|
// std::vector<c10::OperatorName> op_names_;
|
|
// std::vector<std::function<void(Stack&)>> operators_;
|
|
// std::vector<c10::IValue> constants_;
|
|
// std::vector<c10::TypePtr> types_;
|
|
// size_t register_size_; // Aggregated output size.
|
|
//
|
|
class CompilationUnit {
|
|
public:
|
|
void register_function(std::unique_ptr<Function> fn);
|
|
std::vector<std::unique_ptr<Function>>& methods() {
|
|
return methods_;
|
|
}
|
|
Function* find_function(const c10::QualifiedName& qn);
|
|
|
|
private:
|
|
std::vector<std::unique_ptr<Function>> methods_;
|
|
};
|
|
|
|
// A Torch Mobile Module is a representation of the model (trained in case
|
|
// of inference). A Mobile Module contains
|
|
//
|
|
// 1. data (object_)
|
|
// 2. metadata (optional) about the model (metadata_ from the metadata.pkl
|
|
// file added after training)
|
|
// 3. Compilation Unit (cu_)
|
|
//
|
|
class TORCH_API Module {
|
|
public:
|
|
Module(
|
|
// NOLINTNEXTLINE(modernize-pass-by-value)
|
|
c10::intrusive_ptr<c10::ivalue::Object> object,
|
|
std::shared_ptr<CompilationUnit> cu)
|
|
: object_(object), cu_(std::move(cu)) {}
|
|
Module() = default;
|
|
Method get_method(const std::string& method_name) const;
|
|
template <typename... Types>
|
|
c10::IValue run_method(const std::string& method_name, Types&&... args) {
|
|
return get_method(method_name)({IValue(std::forward<Types>(args))...});
|
|
}
|
|
c10::IValue forward(std::vector<c10::IValue> inputs) {
|
|
return get_method("forward")(std::move(inputs));
|
|
}
|
|
c10::optional<Method> find_method(const std::string& basename) const;
|
|
const std::string name() const {
|
|
return object_->name();
|
|
}
|
|
const std::vector<at::IValue>& slots() const {
|
|
return object_->slots();
|
|
}
|
|
const c10::intrusive_ptr<c10::ivalue::Object> _ivalue() const {
|
|
return object_;
|
|
}
|
|
const std::vector<at::Tensor> parameters() const;
|
|
const std::map<std::string, at::Tensor> named_parameters() const;
|
|
std::string get_forward_method_debug_info(size_t pc) const;
|
|
/// Enables "training" mode.
|
|
void train(bool on = true);
|
|
/// Calls train(false) to enable "eval" mode.
|
|
void eval() {
|
|
train(/*on=*/false);
|
|
}
|
|
/// True if the module is in training mode.
|
|
bool is_training() const;
|
|
const std::unordered_map<std::string, std::string> getMetadata() const {
|
|
return metadata_;
|
|
}
|
|
void setMetadata(
|
|
const std::unordered_map<std::string, std::string>& metadata) {
|
|
metadata_ = metadata;
|
|
}
|
|
const std::vector<Method> get_methods() const;
|
|
|
|
c10::IValue attr(const std::string& name, c10::IValue or_else) const {
|
|
if (auto r = object_->type()->findAttributeSlot(name)) {
|
|
return object_->getSlot(*r);
|
|
}
|
|
if (auto r = object_->type()->findConstantSlot(name)) {
|
|
return object_->type()->getConstant(*r);
|
|
}
|
|
return or_else;
|
|
}
|
|
|
|
void setDebugTable(MobileDebugTable&& debug_table) {
|
|
debug_table_ = std::move(debug_table);
|
|
}
|
|
const MobileDebugTable& getDebugTable() const {
|
|
return debug_table_;
|
|
}
|
|
|
|
private:
|
|
c10::intrusive_ptr<c10::ivalue::Object> object_;
|
|
std::unordered_map<std::string, std::string> metadata_;
|
|
std::shared_ptr<CompilationUnit> cu_;
|
|
MobileDebugTable debug_table_;
|
|
};
|
|
} // namespace mobile
|
|
} // namespace jit
|
|
} // namespace torch
|