Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
曾经的那一瞬间
Tensorflow
提交
3187d364
T
Tensorflow
项目概览
曾经的那一瞬间
/
Tensorflow
10 个月 前同步成功
通知
10
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Tensorflow
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
3187d364
编写于
7月 20, 2023
作者:
A
A. Unique TensorFlower
提交者:
TensorFlower Gardener
7月 20, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Move ConvertTFQuantOpsToMHLO pass definition to passes.td to be consistent with other passes
PiperOrigin-RevId: 549654509
上级
30e983f6
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
27 addition
and
31 deletion
+27
-31
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/convert_tf_quant_ops_to_mhlo.cc
...n/stablehlo/passes/bridge/convert_tf_quant_ops_to_mhlo.cc
+10
-27
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.h
...mpiler/mlir/quantization/stablehlo/passes/bridge/passes.h
+4
-4
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.td
...piler/mlir/quantization/stablehlo/passes/bridge/passes.td
+13
-0
未找到文件。
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/convert_tf_quant_ops_to_mhlo.cc
浏览文件 @
3187d364
...
...
@@ -58,6 +58,9 @@ namespace mlir {
namespace
stablehlo
{
namespace
{
#define GEN_PASS_DEF_CONVERTTFQUANTOPSTOMHLO
#include "tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.h.inc"
FailureOr
<
IntegerType
>
GetStorageType
(
Operation
*
op
,
Type
original_output_element_type
,
PatternRewriter
&
rewriter
)
{
...
...
@@ -638,37 +641,17 @@ class ConvertUniformQuantizedClipByValueOp
}
};
class
ConvertTFQuantOpsToMHLOPass
:
public
PassWrapper
<
ConvertTFQuantOpsToMHLOPass
,
OperationPass
<
func
::
FuncOp
>>
{
class
ConvertTFQuantOpsToMHLO
:
public
impl
::
ConvertTFQuantOpsToMHLOBase
<
ConvertTFQuantOpsToMHLO
>
{
public:
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID
(
ConvertTFQuantOpsToMHLOPass
)
StringRef
getArgument
()
const
final
{
// This is the argument used to refer to the pass in
// the textual format (on the commandline for example).
return
"quant-convert-tf-quant-ops-to-mhlo"
;
}
StringRef
getDescription
()
const
final
{
// This is a brief description of the pass.
return
"Convert TF Quant ops to MHLO quantization"
;
}
void
getDependentDialects
(
DialectRegistry
&
registry
)
const
override
{
registry
.
insert
<
TF
::
TensorFlowDialect
>
();
registry
.
insert
<
mhlo
::
MhloDialect
>
();
registry
.
insert
<
chlo
::
ChloDialect
>
();
registry
.
insert
<
tf_type
::
TFTypeDialect
>
();
registry
.
insert
<
quant
::
QuantizationDialect
>
();
}
ConvertTFQuantOpsToMHLO
()
=
default
;
ConvertTFQuantOpsToMHLO
(
const
ConvertTFQuantOpsToMHLO
&
)
=
default
;
// Performs conversion of MHLO quant ops to primitive ops.
void
runOnOperation
()
override
;
};
static
PassRegistration
<
ConvertTFQuantOpsToMHLOPass
>
pass
;
void
ConvertTFQuantOpsToMHLOPass
::
runOnOperation
()
{
void
ConvertTFQuantOpsToMHLO
::
runOnOperation
()
{
MLIRContext
*
ctx
=
&
getContext
();
func
::
FuncOp
func
=
getOperation
();
ConversionTarget
target
(
*
ctx
);
...
...
@@ -703,7 +686,7 @@ void PopulateLegalizeTfQuantizationPatterns(MLIRContext *context,
std
::
unique_ptr
<
OperationPass
<
func
::
FuncOp
>>
CreateConvertTFQuantOpsToMHLOPass
()
{
return
std
::
make_unique
<
ConvertTFQuantOpsToMHLO
Pass
>
();
return
std
::
make_unique
<
ConvertTFQuantOpsToMHLO
>
();
}
}
// namespace stablehlo
...
...
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.h
浏览文件 @
3187d364
...
...
@@ -30,10 +30,6 @@ namespace stablehlo {
std
::
unique_ptr
<
OperationPass
<
func
::
FuncOp
>>
createConvertMHLOQuantToIntPass
(
bool
legalize_chlo
=
true
);
#define GEN_PASS_REGISTRATION
#define GEN_PASS_DECL_CONVERTMHLOQUANTTOINT
#include "tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.h.inc"
// Creates an instance of the ConvertTFQuantOpsToMHLOPass pass, which will
// convert TF uniform quantized ops to the corresponding quantized MHLO ops.
std
::
unique_ptr
<
OperationPass
<
func
::
FuncOp
>>
...
...
@@ -44,6 +40,10 @@ CreateConvertTFQuantOpsToMHLOPass();
void
PopulateLegalizeTfQuantizationPatterns
(
MLIRContext
*
context
,
RewritePatternSet
*
patterns
);
#define GEN_PASS_REGISTRATION
#define GEN_PASS_DECL_CONVERTMHLOQUANTTOINT
#define GEN_PASS_DECL_CONVERTTFQUANTOPSTOMHLO
#include "tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.h.inc"
}
// namespace stablehlo
}
// namespace mlir
...
...
tensorflow/compiler/mlir/quantization/stablehlo/passes/bridge/passes.td
浏览文件 @
3187d364
...
...
@@ -35,3 +35,16 @@ def ConvertMHLOQuantToInt : Pass<"convert-mhlo-quant-to-int", "mlir::func::FuncO
"shape::ShapeDialect",
"func::FuncDialect"];
}
def ConvertTFQuantOpsToMHLO : Pass<"quant-convert-tf-quant-ops-to-mhlo", "mlir::func::FuncOp"> {
let summary = "Convert TF Quant ops to MHLO quantizated ops.";
let description = [{
Convert TF Quant ops to MHLO quant ops.
}];
let constructor = "mlir::stablehlo::CreateConvertTFQuantOpsToMHLOPass()";
let dependentDialects = ["TF::TensorFlowDialect", "chlo::ChloDialect",
"mhlo::MhloDialect", "tf_type::TFTypeDialect",
"quant::QuantizationDialect"];
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录