| // RUN: mlir-opt %s -split-input-file -verify-diagnostics |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @dcast_scalar(%arg0: !qalias) { |
| %0 = quant.dcast %arg0 : !qalias to f32 |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @dcast_ranked(%arg0: tensor<2x?x4x!qalias>) { |
| %0 = quant.dcast %arg0 : tensor<2x?x4x!qalias> to tensor<2x?x4xf32> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @dcast_unranked(%arg0: tensor<*x!qalias>) { |
| %0 = quant.dcast %arg0 : tensor<*x!qalias> to tensor<*xf32> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @dcast_per_axis_static(%arg0: tensor<1x2x3x!qalias>) { |
| %0 = quant.dcast %arg0 : tensor<1x2x3x!qalias> to tensor<1x2x3xf32> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @dcast_per_axis_dynamic(%arg0: tensor<?x?x?x!qalias>) { |
| %0 = quant.dcast %arg0 : tensor<?x?x?x!qalias> to tensor<?x?x?xf32> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @dcast_per_axis_unranked(%arg0: tensor<*x!qalias>) { |
| %0 = quant.dcast %arg0 : tensor<*x!qalias> to tensor<*xf32> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @qcast_scalar(%arg0: f32) { |
| %0 = quant.qcast %arg0 : f32 to !qalias |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @qcast_ranked(%arg0: tensor<2x?x4xf32>) { |
| %0 = quant.qcast %arg0 : tensor<2x?x4xf32> to tensor<2x?x4x!qalias> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @qcast_unranked(%arg0: tensor<*xf32>) { |
| %0 = quant.qcast %arg0 : tensor<*xf32> to tensor<*x!qalias> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @qcast_per_axis_static(%arg0: tensor<1x2x3xf32>) { |
| %0 = quant.qcast %arg0 : tensor<1x2x3xf32> to tensor<1x2x3x!qalias> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @qcast_per_axis_dynamic(%arg0: tensor<?x?x?xf32>) { |
| %0 = quant.qcast %arg0 : tensor<?x?x?xf32> to tensor<?x?x?x!qalias> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @qcast_per_axis_unranked(%arg0: tensor<*xf32>) { |
| %0 = quant.qcast %arg0 : tensor<*xf32> to tensor<*x!qalias> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @scast_scalar(%arg0: i8) { |
| %0 = quant.scast %arg0 : i8 to !qalias |
| %1 = quant.scast %0 : !qalias to i8 |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @scast_ranked(%arg0: tensor<2x?x4xi8>) { |
| %0 = quant.scast %arg0 : tensor<2x?x4xi8> to tensor<2x?x4x!qalias> |
| %1 = quant.scast %0 : tensor<2x?x4x!qalias> to tensor<2x?x4xi8> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32, 1.0> |
| func.func @scast_unranked(%arg0: tensor<*xi8>) { |
| %0 = quant.scast %arg0 : tensor<*xi8> to tensor<*x!qalias> |
| %1 = quant.scast %0 : tensor<*x!qalias> to tensor<*xi8> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @scast_per_axis_static(%arg0: tensor<1x2x3xi8>) { |
| %0 = quant.scast %arg0 : tensor<1x2x3xi8> to tensor<1x2x3x!qalias> |
| %1 = quant.scast %0 : tensor<1x2x3x!qalias> to tensor<1x2x3xi8> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @scast_per_axis_dynamic(%arg0: tensor<?x?x?xi8>) { |
| %0 = quant.scast %arg0 : tensor<?x?x?xi8> to tensor<?x?x?x!qalias> |
| %1 = quant.scast %0 : tensor<?x?x?x!qalias> to tensor<?x?x?xi8> |
| return |
| } |
| |
| // ----- |
| |
| !qalias = !quant.uniform<i8:f32:2, {1.0, 2.0, 3.0}> |
| func.func @scast_per_axis_unranked(%arg0: tensor<*xi8>) { |
| %0 = quant.scast %arg0 : tensor<*xi8> to tensor<*x!qalias> |
| %1 = quant.scast %0 : tensor<*x!qalias> to tensor<*xi8> |
| return |
| } |
| |
| |