File: context_regular_mode.cpp

package info (click to toggle)
charls 2.4.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 17,636 kB
  • sloc: cpp: 13,392; ansic: 986; makefile: 22
file content (63 lines) | stat: -rw-r--r-- 1,813 bytes parent folder | download | duplicates (2)
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
// Copyright (c) Team CharLS.
// SPDX-License-Identifier: BSD-3-Clause

#include <benchmark/benchmark.h>

#include "context_regular_mode_v220.h"

#pragma warning(disable : 26409) // Avoid calling new explicitly (triggered by BENCHMARK macro)

using namespace charls;

context_regular_mode g_context;
jls_context_v220 g_context_v220;

volatile int32_t error_value;
volatile int32_t near_lossless;
volatile int32_t reset_threshold{64};

static void bm_regular_mode_update_variables_220(benchmark::State& state)
{
    g_context_v220 = jls_context_v220();

    for (const auto _ : state)
    {
        g_context_v220.update_variables(error_value, near_lossless, reset_threshold);
    }
}
BENCHMARK(bm_regular_mode_update_variables_220);

static void bm_regular_mode_update_variables(benchmark::State& state)
{
    g_context = context_regular_mode();

    for (const auto _ : state)
    {
        g_context.update_variables_and_bias(error_value, near_lossless, reset_threshold);
    }
}
BENCHMARK(bm_regular_mode_update_variables);

static void bm_regular_mode_get_golomb_coding_parameter_v220(benchmark::State& state)
{
    g_context_v220 = jls_context_v220();
    g_context_v220.update_variables(error_value, near_lossless, reset_threshold);

    for (const auto _ : state)
    {
        benchmark::DoNotOptimize(g_context_v220.get_golomb_coding_parameter());
    }
}
BENCHMARK(bm_regular_mode_get_golomb_coding_parameter_v220);

static void bm_regular_mode_get_golomb_coding_parameter(benchmark::State& state)
{
    g_context = context_regular_mode();
    g_context.update_variables_and_bias(error_value, near_lossless, reset_threshold);

    for (const auto _ : state)
    {
        benchmark::DoNotOptimize(g_context.get_golomb_coding_parameter());
    }
}
BENCHMARK(bm_regular_mode_get_golomb_coding_parameter);