// RUN: mlir-opt %s -split-input-file -pass-pipeline='builtin.module(func.func(canonicalize{test-convergence}))' | FileCheck %s // ----- // CHECK-LABEL: redundant_scast func.func @redundant_scast() -> tensor<4xi8> { // CHECK-NEXT: arith.constant dense<10> : tensor<4xi8> // CHECK-NEXT: return %cst = arith.constant dense<5> : tensor<4xi8> %1 = "quant.scast"(%cst) : (tensor<4xi8>) -> tensor<4x!quant.uniform> %2 = "quant.scast"(%1) : (tensor<4x!quant.uniform>) -> tensor<4xi8> %3 = arith.addi %2, %2 : tensor<4xi8> return %3 : tensor<4xi8> } // ----- // CHECK-LABEL: non_redundant_scast func.func @non_redundant_scast() -> tensor<4x!quant.uniform> { // CHECK-NEXT: arith.constant dense<5> : tensor<4xi8> // CHECK-NEXT: scast // CHECK-NEXT: return %cst = arith.constant dense<5> : tensor<4xi8> %1 = "quant.scast"(%cst) : (tensor<4xi8>) -> tensor<4x!quant.uniform> return %1 : tensor<4x!quant.uniform> }