1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * Copyright (c) 2019 Guo Yejun
3cabdff1aSopenharmony_ci *
4cabdff1aSopenharmony_ci * This file is part of FFmpeg.
5cabdff1aSopenharmony_ci *
6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
10cabdff1aSopenharmony_ci *
11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14cabdff1aSopenharmony_ci * Lesser General Public License for more details.
15cabdff1aSopenharmony_ci *
16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19cabdff1aSopenharmony_ci */
20cabdff1aSopenharmony_ci
21cabdff1aSopenharmony_ci#include <stdio.h>
22cabdff1aSopenharmony_ci#include <string.h>
23cabdff1aSopenharmony_ci#include <math.h>
24cabdff1aSopenharmony_ci#include "libavfilter/dnn/dnn_backend_native_layer_maximum.h"
25cabdff1aSopenharmony_ci
26cabdff1aSopenharmony_ci#define EPSON 0.00001
27cabdff1aSopenharmony_ci
28cabdff1aSopenharmony_cistatic int test(void)
29cabdff1aSopenharmony_ci{
30cabdff1aSopenharmony_ci    DnnLayerMaximumParams params;
31cabdff1aSopenharmony_ci    DnnOperand operands[2];
32cabdff1aSopenharmony_ci    int32_t input_indexes[1];
33cabdff1aSopenharmony_ci    float input[1*1*2*3] = {
34cabdff1aSopenharmony_ci        -3, 2.5, 2, -2.1, 7.8, 100
35cabdff1aSopenharmony_ci    };
36cabdff1aSopenharmony_ci    float *output;
37cabdff1aSopenharmony_ci
38cabdff1aSopenharmony_ci    params.val.y = 2.3;
39cabdff1aSopenharmony_ci
40cabdff1aSopenharmony_ci    operands[0].data = input;
41cabdff1aSopenharmony_ci    operands[0].dims[0] = 1;
42cabdff1aSopenharmony_ci    operands[0].dims[1] = 1;
43cabdff1aSopenharmony_ci    operands[0].dims[2] = 2;
44cabdff1aSopenharmony_ci    operands[0].dims[3] = 3;
45cabdff1aSopenharmony_ci    operands[1].data = NULL;
46cabdff1aSopenharmony_ci
47cabdff1aSopenharmony_ci    input_indexes[0] = 0;
48cabdff1aSopenharmony_ci    ff_dnn_execute_layer_maximum(operands, input_indexes, 1, &params, NULL);
49cabdff1aSopenharmony_ci
50cabdff1aSopenharmony_ci    output = operands[1].data;
51cabdff1aSopenharmony_ci    for (int i = 0; i < sizeof(input) / sizeof(float); i++) {
52cabdff1aSopenharmony_ci        float expected_output = input[i] > params.val.y ? input[i] : params.val.y;
53cabdff1aSopenharmony_ci        if (fabs(output[i] - expected_output) > EPSON) {
54cabdff1aSopenharmony_ci            printf("at index %d, output: %f, expected_output: %f\n", i, output[i], expected_output);
55cabdff1aSopenharmony_ci            av_freep(&output);
56cabdff1aSopenharmony_ci            return 1;
57cabdff1aSopenharmony_ci        }
58cabdff1aSopenharmony_ci    }
59cabdff1aSopenharmony_ci
60cabdff1aSopenharmony_ci    av_freep(&output);
61cabdff1aSopenharmony_ci    return 0;
62cabdff1aSopenharmony_ci
63cabdff1aSopenharmony_ci}
64cabdff1aSopenharmony_ci
65cabdff1aSopenharmony_ciint main(int argc, char **argv)
66cabdff1aSopenharmony_ci{
67cabdff1aSopenharmony_ci    if (test())
68cabdff1aSopenharmony_ci        return 1;
69cabdff1aSopenharmony_ci
70cabdff1aSopenharmony_ci    return 0;
71cabdff1aSopenharmony_ci}
72