program.hpp 3.85 KB
Newer Older
Paul's avatar
Paul committed
1
2
#ifndef MIGRAPHX_GUARD_MIGRAPHLIB_PROGRAM_HPP
#define MIGRAPHX_GUARD_MIGRAPHLIB_PROGRAM_HPP
Paul's avatar
Paul committed
3

Paul's avatar
Paul committed
4
#include <list>
Paul's avatar
Paul committed
5
#include <unordered_map>
Paul's avatar
Paul committed
6
7
8
9
10
11
#include <migraphx/operation.hpp>
#include <migraphx/literal.hpp>
#include <migraphx/builtin.hpp>
#include <migraphx/instruction_ref.hpp>
#include <migraphx/target.hpp>
#include <migraphx/tracer.hpp>
Paul's avatar
Paul committed
12
#include <migraphx/env.hpp>
Paul's avatar
Paul committed
13
#include <migraphx/config.hpp>
Paul's avatar
Paul committed
14
#include <algorithm>
Paul's avatar
Paul committed
15
#include <iostream>
Paul's avatar
Paul committed
16

Paul's avatar
Paul committed
17
namespace migraphx {
Paul's avatar
Paul committed
18
inline namespace MIGRAPHX_INLINE_NS {
Paul's avatar
Paul committed
19

Paul's avatar
Paul committed
20
21
22
MIGRAPHX_DECLARE_ENV_VAR(MIGRAPHX_TRACE_COMPILE)
MIGRAPHX_DECLARE_ENV_VAR(MIGRAPHX_TRACE_EVAL)

Paul's avatar
Paul committed
23
24
struct program_impl;

Paul's avatar
Paul committed
25
26
const operation& get_operation(instruction_ref ins);

mei-ye's avatar
mei-ye committed
27
/**
Paul's avatar
Paul committed
28
29
 * @brief Stores the instruction stream
 */
Paul's avatar
Paul committed
30
31
struct program
{
Paul's avatar
Paul committed
32
    program();
33
34

    // move constructor
Paul's avatar
Paul committed
35
    program(program&&) noexcept;
36
37

    // copy constructor
Shucai Xiao's avatar
Shucai Xiao committed
38
    program(const program&);
39
40

    // copy assignment operator
Shucai Xiao's avatar
Shucai Xiao committed
41
    program& operator=(program);
42

Paul's avatar
Paul committed
43
    ~program() noexcept;
Paul's avatar
Paul committed
44

mei-ye's avatar
mei-ye committed
45
    using parameter_map = std::unordered_map<std::string, argument>;
Paul's avatar
Paul committed
46

Paul's avatar
Paul committed
47
    template <class... Ts>
Paul's avatar
Paul committed
48
    instruction_ref add_instruction(operation op, Ts... args)
Paul's avatar
Paul committed
49
    {
Paul's avatar
Paul committed
50
        return add_instruction(op, {args...});
Paul's avatar
Paul committed
51
    }
Paul's avatar
Paul committed
52
    instruction_ref add_instruction(const operation& op, std::vector<instruction_ref> args);
Paul's avatar
Paul committed
53

Paul's avatar
Paul committed
54
55
56
57
58
    template <class... Ts>
    instruction_ref insert_instruction(instruction_ref ins, operation op, Ts... args)
    {
        return insert_instruction(ins, op, {args...});
    }
Paul's avatar
Paul committed
59
    instruction_ref
Paul's avatar
Paul committed
60
    insert_instruction(instruction_ref ins, const operation& op, std::vector<instruction_ref> args);
Paul's avatar
Paul committed
61

Paul's avatar
Paul committed
62
63
64
65
66
    template <class... Ts>
    instruction_ref replace_instruction(instruction_ref ins, operation op, Ts... args)
    {
        return replace_instruction(ins, op, {args...});
    }
Paul's avatar
Paul committed
67
68
69
    instruction_ref replace_instruction(instruction_ref ins,
                                        const operation& op,
                                        std::vector<instruction_ref> args);
Paul's avatar
Paul committed
70

Paul's avatar
Paul committed
71
    instruction_ref replace_instruction(instruction_ref ins, instruction_ref rep);
Paul's avatar
Paul committed
72

Paul's avatar
Paul committed
73
    instruction_ref remove_instruction(instruction_ref ins);
74
    instruction_ref remove_instructions(instruction_ref first, instruction_ref last);
Paul's avatar
Paul committed
75

76
    instruction_ref move_instruction(instruction_ref src, instruction_ref dst);
Paul's avatar
Paul committed
77

Paul's avatar
Paul committed
78
    template <class... Ts>
Paul's avatar
Paul committed
79
    instruction_ref add_literal(Ts&&... xs)
Paul's avatar
Paul committed
80
    {
Paul's avatar
Paul committed
81
        return add_literal(literal{std::forward<Ts>(xs)...});
Paul's avatar
Paul committed
82
83
    }

Paul's avatar
Paul committed
84
    instruction_ref add_literal(literal l);
Paul's avatar
Paul committed
85

Paul's avatar
Paul committed
86
    instruction_ref add_outline(const shape& s);
Paul's avatar
Paul committed
87

Paul's avatar
Paul committed
88
    instruction_ref add_parameter(std::string name, shape s);
Paul's avatar
Paul committed
89

Paul's avatar
Paul committed
90
    shape get_parameter_shape(std::string name) const;
Paul's avatar
Paul committed
91

mei-ye's avatar
mei-ye committed
92
93
    instruction_ref get_parameter(std::string name) const;

Paul's avatar
Paul committed
94
95
    std::unordered_map<std::string, shape> get_parameter_shapes() const;

Paul's avatar
Paul committed
96
    argument eval(parameter_map params) const;
Paul's avatar
Paul committed
97

Paul's avatar
Paul committed
98
    bool has_instruction(instruction_ref ins) const;
Paul's avatar
Paul committed
99

Paul's avatar
Paul committed
100
    std::size_t size() const;
Paul's avatar
Paul committed
101
102
    instruction_ref begin() const;
    instruction_ref end() const;
103

Paul's avatar
Paul committed
104
105
    shape get_shape() const;

Paul's avatar
Paul committed
106
107
    context& get_context() const;

Paul's avatar
Paul committed
108
109
    instruction_ref validate() const;

mei-ye's avatar
mei-ye committed
110
    void compile(const target& t, tracer trace = tracer{});
Paul's avatar
Paul committed
111

Paul's avatar
Paul committed
112
    void finalize();
Paul's avatar
Paul committed
113

Paul's avatar
Paul committed
114
115
    void perf_report(std::ostream& os, std::size_t n, parameter_map params) const;

Paul's avatar
Paul committed
116
117
118
    void debug_print() const;
    void debug_print(instruction_ref ins) const;
    void debug_print(const std::vector<instruction_ref>& inss) const;
119
    void print_graph(std::ostream& os) const;
Paul's avatar
Paul committed
120

Paul's avatar
Paul committed
121
122
    void dry_run(parameter_map params) const;

Paul's avatar
Paul committed
123
124
    void annotate(std::ostream& os, std::function<void(instruction_ref)> a) const;

Paul's avatar
Paul committed
125
126
    friend std::ostream& operator<<(std::ostream& os, const program& p);
    friend bool operator==(const program& x, const program& y);
Paul's avatar
Paul committed
127
    friend bool operator!=(const program& x, const program& y) { return !(x == y); }
Paul's avatar
Paul committed
128

129
    private:
Shucai Xiao's avatar
Shucai Xiao committed
130
    void copy(const program& p);
131

Paul's avatar
Paul committed
132
    private:
Paul's avatar
Paul committed
133
    std::unique_ptr<program_impl> impl;
Paul's avatar
Paul committed
134
};
Paul's avatar
Paul committed
135

Paul's avatar
Paul committed
136
} // namespace MIGRAPHX_INLINE_NS
Paul's avatar
Paul committed
137
} // namespace migraphx
Paul's avatar
Paul committed
138
139

#endif