blob: 40b4073e1f4c8b7e45d331e2a866eecbaba9c18e [file] [log] [blame]
/* Copyright 2019 The TensorFlow 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.
==============================================================================*/
#ifndef MLIR_HLO_DIALECT_MHLO_TRANSFORMS_REWRITERS_H
#define MLIR_HLO_DIALECT_MHLO_TRANSFORMS_REWRITERS_H
#include <functional>
#include <memory>
#include "mlir/IR/MLIRContext.h"
#include "mlir/IR/PatternMatch.h"
#include "mlir/Transforms/DialectConversion.h"
namespace mlir {
namespace bufferization {
class BufferizeTypeConverter;
} // namespace bufferization
namespace mhlo {
// Collection of rewrite patterns for lowering a general dot product.
void populateGeneralDotOpLoweringPatterns(RewritePatternSet *patterns,
MLIRContext *ctx);
// Collection of rewrite patterns for lowering complex operations to equivalent
// float operations.
void populateComplexLoweringPatterns(MLIRContext *context,
RewritePatternSet *patterns);
void populateOptimizeMhloPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Rewrite patterns for einsum to equivalent dot_general legalization.
void populateEinsumToDotGeneralPatterns(mlir::MLIRContext *context,
RewritePatternSet *patterns);
// Rewrite patterns for gather to equivalent torch index select legalization.
void populateGatherToTorchIndexSelectPatterns(mlir::MLIRContext *context,
RewritePatternSet *patterns);
void populateMhloToStdPatterns(RewritePatternSet *patterns, MLIRContext *ctx);
// Collection of rewrite patterns for lowering all mhlo ops to their
// lmhlo counterparts.
void populateDynamicHloToLhloConversionPattern(
MLIRContext *context, bufferization::BufferizeTypeConverter *converter,
RewritePatternSet *patterns);
// Collection of rewrite patterns for lowering of HLO to LHLO dialect.
void populateHloToLhloConversionPattern(
MLIRContext *context, bufferization::BufferizeTypeConverter *converter,
RewritePatternSet *patterns);
// Collection of rewrite patterns for lowering of HLO to arithmetic dialect.
void populateHloToArithmeticConversionPatterns(RewritePatternSet *patterns);
// Collection of rewrite patterns for lowering of shape operations from the HLO
// dialect to the standard dialect.
void populateHloShapeOpsToStandardConversionPattern(
MLIRContext *context, TypeConverter &typeConverter,
RewritePatternSet *patterns);
// Collection of rewrite patterns for lowering of HLO to Linalg dialect.
void populateHloToLinalgConversionPattern(MLIRContext *context,
TypeConverter &typeConverter,
RewritePatternSet *patterns);
// Collection of rewrite patterns for lowering of HLO dim operations.
void populateShapeComputationPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Converter to signless intergers to be used with linalg conversion patterns.
std::unique_ptr<TypeConverter> createHloToLinalgSignedIntegerConverter();
// Sets up legality definitions for materializing broadcasts.
void setupMaterializeBroadcastsLegality(MLIRContext *context,
ConversionTarget *conversionTarget);
// Populates a collection of rewrite patterns for materializing broadcast
// attributes to equivalent sequences of ops.
void populateMaterializeBroadcastsPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Populates a collection of rewrite patterns to realize element-wise operations
// on ranked tensors where possible.
void populateTransformUnrankedHloPatterns(MLIRContext *context,
RewritePatternSet *patterns);
void populateDynamicShapeFusionPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Populate a collection of conversion patterns for un-fusing
// batch_norm_inference into constituent HLO ops.
void populateUnfuseBatchNormInferencePattern(MLIRContext *context,
RewritePatternSet *patterns);
// Populate a collection of conversion patterns for un-fusing
// batch_norm_training into constituent HLO ops.
void populateUnfuseBatchNormTrainingPattern(MLIRContext *context,
RewritePatternSet *patterns);
// Populate a collection of conversion patterns for un-fusing
// // batch_norm_inference and batch_norm_training into constituent HLO ops.
inline void populateUnfuseBatchNormPatterns(MLIRContext *context,
RewritePatternSet *patterns) {
populateUnfuseBatchNormInferencePattern(context, patterns);
populateUnfuseBatchNormTrainingPattern(context, patterns);
}
// Populates patterns that translate the trigonometric operations from the
// standard dialect to approximations that do not use intrinsics.
void populateTrigonometricToApproximationPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Populate patterns to prepare moving dynamic broadcasts up over element-wise
// operations and broadcast the operands rather than the result. This will
// eventually allow for larger fusions.
void populateMergeAssumingOpsPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Populate patterns for iterative shape reification.
void populateShapeReificationPatterns(MLIRContext *, RewritePatternSet *);
// Populate patterns to group reduction and parallel dimensions of reduction
// operations and realize them through equivalent 1D or 2D reductions.
void populateGroupReductionDimensionsPatterns(MLIRContext *context,
RewritePatternSet *patterns,
bool preferColumnsReductions);
/// Populate rank specialization clustering and lowering patterns.
void populateRankSpecializationClusterPatterns(MLIRContext *context,
RewritePatternSet *patterns);
void populateRankSpecializationToSCFPatterns(MLIRContext *context,
RewritePatternSet *patterns,
int64_t maxTargetRank);
/// Populate sparse tensor specific rewriting patterns.
void populateSparseRewritingPatterns(RewritePatternSet *patterns,
MLIRContext *ctx);
} // namespace mhlo
namespace chlo {
// Populates a collection of conversion patterns for legalizing broadcasting
// client-HLO to their non-broadcasting counterparts.
void populateChloBroadcastingPatterns(MLIRContext *context,
RewritePatternSet *patterns);
// Populates a collection of conversion patterns for legalizing client-HLO to
// HLO by decomposing client-operations to corresponding sequences of more
// primitive operations. This does not include the
// PopulateChloBroadcastingPatterns above.
void populateDecomposeChloPatterns(MLIRContext *context,
RewritePatternSet *patterns);
} // namespace chlo
} // namespace mlir
#endif // MLIR_HLO_DIALECT_MHLO_TRANSFORMS_REWRITERS_H