aboutsummaryrefslogtreecommitdiffstats
path: root/tests/checkasm/apv_dsp.c
blob: 6d3a35683889fe5028d76f7d3c656c3df4a3933f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
 * This file is part of FFmpeg.
 *
 * FFmpeg is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * FFmpeg is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with FFmpeg; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 */

#include <stdint.h>

#include "checkasm.h"

#include "libavutil/attributes.h"
#include "libavutil/mem_internal.h"
#include "libavcodec/apv_dsp.h"


static void check_decode_transquant_8(void)
{
    LOCAL_ALIGNED_16(int16_t, input,      [64]);
    LOCAL_ALIGNED_16(int16_t, qmatrix,    [64]);
    LOCAL_ALIGNED_16(uint8_t, new_output, [64]);
    LOCAL_ALIGNED_16(uint8_t, ref_output, [64]);

    declare_func(void,
                 void *output,
                 ptrdiff_t pitch,
                 const int16_t *input,
                 const int16_t *qmatrix,
                 int bit_depth,
                 int qp_shift);

    for (int i = 0; i < 64; i++) {
        // Any signed 12-bit integer.
        input[i] = rnd() % 2048 - 1024;

        // qmatrix input is premultiplied by level_scale, so
        // range is 1 to 255 * 71.  Interesting values are all
        // at the low end of that, though.
        qmatrix[i] = rnd() % 16 + 16;
    }

    call_ref(ref_output, 8, input, qmatrix, 8, 4);
    call_new(new_output, 8, input, qmatrix, 8, 4);

    if (memcmp(new_output, ref_output, 64 * sizeof(*ref_output)))
        fail();

    bench_new(new_output, 8, input, qmatrix, 8, 4);
}

static void check_decode_transquant_10(void)
{
    LOCAL_ALIGNED_16( int16_t, input,      [64]);
    LOCAL_ALIGNED_16( int16_t, qmatrix,    [64]);
    LOCAL_ALIGNED_16(uint16_t, new_output, [64]);
    LOCAL_ALIGNED_16(uint16_t, ref_output, [64]);

    declare_func(void,
                 void *output,
                 ptrdiff_t pitch,
                 const int16_t *input,
                 const int16_t *qmatrix,
                 int bit_depth,
                 int qp_shift);

    for (int i = 0; i < 64; i++) {
        // Any signed 14-bit integer.
        input[i] = rnd() % 16384 - 8192;

        // qmatrix input is premultiplied by level_scale, so
        // range is 1 to 255 * 71.  Interesting values are all
        // at the low end of that, though.
        qmatrix[i] = 16; //rnd() % 16 + 16;
    }

    call_ref(ref_output, 16, input, qmatrix, 10, 4);
    call_new(new_output, 16, input, qmatrix, 10, 4);

    if (memcmp(new_output, ref_output, 64 * sizeof(*ref_output)))
        fail();

    bench_new(new_output, 16, input, qmatrix, 10, 4);
}

void checkasm_check_apv_dsp(void)
{
    APVDSPContext dsp;

    ff_apv_dsp_init(&dsp);

    if (check_func(dsp.decode_transquant, "decode_transquant_8"))
        check_decode_transquant_8();

    if (check_func(dsp.decode_transquant, "decode_transquant_10"))
        check_decode_transquant_10();

    report("decode_transquant");
}