[FFmpeg-devel] [PATCH] checkasm/hevc_deblock: adjust RANDCLIP to clip after rng()

Stone Chen chen.stonechen at gmail.com
Sun Feb 16 02:16:50 EET 2025


Increase chances of generating a strong deblock test case by changing RANDCLIP to generate the random value first before clipping.

RANDCLIP(x, diff) attempts to generate a random value such the distance to x is less than diff. This is also clipped to the pixel range. This is done by subtracting diff from x and adding a random value between 0 and 2*diff. However since this occurs after clipping, if e.g. x - diff is negative, then it's possible to exceed the diff. Instead generate the number first and then clip.

Signed-off-by: Stone Chen <chen.stonechen at gmail.com>
---
 tests/checkasm/hevc_deblock.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/tests/checkasm/hevc_deblock.c b/tests/checkasm/hevc_deblock.c
index 89dd8a308b..46faf34c2d 100644
--- a/tests/checkasm/hevc_deblock.c
+++ b/tests/checkasm/hevc_deblock.c
@@ -104,8 +104,8 @@ static void check_deblock_chroma(HEVCDSPContext *h, int bit_depth, int c)
     else \
         *(uint16_t*)(&x) = z; \
 } while (0)
-#define RANDCLIP(x, diff) av_clip(GET(x) - (diff), 0, \
-    (1 << (bit_depth)) - 1) + rnd() % FFMAX(2 * (diff), 1)
+#define RANDCLIP(x, diff) av_clip(GET(x) - (diff) + rnd() % FFMAX(2 * (diff), 1), 0, \
+    (1 << (bit_depth)) - 1)
 
 // NOTE: this function doesn't work 'correctly' in that it won't always choose
 // strong/strong or weak/weak, in most cases it tends to but will sometimes mix
-- 
2.47.1.windows.1



More information about the ffmpeg-devel mailing list