forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconstants.h
60 lines (50 loc) · 1.96 KB
/
constants.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#pragma once
#include <ATen/core/ivalue.h>
#include <ATen/core/jit_type.h>
#include <torch/csrc/Export.h>
#include <torch/csrc/jit/frontend/source_range.h>
#include <torch/csrc/jit/ir/scope.h>
// helpers for handling constants in the IR
// - create constant nodes from ints, floats, complex, intlist, Tensors, and
// other types
// - implement primitive constant ops.
namespace torch::jit {
using ::c10::IValue;
struct Graph;
struct Value;
// thrown when insertConstant cannot encode the IValue into a graph
struct TORCH_API constant_not_supported_error : public std::runtime_error {
using runtime_error::runtime_error;
};
TORCH_API Value* insertConstant(
Graph& g,
const IValue& val,
std::optional<SourceRange> loc = std::nullopt,
std::optional<ScopePtr> scope = std::nullopt);
// note: prefer g.insertConsant(val, loc) which does exactly the same thing
// this function is only declared/defined here because its implementation is
// closely related to the implementation of prim::Constant that is also in
// constants.cpp.
//
// returns a std::nullopt if the IValue kind cannot be inserted as a constant
TORCH_API std::optional<Value*> tryInsertConstant(
Graph& g,
const IValue& val,
std::optional<SourceRange> loc = std::nullopt,
std::optional<ScopePtr> scope = std::nullopt);
////////////////////////////////////////////////////////////////////////////////
// Helper for retrieving constants
////////////////////////////////////////////////////////////////////////////////
// attempt to convert a (possibly constant) Value* into an interpreter value
// (IValue). returns std::nullopt if the Value* was not constant
TORCH_API std::optional<IValue> toIValue(const Value* v);
// if a value is a constant then try to turn into type T using the
// same rules as the interpreter
template <typename T>
std::optional<T> constant_as(const Value* v) {
if (auto ivalue = toIValue(v)) {
return ivalue->to<T>();
}
return std::nullopt;
}
} // namespace torch::jit