| /* |
| * Copyright (c) 2021, Alliance for Open Media. All rights reserved |
| * |
| * This source code is subject to the terms of the BSD 3-Clause Clear License |
| * and the Alliance for Open Media Patent License 1.0. If the BSD 3-Clause Clear |
| * License was not distributed with this source code in the LICENSE file, you |
| * can obtain it at aomedia.org/license/software-license/bsd-3-c-c/. If the |
| * Alliance for Open Media Patent License 1.0 was not distributed with this |
| * source code in the PATENTS file, you can obtain it at |
| * aomedia.org/license/patent-license/. |
| */ |
| |
| #include "third_party/googletest/src/googletest/include/gtest/gtest.h" |
| #include "test/acm_random.h" |
| |
| using libaom_test::ACMRandom; |
| |
| extern "C" { |
| int av1_neg_interleave(int x, int ref, int max); |
| int av1_neg_deinterleave(int diff, int ref, int max); |
| } |
| |
| namespace { |
| |
| struct Segment { |
| int id; |
| int pred; |
| int last_id; |
| }; |
| |
| Segment GenerateSegment(int seed) { |
| static const int MAX_SEGMENTS = 8; |
| |
| ACMRandom rnd_(seed); |
| |
| Segment segment; |
| const int last_segid = rnd_.PseudoUniform(MAX_SEGMENTS); |
| segment.last_id = last_segid; |
| segment.pred = rnd_.PseudoUniform(MAX_SEGMENTS); |
| segment.id = rnd_.PseudoUniform(last_segid + 1); |
| |
| return segment; |
| } |
| |
| // Try to reveal a mismatch between segment binarization and debinarization |
| TEST(SegmentBinarizationSync, SearchForBinarizationMismatch) { |
| const int count_tests = 1000; |
| const int seed_init = 4321; |
| |
| for (int i = 0; i < count_tests; ++i) { |
| const Segment seg = GenerateSegment(seed_init + i); |
| |
| const int max_segid = seg.last_id + 1; |
| const int seg_diff = av1_neg_interleave(seg.id, seg.pred, max_segid); |
| const int decoded_segid = |
| av1_neg_deinterleave(seg_diff, seg.pred, max_segid); |
| |
| ASSERT_EQ(decoded_segid, seg.id); |
| } |
| } |
| |
| } // namespace |