// Copyright 2020 Google LLC // // This source code is licensed under the BSD-style license found in the // LICENSE file in the root directory of this source tree. #include #include #include #include #include #include #include enum xnn_status xnn_define_leaky_relu( xnn_subgraph_t subgraph, float negative_slope, uint32_t input_id, uint32_t output_id, uint32_t flags) { if ((xnn_params.init_flags & XNN_INIT_FLAG_XNNPACK) == 0) { xnn_log_error("failed to define %s operator: XNNPACK is not initialized", xnn_node_type_to_string(xnn_node_type_leaky_relu)); return xnn_status_uninitialized; } if (!isfinite(negative_slope)) { xnn_log_error( "failed to create %s operator with %f negative slope: finite number expected", xnn_node_type_to_string(xnn_node_type_leaky_relu), negative_slope); return xnn_status_invalid_parameter; } if (input_id >= subgraph->num_values) { xnn_log_error( "failed to define %s operator with input ID #%" PRIu32 ": invalid Value ID", xnn_node_type_to_string(xnn_node_type_leaky_relu), input_id); return xnn_status_invalid_parameter; } if (output_id >= subgraph->num_values) { xnn_log_error( "failed to define %s operator with output ID #%" PRIu32 ": invalid Value ID", xnn_node_type_to_string(xnn_node_type_leaky_relu), output_id); return xnn_status_invalid_parameter; } struct xnn_node* node = xnn_subgraph_new_node(subgraph); if (node == NULL) { return xnn_status_out_of_memory; } node->type = xnn_node_type_leaky_relu; node->params.leaky_relu.negative_slope = negative_slope; node->num_inputs = 1; node->inputs[0] = input_id; node->num_outputs = 1; node->outputs[0] = output_id; node->flags = flags; return xnn_status_success; }