Jlm
ThetaConversion.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2021 David Metz <david.c.metz@ntnu.no>
3  * See COPYING for terms of redistribution.
4  */
5 
6 #ifndef JLM_HLS_BACKEND_RVSDG2RHLS_THETACONVERSION_HPP
7 #define JLM_HLS_BACKEND_RVSDG2RHLS_THETACONVERSION_HPP
8 
10 
11 namespace jlm::hls
12 {
13 
18 {
19 public:
20  ~ThetaNodeConversion() noexcept override;
21 
23 
25 
27  operator=(const ThetaNodeConversion &) = delete;
28 
29  void
30  Run(rvsdg::RvsdgModule & rvsdgModule, util::StatisticsCollector & statisticsCollector) override;
31 
32  static void
33  CreateAndRun(rvsdg::RvsdgModule & rvsdgModule, util::StatisticsCollector & statisticsCollector)
34  {
35  ThetaNodeConversion thetaNodeConversion;
36  thetaNodeConversion.Run(rvsdgModule, statisticsCollector);
37  }
38 };
39 
40 }
41 
42 #endif // JLM_HLS_BACKEND_RVSDG2RHLS_THETACONVERSION_HPP
void Run(rvsdg::RvsdgModule &rvsdgModule, util::StatisticsCollector &statisticsCollector) override
Perform RVSDG transformation.
static void CreateAndRun(rvsdg::RvsdgModule &rvsdgModule, util::StatisticsCollector &statisticsCollector)
~ThetaNodeConversion() noexcept override
Represents an RVSDG transformation.