|
|
|
@@ -301,7 +301,7 @@ AbstractBasePtr InferImplLayerNorm(const AnalysisEnginePtr &, const PrimitivePtr |
|
|
|
|
|
|
|
// begin_norm_axis and begin_params_axis should be smaller than the size of input_x and >= -1 |
|
|
|
ValuePtr bna_ptr = primitive->GetAttr("begin_norm_axis"); |
|
|
|
(void)CheckAxis(op_name, bna_ptr, -1, SizeToInt(input_rank) - 1); |
|
|
|
int begin_norm_axis = CheckAxis(op_name, bna_ptr, -1, SizeToInt(input_rank) - 1); |
|
|
|
|
|
|
|
ValuePtr bpa_ptr = primitive->GetAttr("begin_params_axis"); |
|
|
|
int begin_params_axis = CheckAxis(op_name, bpa_ptr, -1, SizeToInt(input_rank) - 1); |
|
|
|
@@ -341,7 +341,13 @@ AbstractBasePtr InferImplLayerNorm(const AnalysisEnginePtr &, const PrimitivePtr |
|
|
|
} |
|
|
|
|
|
|
|
auto mean_var_shape_value = input_shape->shape(); |
|
|
|
mean_var_shape_value[input_rank - 1] = 1; |
|
|
|
if (begin_norm_axis == -1) { |
|
|
|
mean_var_shape_value[input_rank - 1] = 1; |
|
|
|
} else { |
|
|
|
for (size_t i = begin_norm_axis; i < input_rank; ++i) { |
|
|
|
mean_var_shape_value[i] = 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
auto mean = input_x->Broaden(); |
|
|
|
mean->set_shape(std::make_shared<Shape>(mean_var_shape_value)); |
|
|
|
|