// Copyright (c) 2021 CINN Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. /** * This file implements the IRMutator as the base interface to mutate the IR. */ #pragma once #include "paddle/cinn/ir/intrinsic_ops.h" #include "paddle/cinn/ir/ir.h" #include "paddle/cinn/ir/ir_visitor.h" namespace cinn { namespace ir { //! T might be Expr* or const Expr* template class IRMutator : public IRVisitorBase { public: void Visit(const Expr *expr, T op) override; #define __(op__) void Visit(const op__ *op, T expr) override; NODETY_FORALL(__) #undef __ }; template void IRMutator::Visit(const Expr *expr, T op) { IRVisitorBase::Visit(expr, op); } #define UNARY_OP_IMPL(op__) \ template \ void IRMutator::Visit(const op__ *expr, T op) { \ auto *node = op->template As(); \ IRVisitorBase::Visit(&node->v(), &node->v()); \ } #define BINARY_OP_IMPL(op__) \ template \ void IRMutator::Visit(const op__ *expr, T op) { \ auto *node = op->template As(); \ IRVisitorBase::Visit(&node->a(), &node->a()); \ IRVisitorBase::Visit(&node->b(), &node->b()); \ } NODETY_UNARY_OP_FOR_EACH(UNARY_OP_IMPL) NODETY_BINARY_OP_FOR_EACH(BINARY_OP_IMPL) #undef UNARY_OP_IMPL #undef BINARY_OP_IMPL template void IRMutator::Visit(const IntImm *expr, T op) {} template void IRMutator::Visit(const UIntImm *expr, T op) {} template void IRMutator::Visit(const FloatImm *expr, T op) {} template void IRMutator::Visit(const StringImm *expr, T op) {} template void IRMutator::Visit(const Cast *expr, T op) { auto *node = op->template As(); Visit(&node->v(), &node->v()); } template void IRMutator::Visit(const For *expr, T op) { auto *node = op->template As(); IRVisitorBase::Visit(&node->min, &node->min); IRVisitorBase::Visit(&node->extent, &node->extent); IRVisitorBase::Visit(&node->body, &node->body); } template void IRMutator::Visit(const PolyFor *expr, T op) { auto *node = op->template As(); // IRVisitorBase::Visit(&node->iterator, &node->iterator); IRVisitorBase::Visit(&node->init, &node->init); IRVisitorBase::Visit(&node->condition, &node->condition); IRVisitorBase::Visit(&node->inc, &node->inc); IRVisitorBase::Visit(&node->body, &node->body); } template void IRMutator::Visit(const Select *expr, T op) { auto *node = op->template As