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
|
// Copyright (c) the JPEG XL Project Authors. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
#include <string>
#include "lib/extras/codec.h"
#include "lib/jxl/base/data_parallel.h"
#include "lib/jxl/base/padded_bytes.h"
#include "lib/jxl/codec_in_out.h"
#include "lib/jxl/enc_butteraugli_comparator.h"
#include "lib/jxl/enc_cache.h"
#include "lib/jxl/enc_color_management.h"
#include "lib/jxl/enc_file.h"
#include "lib/jxl/enc_params.h"
#include "lib/jxl/image.h"
#include "lib/jxl/image_test_utils.h"
#include "lib/jxl/test_utils.h"
#include "lib/jxl/testing.h"
namespace jxl {
namespace {
struct SpeedTierTestParams {
explicit SpeedTierTestParams(const SpeedTier speed_tier,
const bool shrink8 = false)
: speed_tier(speed_tier), shrink8(shrink8) {}
SpeedTier speed_tier;
bool shrink8;
};
std::ostream& operator<<(std::ostream& os, SpeedTierTestParams params) {
auto previous_flags = os.flags();
os << std::boolalpha;
os << "SpeedTierTestParams{" << static_cast<size_t>(params.speed_tier)
<< ", /*shrink8=*/" << params.shrink8 << "}";
os.flags(previous_flags);
return os;
}
class SpeedTierTest : public testing::TestWithParam<SpeedTierTestParams> {};
JXL_GTEST_INSTANTIATE_TEST_SUITE_P(
SpeedTierTestInstantiation, SpeedTierTest,
testing::Values(SpeedTierTestParams{SpeedTier::kCheetah,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kCheetah,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kThunder,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kThunder,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kLightning,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kLightning,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kFalcon,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kFalcon,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kHare,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kHare,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kWombat,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kWombat,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kSquirrel,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kSquirrel,
/*shrink8=*/false},
SpeedTierTestParams{SpeedTier::kKitten,
/*shrink8=*/true},
SpeedTierTestParams{SpeedTier::kKitten,
/*shrink8=*/false},
// Only downscaled image for Tortoise mode.
SpeedTierTestParams{SpeedTier::kTortoise,
/*shrink8=*/true}));
TEST_P(SpeedTierTest, Roundtrip) {
const PaddedBytes orig = jxl::test::ReadTestData(
"external/wesaturate/500px/u76c0g_bliznaca_srgb8.png");
CodecInOut io;
test::ThreadPoolForTests pool(8);
ASSERT_TRUE(SetFromBytes(Span<const uint8_t>(orig), &io, &pool));
const SpeedTierTestParams& params = GetParam();
if (params.shrink8) {
io.ShrinkTo(io.xsize() / 8, io.ysize() / 8);
}
CompressParams cparams;
cparams.speed_tier = params.speed_tier;
CodecInOut io2;
JXL_EXPECT_OK(test::Roundtrip(&io, cparams, {}, &io2, _));
// Can be 2.2 in non-hare mode.
EXPECT_LE(
ButteraugliDistance(io.frames, io2.frames, cparams.ba_params, GetJxlCms(),
/*distmap=*/nullptr, /*pool=*/nullptr),
2.8);
}
} // namespace
} // namespace jxl
|